nostr-tools 0.7.2 → 0.9.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.
Files changed (3) hide show
  1. package/package.json +1 -1
  2. package/pool.js +8 -4
  3. package/relay.js +22 -11
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nostr-tools",
3
- "version": "0.7.2",
3
+ "version": "0.9.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
 
@@ -29,19 +29,23 @@ export function relayPool(globalPrivateKey) {
29
29
  const activeFilters = filter
30
30
 
31
31
  activeSubscriptions[id] = {
32
- sub: ({cb = activeCallback, filter = activeFilters}) =>
32
+ sub: ({cb = activeCallback, filter = activeFilters}) => {
33
33
  Object.entries(subControllers).map(([relayURL, sub]) => [
34
34
  relayURL,
35
35
  sub.sub({cb, filter}, id)
36
- ]),
36
+ ])
37
+ return activeSubscriptions[id]
38
+ },
37
39
  addRelay: relay => {
38
- subControllers[relay.url] = relay.sub({cb, filter})
40
+ subControllers[relay.url] = relay.sub({cb, filter}, id)
41
+ return activeSubscriptions[id]
39
42
  },
40
43
  removeRelay: relayURL => {
41
44
  if (relayURL in subControllers) {
42
45
  subControllers[relayURL].unsub()
43
46
  if (Object.keys(subControllers).length === 0) unsub()
44
47
  }
48
+ return activeSubscriptions[id]
45
49
  },
46
50
  unsub: () => {
47
51
  Object.values(subControllers).forEach(sub => sub.unsub())
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)