Compare commits

..

3 Commits

Author SHA1 Message Date
fiatjaf
fff31b5ff4 automatically run received events through the filters they should pass (double-check the work made by the relay). 2021-12-14 22:00:42 -03:00
fiatjaf
cd7ffb8911 add local event filter functions. 2021-12-14 21:56:07 -03:00
fiatjaf
4f0cae0eb8 add missing id arguments. 2021-12-13 21:22:23 -03:00
5 changed files with 48 additions and 13 deletions

26
filter.js Normal file
View File

@@ -0,0 +1,26 @@
export function matchFilter(filter, event) {
if (filter.id && event.id !== filter.id) return false
if (filter.kind && event.kind !== filter.kind) return false
if (filter.author && event.pubkey !== filter.author) return false
if (filter.authors && filter.author.indexOf(event.pubkey) === -1) return false
if (
filter['#e'] &&
event.tags.find(([t, v]) => t === 'e' && v === filter['#e']) === null
)
return false
if (
filter['#p'] &&
event.tags.find(([t, v]) => t === 'p' && v === filter['#p']) === null
)
return false
if (filter.since && event.created_at <= filter.since) return false
return true
}
export function matchFilters(filters, event) {
for (let i = 0; i < filters.length; i++) {
if (matchFilter(filters[i], event)) return true
}
return false
}

View File

@@ -7,6 +7,7 @@ import {
serializeEvent,
getEventHash
} from './event'
import {matchFilter, matchFilters} from './filter'
import {makeRandom32, sha256, getPublicKey} from './utils'
export {
@@ -19,5 +20,7 @@ export {
makeRandom32,
sha256,
getPublicKey,
getBlankEvent
getBlankEvent,
matchFilter,
matchFilters
}

View File

@@ -1,6 +1,6 @@
{
"name": "nostr-tools",
"version": "0.9.0",
"version": "0.10.1",
"description": "Tools for making a Nostr client.",
"repository": {
"type": "git",

View File

@@ -21,7 +21,7 @@ export function relayPool(globalPrivateKey) {
.filter(({policy}) => policy.read)
.map(({relay}) => [
relay.url,
relay.sub({filter, cb: event => cb(event, relay.url)})
relay.sub({filter, cb: event => cb(event, relay.url)}, id)
])
)
@@ -37,7 +37,7 @@ export function relayPool(globalPrivateKey) {
return activeSubscriptions[id]
},
addRelay: relay => {
subControllers[relay.url] = relay.sub({cb, filter})
subControllers[relay.url] = relay.sub({cb, filter}, id)
return activeSubscriptions[id]
},
removeRelay: relayURL => {

View File

@@ -1,6 +1,7 @@
import 'websocket-polyfill'
import {verifySignature} from './event'
import {matchFilters} from './filter'
export function normalizeRelayURL(url) {
let [host, ...qs] = url.split('?')
@@ -88,10 +89,12 @@ export function relayConnect(url, onNotice) {
let channel = data[1]
let event = data[2]
if (await verifySignature(event)) {
if (channels[channel]) {
channels[channel](event)
}
if (
(await verifySignature(event)) &&
channels[channel] &&
matchFilters(openSubs[channel], event)
) {
channels[channel](event)
}
return
}
@@ -145,12 +148,15 @@ export function relayConnect(url, onNotice) {
try {
await trySend(['EVENT', event])
statusCallback(0)
let {unsub} = relay.sub({
cb: () => {
statusCallback(1)
let {unsub} = relay.sub(
{
cb: () => {
statusCallback(1)
},
filter: {id: event.id}
},
filter: {id: event.id}
})
`monitor-${event.id.slice(0, 5)}`
)
setTimeout(unsub, 5000)
} catch (err) {
statusCallback(-1)