nostr-tools 0.8.0 → 0.10.0

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.0",
3
+ "version": "0.10.0",
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
@@ -13,7 +13,7 @@ export function normalizeRelayURL(url) {
13
13
  export function relayConnect(url, onNotice) {
14
14
  url = normalizeRelayURL(url)
15
15
 
16
- var ws, resolveOpen, untilOpen
16
+ var ws, resolveOpen, untilOpen, wasClosed
17
17
  var openSubs = {}
18
18
  let attemptNumber = 1
19
19
  let nextAttemptSeconds = 1
@@ -34,10 +34,13 @@ export function relayConnect(url, onNotice) {
34
34
  resolveOpen()
35
35
 
36
36
  // 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)
37
+ if (wasClosed) {
38
+ wasClosed = false
39
+ for (let channel in openSubs) {
40
+ let filters = openSubs[channel]
41
+ let cb = channels[channel]
42
+ sub({cb, filter: filters}, channel)
43
+ }
41
44
  }
42
45
  }
43
46
  ws.onerror = () => {
@@ -46,7 +49,10 @@ export function relayConnect(url, onNotice) {
46
49
  ws.onclose = () => {
47
50
  resetOpenState()
48
51
  attemptNumber++
49
- nextAttemptSeconds += attemptNumber
52
+ nextAttemptSeconds += attemptNumber ** 3
53
+ if (nextAttemptSeconds > 14400) {
54
+ nextAttemptSeconds = 14400 // 4 hours
55
+ }
50
56
  console.log(
51
57
  `relay ${url} connection closed. reconnecting in ${nextAttemptSeconds} seconds.`
52
58
  )
@@ -55,6 +61,8 @@ export function relayConnect(url, onNotice) {
55
61
  connect()
56
62
  } catch (err) {}
57
63
  }, nextAttemptSeconds * 1000)
64
+
65
+ wasClosed = true
58
66
  }
59
67
 
60
68
  ws.onmessage = async e => {
@@ -137,12 +145,15 @@ export function relayConnect(url, onNotice) {
137
145
  try {
138
146
  await trySend(['EVENT', event])
139
147
  statusCallback(0)
140
- let {unsub} = relay.sub({
141
- cb: () => {
142
- statusCallback(1)
148
+ let {unsub} = relay.sub(
149
+ {
150
+ cb: () => {
151
+ statusCallback(1)
152
+ },
153
+ filter: {id: event.id}
143
154
  },
144
- filter: {id: event.id}
145
- })
155
+ `monitor-${event.id.slice(0, 5)}`
156
+ )
146
157
  setTimeout(unsub, 5000)
147
158
  } catch (err) {
148
159
  statusCallback(-1)