nostr-tools 0.8.1 → 0.10.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/filter.js ADDED
@@ -0,0 +1,26 @@
1
+ export function matchFilter(filter, event) {
2
+ if (filter.id && event.id !== filter.id) return false
3
+ if (filter.kind && event.kind !== filter.kind) return false
4
+ if (filter.author && event.pubkey !== filter.author) return false
5
+ if (filter.authors && filter.author.indexOf(event.pubkey) === -1) return false
6
+ if (
7
+ filter['#e'] &&
8
+ event.tags.find(([t, v]) => t === 'e' && v === filter['#e']) === null
9
+ )
10
+ return false
11
+ if (
12
+ filter['#p'] &&
13
+ event.tags.find(([t, v]) => t === 'p' && v === filter['#p']) === null
14
+ )
15
+ return false
16
+ if (filter.since && event.created_at <= filter.since) return false
17
+
18
+ return true
19
+ }
20
+
21
+ export function matchFilters(filters, event) {
22
+ for (let i = 0; i < filters.length; i++) {
23
+ if (matchFilter(filters[i], event)) return true
24
+ }
25
+ return false
26
+ }
package/index.js CHANGED
@@ -7,6 +7,7 @@ import {
7
7
  serializeEvent,
8
8
  getEventHash
9
9
  } from './event'
10
+ import {matchFilter, matchFilters} from './filter'
10
11
  import {makeRandom32, sha256, getPublicKey} from './utils'
11
12
 
12
13
  export {
@@ -19,5 +20,7 @@ export {
19
20
  makeRandom32,
20
21
  sha256,
21
22
  getPublicKey,
22
- getBlankEvent
23
+ getBlankEvent,
24
+ matchFilter,
25
+ matchFilters
23
26
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nostr-tools",
3
- "version": "0.8.1",
3
+ "version": "0.10.1",
4
4
  "description": "Tools for making a Nostr client.",
5
5
  "repository": {
6
6
  "type": "git",
package/pool.js CHANGED
@@ -21,7 +21,7 @@ export function relayPool(globalPrivateKey) {
21
21
  .filter(({policy}) => policy.read)
22
22
  .map(({relay}) => [
23
23
  relay.url,
24
- relay.sub({filter, cb: event => cb(event, relay.url)})
24
+ relay.sub({filter, cb: event => cb(event, relay.url)}, id)
25
25
  ])
26
26
  )
27
27
 
@@ -37,7 +37,7 @@ export function relayPool(globalPrivateKey) {
37
37
  return activeSubscriptions[id]
38
38
  },
39
39
  addRelay: relay => {
40
- subControllers[relay.url] = relay.sub({cb, filter})
40
+ subControllers[relay.url] = relay.sub({cb, filter}, id)
41
41
  return activeSubscriptions[id]
42
42
  },
43
43
  removeRelay: relayURL => {
package/relay.js CHANGED
@@ -1,6 +1,7 @@
1
1
  import 'websocket-polyfill'
2
2
 
3
3
  import {verifySignature} from './event'
4
+ import {matchFilters} from './filter'
4
5
 
5
6
  export function normalizeRelayURL(url) {
6
7
  let [host, ...qs] = url.split('?')
@@ -13,7 +14,7 @@ export function normalizeRelayURL(url) {
13
14
  export function relayConnect(url, onNotice) {
14
15
  url = normalizeRelayURL(url)
15
16
 
16
- var ws, resolveOpen, untilOpen
17
+ var ws, resolveOpen, untilOpen, wasClosed
17
18
  var openSubs = {}
18
19
  let attemptNumber = 1
19
20
  let nextAttemptSeconds = 1
@@ -34,10 +35,13 @@ export function relayConnect(url, onNotice) {
34
35
  resolveOpen()
35
36
 
36
37
  // restablish old subscriptions
37
- for (let channel in openSubs) {
38
- let filters = openSubs[channel]
39
- let cb = channels[channel]
40
- sub({cb, filter: filters}, channel)
38
+ if (wasClosed) {
39
+ wasClosed = false
40
+ for (let channel in openSubs) {
41
+ let filters = openSubs[channel]
42
+ let cb = channels[channel]
43
+ sub({cb, filter: filters}, channel)
44
+ }
41
45
  }
42
46
  }
43
47
  ws.onerror = () => {
@@ -58,6 +62,8 @@ export function relayConnect(url, onNotice) {
58
62
  connect()
59
63
  } catch (err) {}
60
64
  }, nextAttemptSeconds * 1000)
65
+
66
+ wasClosed = true
61
67
  }
62
68
 
63
69
  ws.onmessage = async e => {
@@ -83,10 +89,12 @@ export function relayConnect(url, onNotice) {
83
89
  let channel = data[1]
84
90
  let event = data[2]
85
91
 
86
- if (await verifySignature(event)) {
87
- if (channels[channel]) {
88
- channels[channel](event)
89
- }
92
+ if (
93
+ (await verifySignature(event)) &&
94
+ channels[channel] &&
95
+ matchFilters(openSubs[channel], event)
96
+ ) {
97
+ channels[channel](event)
90
98
  }
91
99
  return
92
100
  }
@@ -140,12 +148,15 @@ export function relayConnect(url, onNotice) {
140
148
  try {
141
149
  await trySend(['EVENT', event])
142
150
  statusCallback(0)
143
- let {unsub} = relay.sub({
144
- cb: () => {
145
- statusCallback(1)
151
+ let {unsub} = relay.sub(
152
+ {
153
+ cb: () => {
154
+ statusCallback(1)
155
+ },
156
+ filter: {id: event.id}
146
157
  },
147
- filter: {id: event.id}
148
- })
158
+ `monitor-${event.id.slice(0, 5)}`
159
+ )
149
160
  setTimeout(unsub, 5000)
150
161
  } catch (err) {
151
162
  statusCallback(-1)