@aztec/p2p 0.67.0 → 0.67.1-devnet

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 (144) hide show
  1. package/dest/bootstrap/bootstrap.js +2 -2
  2. package/dest/client/index.d.ts +5 -4
  3. package/dest/client/index.d.ts.map +1 -1
  4. package/dest/client/index.js +12 -9
  5. package/dest/client/p2p_client.d.ts +6 -6
  6. package/dest/client/p2p_client.d.ts.map +1 -1
  7. package/dest/client/p2p_client.js +12 -11
  8. package/dest/config.d.ts +1 -1
  9. package/dest/config.d.ts.map +1 -1
  10. package/dest/config.js +2 -2
  11. package/dest/errors/reqresp.error.d.ts +12 -1
  12. package/dest/errors/reqresp.error.d.ts.map +1 -1
  13. package/dest/errors/reqresp.error.js +15 -2
  14. package/dest/index.d.ts +1 -1
  15. package/dest/index.d.ts.map +1 -1
  16. package/dest/index.js +2 -2
  17. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +9 -0
  18. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -1
  19. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts +3 -0
  20. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts.map +1 -0
  21. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.js +171 -0
  22. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +29 -0
  23. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +1 -0
  24. package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +114 -0
  25. package/dest/mem_pools/interface.d.ts +4 -3
  26. package/dest/mem_pools/interface.d.ts.map +1 -1
  27. package/dest/mocks/index.d.ts +6 -6
  28. package/dest/mocks/index.d.ts.map +1 -1
  29. package/dest/mocks/index.js +8 -8
  30. package/dest/services/data_store.d.ts.map +1 -0
  31. package/dest/services/data_store.js +188 -0
  32. package/dest/{service → services/discv5}/discV5_service.d.ts +2 -2
  33. package/dest/services/discv5/discV5_service.d.ts.map +1 -0
  34. package/dest/services/discv5/discV5_service.js +144 -0
  35. package/dest/services/dummy_service.d.ts.map +1 -0
  36. package/dest/{service → services}/dummy_service.js +1 -1
  37. package/dest/{service → services}/encoding.d.ts +5 -0
  38. package/dest/services/encoding.d.ts.map +1 -0
  39. package/dest/services/encoding.js +65 -0
  40. package/dest/services/index.d.ts +3 -0
  41. package/dest/services/index.d.ts.map +1 -0
  42. package/dest/services/index.js +3 -0
  43. package/dest/{service → services/libp2p}/libp2p_service.d.ts +48 -10
  44. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -0
  45. package/dest/services/libp2p/libp2p_service.js +573 -0
  46. package/dest/{service → services/peer-scoring}/peer_scoring.d.ts +1 -1
  47. package/dest/services/peer-scoring/peer_scoring.d.ts.map +1 -0
  48. package/dest/services/peer-scoring/peer_scoring.js +72 -0
  49. package/dest/{service → services}/peer_manager.d.ts +5 -3
  50. package/dest/services/peer_manager.d.ts.map +1 -0
  51. package/dest/services/peer_manager.js +230 -0
  52. package/dest/services/reqresp/config.d.ts.map +1 -0
  53. package/dest/{service → services}/reqresp/config.js +1 -1
  54. package/dest/services/reqresp/handlers.d.ts.map +1 -0
  55. package/dest/{service → services}/reqresp/handlers.js +1 -1
  56. package/dest/services/reqresp/index.d.ts.map +1 -0
  57. package/dest/{service → services}/reqresp/index.js +1 -1
  58. package/dest/services/reqresp/interface.d.ts.map +1 -0
  59. package/dest/{service → services}/reqresp/interface.js +1 -1
  60. package/dest/services/reqresp/rate_limiter/index.d.ts.map +1 -0
  61. package/dest/{service → services}/reqresp/rate_limiter/index.js +1 -1
  62. package/dest/services/reqresp/rate_limiter/rate_limiter.d.ts.map +1 -0
  63. package/dest/{service → services}/reqresp/rate_limiter/rate_limiter.js +2 -2
  64. package/dest/services/reqresp/rate_limiter/rate_limits.d.ts.map +1 -0
  65. package/dest/{service → services}/reqresp/rate_limiter/rate_limits.js +1 -1
  66. package/dest/{service → services}/reqresp/reqresp.d.ts +16 -0
  67. package/dest/services/reqresp/reqresp.d.ts.map +1 -0
  68. package/dest/services/reqresp/reqresp.js +279 -0
  69. package/dest/services/service.d.ts.map +1 -0
  70. package/dest/{service → services}/service.js +1 -1
  71. package/dest/tx_validator/aggregate_tx_validator.d.ts +1 -1
  72. package/dest/tx_validator/aggregate_tx_validator.d.ts.map +1 -1
  73. package/dest/tx_validator/aggregate_tx_validator.js +5 -3
  74. package/dest/tx_validator/double_spend_validator.d.ts +3 -2
  75. package/dest/tx_validator/double_spend_validator.d.ts.map +1 -1
  76. package/dest/tx_validator/double_spend_validator.js +6 -6
  77. package/package.json +8 -7
  78. package/src/bootstrap/bootstrap.ts +1 -1
  79. package/src/client/index.ts +38 -16
  80. package/src/client/p2p_client.ts +28 -15
  81. package/src/config.ts +1 -1
  82. package/src/errors/reqresp.error.ts +15 -1
  83. package/src/index.ts +1 -1
  84. package/src/mem_pools/attestation_pool/attestation_pool.ts +10 -0
  85. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +237 -0
  86. package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +153 -0
  87. package/src/mem_pools/interface.ts +5 -3
  88. package/src/mocks/index.ts +13 -10
  89. package/src/{service → services/discv5}/discV5_service.ts +3 -3
  90. package/src/{service → services}/encoding.ts +21 -3
  91. package/src/services/index.ts +2 -0
  92. package/src/{service → services/libp2p}/libp2p_service.ts +192 -86
  93. package/src/{service → services/peer-scoring}/peer_scoring.ts +1 -1
  94. package/src/{service → services}/peer_manager.ts +5 -2
  95. package/src/{service → services}/reqresp/rate_limiter/rate_limiter.ts +1 -1
  96. package/src/{service → services}/reqresp/reqresp.ts +83 -17
  97. package/src/tx_validator/aggregate_tx_validator.ts +5 -3
  98. package/src/tx_validator/double_spend_validator.ts +6 -8
  99. package/dest/service/data_store.d.ts.map +0 -1
  100. package/dest/service/data_store.js +0 -188
  101. package/dest/service/discV5_service.d.ts.map +0 -1
  102. package/dest/service/discV5_service.js +0 -144
  103. package/dest/service/dummy_service.d.ts.map +0 -1
  104. package/dest/service/encoding.d.ts.map +0 -1
  105. package/dest/service/encoding.js +0 -49
  106. package/dest/service/index.d.ts +0 -3
  107. package/dest/service/index.d.ts.map +0 -1
  108. package/dest/service/index.js +0 -3
  109. package/dest/service/libp2p_service.d.ts.map +0 -1
  110. package/dest/service/libp2p_service.js +0 -500
  111. package/dest/service/peer_manager.d.ts.map +0 -1
  112. package/dest/service/peer_manager.js +0 -214
  113. package/dest/service/peer_scoring.d.ts.map +0 -1
  114. package/dest/service/peer_scoring.js +0 -72
  115. package/dest/service/reqresp/config.d.ts.map +0 -1
  116. package/dest/service/reqresp/handlers.d.ts.map +0 -1
  117. package/dest/service/reqresp/index.d.ts.map +0 -1
  118. package/dest/service/reqresp/interface.d.ts.map +0 -1
  119. package/dest/service/reqresp/rate_limiter/index.d.ts.map +0 -1
  120. package/dest/service/reqresp/rate_limiter/rate_limiter.d.ts.map +0 -1
  121. package/dest/service/reqresp/rate_limiter/rate_limits.d.ts.map +0 -1
  122. package/dest/service/reqresp/reqresp.d.ts.map +0 -1
  123. package/dest/service/reqresp/reqresp.js +0 -230
  124. package/dest/service/service.d.ts.map +0 -1
  125. package/src/service/index.ts +0 -2
  126. /package/dest/{service → services}/data_store.d.ts +0 -0
  127. /package/dest/{service → services}/dummy_service.d.ts +0 -0
  128. /package/dest/{service → services}/reqresp/config.d.ts +0 -0
  129. /package/dest/{service → services}/reqresp/handlers.d.ts +0 -0
  130. /package/dest/{service → services}/reqresp/index.d.ts +0 -0
  131. /package/dest/{service → services}/reqresp/interface.d.ts +0 -0
  132. /package/dest/{service → services}/reqresp/rate_limiter/index.d.ts +0 -0
  133. /package/dest/{service → services}/reqresp/rate_limiter/rate_limiter.d.ts +0 -0
  134. /package/dest/{service → services}/reqresp/rate_limiter/rate_limits.d.ts +0 -0
  135. /package/dest/{service → services}/service.d.ts +0 -0
  136. /package/src/{service → services}/data_store.ts +0 -0
  137. /package/src/{service → services}/dummy_service.ts +0 -0
  138. /package/src/{service → services}/reqresp/config.ts +0 -0
  139. /package/src/{service → services}/reqresp/handlers.ts +0 -0
  140. /package/src/{service → services}/reqresp/index.ts +0 -0
  141. /package/src/{service → services}/reqresp/interface.ts +0 -0
  142. /package/src/{service → services}/reqresp/rate_limiter/index.ts +0 -0
  143. /package/src/{service → services}/reqresp/rate_limiter/rate_limits.ts +0 -0
  144. /package/src/{service → services}/service.ts +0 -0
@@ -1,214 +0,0 @@
1
- import { createLogger } from '@aztec/foundation/log';
2
- import { inspect } from 'util';
3
- import { PeerScoring } from './peer_scoring.js';
4
- const MAX_DIAL_ATTEMPTS = 3;
5
- const MAX_CACHED_PEERS = 100;
6
- export class PeerManager {
7
- constructor(libP2PNode, peerDiscoveryService, config, logger = createLogger('p2p:peer-manager')) {
8
- this.libP2PNode = libP2PNode;
9
- this.peerDiscoveryService = peerDiscoveryService;
10
- this.config = config;
11
- this.logger = logger;
12
- this.cachedPeers = new Map();
13
- this.heartbeatCounter = 0;
14
- this.peerScoring = new PeerScoring(config);
15
- // Handle new established connections
16
- this.libP2PNode.addEventListener('peer:connect', evt => {
17
- const peerId = evt.detail;
18
- if (this.peerDiscoveryService.isBootstrapPeer(peerId)) {
19
- this.logger.verbose(`Connected to bootstrap peer ${peerId.toString()}`);
20
- }
21
- else {
22
- this.logger.verbose(`Connected to transaction peer ${peerId.toString()}`);
23
- }
24
- });
25
- // Handle lost connections
26
- this.libP2PNode.addEventListener('peer:disconnect', evt => {
27
- const peerId = evt.detail;
28
- if (this.peerDiscoveryService.isBootstrapPeer(peerId)) {
29
- this.logger.verbose(`Disconnected from bootstrap peer ${peerId.toString()}`);
30
- }
31
- else {
32
- this.logger.verbose(`Disconnected from transaction peer ${peerId.toString()}`);
33
- }
34
- });
35
- // Handle Discovered peers
36
- this.peerDiscoveryService.on('peer:discovered', async (enr) => {
37
- await this.handleDiscoveredPeer(enr);
38
- });
39
- }
40
- heartbeat() {
41
- this.heartbeatCounter++;
42
- this.discover();
43
- this.peerScoring.decayAllScores();
44
- }
45
- penalizePeer(peerId, penalty) {
46
- const id = peerId.toString();
47
- const penaltyValue = this.peerScoring.peerPenalties[penalty];
48
- const newScore = this.peerScoring.updateScore(id, -penaltyValue);
49
- this.logger.verbose(`Penalizing peer ${id} with ${penalty} (new score is ${newScore})`);
50
- }
51
- getPeerScore(peerId) {
52
- return this.peerScoring.getScore(peerId);
53
- }
54
- getPeers(includePending = false) {
55
- const connected = this.libP2PNode
56
- .getPeers()
57
- .map(peer => ({ id: peer.toString(), score: this.getPeerScore(peer.toString()), status: 'connected' }));
58
- if (!includePending) {
59
- return connected;
60
- }
61
- const dialQueue = this.libP2PNode
62
- .getDialQueue()
63
- .filter(peer => !!peer.peerId)
64
- .map(peer => ({
65
- id: peer.peerId.toString(),
66
- status: 'dialing',
67
- dialStatus: peer.status,
68
- addresses: peer.multiaddrs.map(m => m.toString()),
69
- }));
70
- const cachedPeers = Array.from(this.cachedPeers.values())
71
- .filter(peer => !dialQueue.some(dialPeer => dialPeer.id && peer.peerId.toString() === dialPeer.id.toString()))
72
- .filter(peer => !connected.some(connPeer => connPeer.id.toString() === peer.peerId.toString()))
73
- .map(peer => ({
74
- status: 'cached',
75
- id: peer.peerId.toString(),
76
- addresses: [peer.multiaddrTcp.toString()],
77
- dialAttempts: peer.dialAttempts,
78
- enr: peer.enr.encodeTxt(),
79
- }));
80
- return [...connected, ...dialQueue, ...cachedPeers];
81
- }
82
- /**
83
- * Discovers peers.
84
- */
85
- discover() {
86
- // Get current connections
87
- const connections = this.libP2PNode.getConnections();
88
- // Calculate how many connections we're looking to make
89
- const peersToConnect = this.config.maxPeerCount - connections.length;
90
- const logLevel = this.heartbeatCounter % 60 === 0 ? 'info' : 'debug';
91
- this.logger[logLevel](`Connected to ${connections.length} peers`, {
92
- connections: connections.length,
93
- maxPeerCount: this.config.maxPeerCount,
94
- cachedPeers: this.cachedPeers.size,
95
- ...this.peerScoring.getStats(),
96
- });
97
- // Exit if no peers to connect
98
- if (peersToConnect <= 0) {
99
- return;
100
- }
101
- const cachedPeersToDial = [];
102
- const pendingDials = new Set(this.libP2PNode
103
- .getDialQueue()
104
- .map(pendingDial => pendingDial.peerId?.toString())
105
- .filter(Boolean));
106
- for (const [id, peerData] of this.cachedPeers.entries()) {
107
- // if already dialling or connected to, remove from cache
108
- if (pendingDials.has(id) || connections.some(conn => conn.remotePeer.equals(peerData.peerId))) {
109
- this.cachedPeers.delete(id);
110
- }
111
- else {
112
- // cachedPeersToDial.set(id, enr);
113
- cachedPeersToDial.push(peerData);
114
- }
115
- }
116
- // reverse to dial older entries first
117
- cachedPeersToDial.reverse();
118
- for (const peer of cachedPeersToDial) {
119
- this.cachedPeers.delete(peer.peerId.toString());
120
- void this.dialPeer(peer);
121
- }
122
- // if we need more peers, start randomNodesQuery
123
- if (peersToConnect > 0) {
124
- this.logger.trace(`Running random nodes query to connect to ${peersToConnect} peers`);
125
- void this.peerDiscoveryService.runRandomNodesQuery();
126
- }
127
- }
128
- /**
129
- * Handles a discovered peer.
130
- * @param enr - The discovered peer's ENR.
131
- */
132
- async handleDiscoveredPeer(enr) {
133
- // TODO: Will be handling peer scoring here
134
- // check if peer is already connected
135
- const [peerId, multiaddrTcp] = await Promise.all([enr.peerId(), enr.getFullMultiaddr('tcp')]);
136
- this.logger.trace(`Handling discovered peer ${peerId.toString()} at ${multiaddrTcp?.toString() ?? 'undefined address'}`);
137
- // throw if no tcp addr in multiaddr
138
- if (!multiaddrTcp) {
139
- this.logger.debug(`No TCP address in discovered node's multiaddr ${enr.encodeTxt()}`);
140
- return;
141
- }
142
- const connections = this.libP2PNode.getConnections();
143
- if (connections.some(conn => conn.remotePeer.equals(peerId))) {
144
- this.logger.trace(`Already connected to peer ${peerId.toString()}`);
145
- return;
146
- }
147
- // check if peer is already in cache
148
- const id = peerId.toString();
149
- if (this.cachedPeers.has(id)) {
150
- this.logger.trace(`Peer already in cache ${id}`);
151
- return;
152
- }
153
- // create cached peer object
154
- const cachedPeer = {
155
- peerId,
156
- enr,
157
- multiaddrTcp,
158
- dialAttempts: 0,
159
- };
160
- // Determine if we should dial immediately or not
161
- if (this.shouldDialPeer()) {
162
- void this.dialPeer(cachedPeer);
163
- }
164
- else {
165
- this.logger.trace(`Caching peer ${id}`);
166
- this.cachedPeers.set(id, cachedPeer);
167
- // Prune set of cached peers
168
- this.pruneCachedPeers();
169
- }
170
- }
171
- async dialPeer(peer) {
172
- const id = peer.peerId.toString();
173
- await this.libP2PNode.peerStore.merge(peer.peerId, { multiaddrs: [peer.multiaddrTcp] });
174
- this.logger.trace(`Dialing peer ${id}`);
175
- try {
176
- await this.libP2PNode.dial(peer.multiaddrTcp);
177
- }
178
- catch (error) {
179
- peer.dialAttempts++;
180
- if (peer.dialAttempts < MAX_DIAL_ATTEMPTS) {
181
- this.logger.trace(`Failed to dial peer ${id} (attempt ${peer.dialAttempts})`, { error: inspect(error) });
182
- this.cachedPeers.set(id, peer);
183
- }
184
- else {
185
- this.logger.debug(`Failed to dial peer ${id} (dropping)`, { error: inspect(error) });
186
- this.cachedPeers.delete(id);
187
- }
188
- }
189
- }
190
- shouldDialPeer() {
191
- const connections = this.libP2PNode.getConnections().length;
192
- if (connections >= this.config.maxPeerCount) {
193
- this.logger.trace(`Not dialing peer due to max peer count of ${this.config.maxPeerCount} reached (${connections} current connections)`);
194
- return false;
195
- }
196
- return true;
197
- }
198
- pruneCachedPeers() {
199
- let peersToDelete = this.cachedPeers.size - MAX_CACHED_PEERS;
200
- if (peersToDelete <= 0) {
201
- return;
202
- }
203
- // Remove the oldest peers
204
- for (const key of this.cachedPeers.keys()) {
205
- this.cachedPeers.delete(key);
206
- this.logger.trace(`Pruning peer ${key} from cache`);
207
- peersToDelete--;
208
- if (peersToDelete <= 0) {
209
- break;
210
- }
211
- }
212
- }
213
- }
214
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVlcl9tYW5hZ2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NlcnZpY2UvcGVlcl9tYW5hZ2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUtyRCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBSS9CLE9BQU8sRUFBMEIsV0FBVyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFHeEUsTUFBTSxpQkFBaUIsR0FBRyxDQUFDLENBQUM7QUFDNUIsTUFBTSxnQkFBZ0IsR0FBRyxHQUFHLENBQUM7QUFTN0IsTUFBTSxPQUFPLFdBQVc7SUFLdEIsWUFDVSxVQUF3QixFQUN4QixvQkFBMEMsRUFDMUMsTUFBaUIsRUFDakIsU0FBUyxZQUFZLENBQUMsa0JBQWtCLENBQUM7UUFIekMsZUFBVSxHQUFWLFVBQVUsQ0FBYztRQUN4Qix5QkFBb0IsR0FBcEIsb0JBQW9CLENBQXNCO1FBQzFDLFdBQU0sR0FBTixNQUFNLENBQVc7UUFDakIsV0FBTSxHQUFOLE1BQU0sQ0FBbUM7UUFSM0MsZ0JBQVcsR0FBNEIsSUFBSSxHQUFHLEVBQUUsQ0FBQztRQUVqRCxxQkFBZ0IsR0FBVyxDQUFDLENBQUM7UUFRbkMsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUMzQyxxQ0FBcUM7UUFDckMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxnQkFBZ0IsQ0FBQyxjQUFjLEVBQUUsR0FBRyxDQUFDLEVBQUU7WUFDckQsTUFBTSxNQUFNLEdBQUcsR0FBRyxDQUFDLE1BQU0sQ0FBQztZQUMxQixJQUFJLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztnQkFDdEQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsK0JBQStCLE1BQU0sQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFD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
@@ -1 +0,0 @@
1
- {"version":3,"file":"peer_scoring.d.ts","sourceRoot":"","sources":["../../src/service/peer_scoring.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,cAAc,CAAC;AAE9C,oBAAY,iBAAiB;IAC3B;;;OAGG;IACH,iBAAiB,sBAAsB;IACvC;;;OAGG;IACH,iBAAiB,sBAAsB;IACvC;;;OAGG;IACH,kBAAkB,uBAAuB;CAC1C;AAQD,qBAAa,WAAW;IACtB,OAAO,CAAC,MAAM,CAAkC;IAChD,OAAO,CAAC,cAAc,CAAkC;IACxD,OAAO,CAAC,aAAa,CAAa;IAClC,OAAO,CAAC,WAAW,CAAO;IAC1B,aAAa,EAAE;SAAG,GAAG,IAAI,iBAAiB,GAAG,MAAM;KAAE,CAAC;gBAE1C,MAAM,EAAE,SAAS;IAY7B,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,MAAM;IAmBvD,cAAc,IAAI,IAAI;IActB,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM;IAIhC,QAAQ,IAAI;QAAE,WAAW,EAAE,MAAM,CAAA;KAAE;CAGpC"}
@@ -1,72 +0,0 @@
1
- import { median } from '@aztec/foundation/collection';
2
- export var PeerErrorSeverity;
3
- (function (PeerErrorSeverity) {
4
- /**
5
- * Not malicious action, but it must not be tolerated
6
- * ~2 occurrences will get the peer banned
7
- */
8
- PeerErrorSeverity["LowToleranceError"] = "LowToleranceError";
9
- /**
10
- * Negative action that can be tolerated only sometimes
11
- * ~10 occurrences will get the peer banned
12
- */
13
- PeerErrorSeverity["MidToleranceError"] = "MidToleranceError";
14
- /**
15
- * Some error that can be tolerated multiple times
16
- * ~50 occurrences will get the peer banned
17
- */
18
- PeerErrorSeverity["HighToleranceError"] = "HighToleranceError";
19
- })(PeerErrorSeverity || (PeerErrorSeverity = {}));
20
- const DefaultPeerPenalties = {
21
- [PeerErrorSeverity.LowToleranceError]: 2,
22
- [PeerErrorSeverity.MidToleranceError]: 10,
23
- [PeerErrorSeverity.HighToleranceError]: 50,
24
- };
25
- export class PeerScoring {
26
- constructor(config) {
27
- this.scores = new Map();
28
- this.lastUpdateTime = new Map();
29
- this.decayInterval = 1000 * 60; // 1 minute
30
- this.decayFactor = 0.9;
31
- const orderedValues = config.peerPenaltyValues?.sort((a, b) => a - b);
32
- this.peerPenalties = {
33
- [PeerErrorSeverity.HighToleranceError]: orderedValues?.[0] ?? DefaultPeerPenalties[PeerErrorSeverity.LowToleranceError],
34
- [PeerErrorSeverity.MidToleranceError]: orderedValues?.[1] ?? DefaultPeerPenalties[PeerErrorSeverity.MidToleranceError],
35
- [PeerErrorSeverity.LowToleranceError]: orderedValues?.[2] ?? DefaultPeerPenalties[PeerErrorSeverity.HighToleranceError],
36
- };
37
- }
38
- updateScore(peerId, scoreDelta) {
39
- const currentTime = Date.now();
40
- const lastUpdate = this.lastUpdateTime.get(peerId) || currentTime;
41
- const timePassed = currentTime - lastUpdate;
42
- const decayPeriods = Math.floor(timePassed / this.decayInterval);
43
- let currentScore = this.scores.get(peerId) || 0;
44
- // Apply decay
45
- currentScore *= Math.pow(this.decayFactor, decayPeriods);
46
- // Apply new score delta
47
- currentScore += scoreDelta;
48
- this.scores.set(peerId, currentScore);
49
- this.lastUpdateTime.set(peerId, currentTime);
50
- return currentScore;
51
- }
52
- decayAllScores() {
53
- const currentTime = Date.now();
54
- for (const [peerId, lastUpdate] of this.lastUpdateTime.entries()) {
55
- const timePassed = currentTime - lastUpdate;
56
- const decayPeriods = Math.floor(timePassed / this.decayInterval);
57
- if (decayPeriods > 0) {
58
- let score = this.scores.get(peerId) || 0;
59
- score *= Math.pow(this.decayFactor, decayPeriods);
60
- this.scores.set(peerId, score);
61
- this.lastUpdateTime.set(peerId, currentTime);
62
- }
63
- }
64
- }
65
- getScore(peerId) {
66
- return this.scores.get(peerId) || 0;
67
- }
68
- getStats() {
69
- return { medianScore: median(Array.from(this.scores.values())) ?? 0 };
70
- }
71
- }
72
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVlcl9zY29yaW5nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NlcnZpY2UvcGVlcl9zY29yaW5nLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUl0RCxNQUFNLENBQU4sSUFBWSxpQkFnQlg7QUFoQkQsV0FBWSxpQkFBaUI7SUFDM0I7OztPQUdHO0lBQ0gsNERBQXVDLENBQUE7SUFDdkM7OztPQUdHO0lBQ0gsNERBQXVDLENBQUE7SUFDdkM7OztPQUdHO0lBQ0gsOERBQXlDLENBQUE7QUFDM0MsQ0FBQyxFQWhCVyxpQkFBaUIsS0FBakIsaUJBQWlCLFFBZ0I1QjtBQUVELE1BQU0sb0JBQW9CLEdBQUc7SUFDM0IsQ0FBQyxpQkFBaUIsQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFLENBQUM7SUFDeEMsQ0FBQyxpQkFBaUIsQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFLEVBQUU7SUFDekMsQ0FBQyxpQkFBaUIsQ0FBQyxrQkFBa0IsQ0FBQyxFQUFFLEVBQUU7Q0FDM0MsQ0FBQztBQUVGLE1BQU0sT0FBTyxXQUFXO0lBT3RCLFlBQVksTUFBaUI7UUFOckIsV0FBTSxHQUF3QixJQUFJLEdBQUcsRUFBRSxDQUFDO1FBQ3hDLG1CQUFjLEdBQXdCLElBQUksR0FBRyxFQUFFLENBQUM7UUFDaEQsa0JBQWEsR0FBRyxJQUFJLEdBQUcsRUFBRSxDQUFDLENBQUMsV0FBVztRQUN0QyxnQkFBVyxHQUFHLEdBQUcsQ0FBQztRQUl4QixNQUFNLGFBQWEsR0FBRyxNQUFNLENBQUMsaUJBQWlCLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBQ3RFLElBQUksQ0FBQyxhQUFhLEdBQUc7WUFDbkIsQ0FBQyxpQkFBaUIsQ0FBQyxrQkFBa0IsQ0FBQyxFQUNwQyxhQUFhLEVBQUUsQ0FBQyxDQUFD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
@@ -1 +0,0 @@
1
- {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../../src/service/reqresp/config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,aAAa,EAAsB,MAAM,0BAA0B,CAAC;AAElF,eAAO,MAAM,qCAAqC,OAAO,CAAC;AAC1D,eAAO,MAAM,kCAAkC,OAAO,CAAC;AAGvD,eAAO,MAAM,0BAA0B,EAAE,gBAGxC,CAAC;AAEF,MAAM,WAAW,gBAAgB;IAC/B;;OAEG;IACH,uBAAuB,EAAE,MAAM,CAAC;IAEhC;;OAEG;IACH,0BAA0B,EAAE,MAAM,CAAC;CACpC;AAED,eAAO,MAAM,wBAAwB,EAAE,MAAM,CAAC,MAAM,gBAAgB,EAAE,aAAa,CAWlF,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"handlers.d.ts","sourceRoot":"","sources":["../../../src/service/reqresp/handlers.ts"],"names":[],"mappings":";;AAAA;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,IAAI,EAAE,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,CAEtD;AAED;;;;GAIG;AACH,wBAAgB,aAAa,CAAC,IAAI,EAAE,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,CAExD"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/service/reqresp/index.ts"],"names":[],"mappings":";AAAA;;;GAGG"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../src/service/reqresp/interface.ts"],"names":[],"mappings":";;AAEA,OAAO,EAAE,KAAK,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAKhD,eAAO,MAAM,aAAa,0BAA0B,CAAC;AACrD,eAAO,MAAM,eAAe,4BAA4B,CAAC;AACzD,eAAO,MAAM,eAAe,wBAAwB,CAAC;AAGrD,MAAM,MAAM,kBAAkB,GAAG,OAAO,aAAa,GAAG,OAAO,eAAe,GAAG,OAAO,eAAe,CAAC;AAExG;;;GAGG;AACH,MAAM,MAAM,yBAAyB,GAAG,CAAC,GAAG,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;AAEzE;;GAEG;AACH,MAAM,MAAM,4BAA4B,GAAG,MAAM,CAAC,kBAAkB,EAAE,sBAAsB,CAAC,CAAC;AAE9F;;GAEG;AACH,MAAM,WAAW,cAAc;IAC7B;;OAEG;IACH,WAAW,EAAE,MAAM,CAAC;IACpB;;OAEG;IACH,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,sBAAsB;IACrC;;OAEG;IACH,SAAS,EAAE,cAAc,CAAC;IAC1B;;OAEG;IACH,WAAW,EAAE,cAAc,CAAC;CAC7B;AAED,eAAO,MAAM,aAAa,wBAA8B,CAAC;AAEzD;;GAEG;AACH,MAAM,MAAM,0BAA0B,GAAG,MAAM,CAAC,kBAAkB,EAAE,yBAAyB,CAAC,CAAC;AAE/F,KAAK,iBAAiB,CAAC,iBAAiB,EAAE,QAAQ,IAAI,CACpD,OAAO,EAAE,iBAAiB,EAC1B,QAAQ,EAAE,QAAQ,EAClB,MAAM,EAAE,MAAM,KACX,OAAO,CAAC,OAAO,CAAC,CAAC;AAEtB,MAAM,MAAM,4BAA4B,GAAG;KACxC,CAAC,IAAI,kBAAkB,GAAG,iBAAiB,CAAC,GAAG,EAAE,GAAG,CAAC;CACvD,CAAC;AAEF,eAAO,MAAM,+BAA+B,EAAE,4BAI7C,CAAC;AAEF;;;GAGG;AACH,MAAM,MAAM,cAAc,GAAG;KAC1B,CAAC,IAAI,kBAAkB,GAAG,mBAAmB,CAAC,GAAG,EAAE,GAAG,CAAC;CACzD,CAAC;AAUF;;GAEG;AACH,eAAO,MAAM,6BAA6B,EAAE,0BAI3C,CAAC;AAEF;;;GAGG;AACH,UAAU,mBAAmB,CAAC,GAAG,EAAE,GAAG;IACpC,OAAO,EAAE,KAAK,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,GAAG,CAAC;IACrC;;OAEG;IACH,QAAQ,EAAE;QACR,KAAK,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,CAAC;QAC1B,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,CAAC;KACjC,CAAC;CACH;AAED;;;;;GAKG;AACH,qBAAa,iBAAiB;IACT,MAAM,EAAE,MAAM;gBAAd,MAAM,EAAE,MAAM;IAEjC,QAAQ;IAIR,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM;CAGjC;AAED;;;;GAIG;AACH,eAAO,MAAM,cAAc,EAAE,cAa5B,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/service/reqresp/rate_limiter/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,0BAA0B,EAAE,MAAM,mBAAmB,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"rate_limiter.d.ts","sourceRoot":"","sources":["../../../../src/service/reqresp/rate_limiter/rate_limiter.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,OAAO,EAAE,KAAK,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAEhD,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAEzD,OAAO,EAAE,KAAK,kBAAkB,EAAE,KAAK,4BAA4B,EAAE,MAAM,iBAAiB,CAAC;AAM7F;;;;;;;;;;;;;;;;;;;GAmBG;AACH,qBAAa,eAAe;IAE1B,OAAO,CAAC,GAAG,CAAS;IAEpB,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAS;IAE1C,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAS;IAEvC;;;OAGG;gBACS,UAAU,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM;IAMnD,KAAK,IAAI,OAAO;CAWjB;AASD,aAAK,eAAe;IAClB,OAAO,IAAA;IACP,YAAY,IAAA;IACZ,UAAU,IAAA;CACX;AAED;;;;;;;;;;;;;;;GAeG;AACH,qBAAa,sBAAsB;IACjC,OAAO,CAAC,YAAY,CAA2C;IAC/D,OAAO,CAAC,aAAa,CAAkB;IACvC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAS;IACxC,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAS;gBAE7B,cAAc,EAAE,MAAM,EAAE,eAAe,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM;IAOhH,KAAK,CAAC,MAAM,EAAE,MAAM,GAAG,eAAe;IAwBtC,oBAAoB;CAQrB;AAED;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,qBAAa,0BAA0B;IAKzB,OAAO,CAAC,WAAW;IAJ/B,OAAO,CAAC,uBAAuB,CAAkD;IAEjF,OAAO,CAAC,eAAe,CAAyC;gBAE5C,WAAW,EAAE,WAAW,EAAE,UAAU,GAAE,4BAAkD;IAgB5G,KAAK;IAML,KAAK,CAAC,WAAW,EAAE,kBAAkB,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO;IAkB/D,oBAAoB;IAIpB;;OAEG;IACH,IAAI;CAGL"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"rate_limits.d.ts","sourceRoot":"","sources":["../../../../src/service/reqresp/rate_limiter/rate_limits.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiB,KAAK,4BAA4B,EAAoC,MAAM,iBAAiB,CAAC;AAGrH,eAAO,MAAM,mBAAmB,EAAE,4BA+BjC,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"reqresp.d.ts","sourceRoot":"","sources":["../../../src/service/reqresp/reqresp.ts"],"names":[],"mappings":";;AACA,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,uBAAuB,CAAC;AAGlE,OAAO,EAA2B,KAAK,MAAM,EAAe,MAAM,mBAAmB,CAAC;AAEtF,OAAO,EAAE,KAAK,MAAM,EAAE,MAAM,QAAQ,CAAC;AAKrC,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAEtD,OAAO,EAAE,KAAK,gBAAgB,EAAE,MAAM,aAAa,CAAC;AACpD,OAAO,EAGL,KAAK,kBAAkB,EACvB,KAAK,0BAA0B,EAC/B,KAAK,4BAA4B,EACjC,KAAK,cAAc,EAEpB,MAAM,gBAAgB,CAAC;AAGxB;;;;;;;;;;;;;GAaG;AACH,qBAAa,OAAO;IAYoB,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,MAAM;IAAE,OAAO,CAAC,WAAW;IAX5F,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IAElC,OAAO,CAAC,uBAAuB,CAAS;IACxC,OAAO,CAAC,0BAA0B,CAAS;IAG3C,OAAO,CAAC,mBAAmB,CAA6D;IACxF,OAAO,CAAC,qBAAqB,CAAiE;IAE9F,OAAO,CAAC,WAAW,CAA6B;gBAEpC,MAAM,EAAE,gBAAgB,EAAqB,MAAM,EAAE,MAAM,EAAU,WAAW,EAAE,WAAW;IASzG;;OAEG;IACG,KAAK,CAAC,mBAAmB,EAAE,0BAA0B,EAAE,qBAAqB,EAAE,4BAA4B;IAWhH;;OAEG;IACG,IAAI;IAiBV;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA4BG;IACG,WAAW,CAAC,WAAW,SAAS,kBAAkB,EACtD,WAAW,EAAE,WAAW,EACxB,OAAO,EAAE,YAAY,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,CAAC,GAC5D,OAAO,CAAC,YAAY,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,UAAU,CAAC,CAAC,GAAG,SAAS,CAAC;IAwC7E;;;;;;;;;;;;;;;;;;;;;;;OAuBG;IACG,iBAAiB,CACrB,MAAM,EAAE,MAAM,EACd,WAAW,EAAE,kBAAkB,EAC/B,OAAO,EAAE,MAAM,GACd,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC;IAmC9B;;OAEG;YACW,WAAW;IASzB;;;;;;;;;;;;;;;OAeG;YACW,aAAa;CA8B5B"}
@@ -1,230 +0,0 @@
1
- // @attribution: lodestar impl for inspiration
2
- import { createLogger } from '@aztec/foundation/log';
3
- import { executeTimeoutWithCustomError } from '@aztec/foundation/timer';
4
- import { pipe } from 'it-pipe';
5
- import { compressSync, uncompressSync } from 'snappy';
6
- import { CollectiveReqRespTimeoutError, IndiviualReqRespTimeoutError } from '../../errors/reqresp.error.js';
7
- import { PeerErrorSeverity } from '../peer_scoring.js';
8
- import { DEFAULT_SUB_PROTOCOL_HANDLERS, DEFAULT_SUB_PROTOCOL_VALIDATORS, subProtocolMap, } from './interface.js';
9
- import { RequestResponseRateLimiter } from './rate_limiter/rate_limiter.js';
10
- /**
11
- * The Request Response Service
12
- *
13
- * It allows nodes to request specific information from their peers, its use case covers recovering
14
- * information that was missed during a syncronisation or a gossip event.
15
- *
16
- * This service implements the request response sub protocol, it is heavily inspired from
17
- * ethereum implementations of the same name.
18
- *
19
- * Note, responses get compressed in streamHandler
20
- * so they get decompressed in readMessage
21
- *
22
- * see: https://github.com/ethereum/consensus-specs/blob/dev/specs/phase0/p2p-interface.md#the-reqresp-domain
23
- */
24
- export class ReqResp {
25
- constructor(config, libp2p, peerManager) {
26
- this.libp2p = libp2p;
27
- this.peerManager = peerManager;
28
- // Warning, if the `start` function is not called as the parent class constructor, then the default sub protocol handlers will be used ( not good )
29
- this.subProtocolHandlers = DEFAULT_SUB_PROTOCOL_HANDLERS;
30
- this.subProtocolValidators = DEFAULT_SUB_PROTOCOL_VALIDATORS;
31
- this.logger = createLogger('p2p:reqresp');
32
- this.overallRequestTimeoutMs = config.overallRequestTimeoutMs;
33
- this.individualRequestTimeoutMs = config.individualRequestTimeoutMs;
34
- this.rateLimiter = new RequestResponseRateLimiter(peerManager);
35
- }
36
- /**
37
- * Start the reqresp service
38
- */
39
- async start(subProtocolHandlers, subProtocolValidators) {
40
- this.subProtocolHandlers = subProtocolHandlers;
41
- this.subProtocolValidators = subProtocolValidators;
42
- // Register all protocol handlers
43
- for (const subProtocol of Object.keys(this.subProtocolHandlers)) {
44
- await this.libp2p.handle(subProtocol, this.streamHandler.bind(this, subProtocol));
45
- }
46
- this.rateLimiter.start();
47
- }
48
- /**
49
- * Stop the reqresp service
50
- */
51
- async stop() {
52
- // Unregister all handlers
53
- for (const protocol of Object.keys(this.subProtocolHandlers)) {
54
- await this.libp2p.unhandle(protocol);
55
- }
56
- // Close all active connections
57
- const closeStreamPromises = this.libp2p.getConnections().map(connection => connection.close());
58
- await Promise.all(closeStreamPromises);
59
- this.logger.debug('ReqResp: All active streams closed');
60
- this.rateLimiter.stop();
61
- this.logger.debug('ReqResp: Rate limiter stopped');
62
- // NOTE: We assume libp2p instance is managed by the caller
63
- }
64
- /**
65
- * Send a request to peers, returns the first response
66
- *
67
- * @param subProtocol - The protocol being requested
68
- * @param request - The request to send
69
- * @returns - The response from the peer, otherwise undefined
70
- *
71
- * @description
72
- * This method attempts to send a request to all active peers using the specified sub-protocol.
73
- * It opens a stream with each peer, sends the request, and awaits a response.
74
- * If a valid response is received, it returns the response; otherwise, it continues to the next peer.
75
- * If no response is received from any peer, it returns undefined.
76
- *
77
- * The method performs the following steps:
78
- * - Iterates over all active peers.
79
- * - Opens a stream with each peer using the specified sub-protocol.
80
- *
81
- * When a response is received, it is validated using the given sub protocols response validator.
82
- * To see the interface for the response validator - see `interface.ts`
83
- *
84
- * Failing a response validation requests in a severe peer penalty, and will
85
- * prompt the node to continue to search to the next peer.
86
- * For example, a transaction request validator will check that the payload returned does in fact
87
- * match the txHash that was requested. A peer that fails this check an only be an extremely naughty peer.
88
- *
89
- * This entire operation is wrapped in an overall timeout, that is independent of the
90
- * peer it is requesting data from.
91
- *
92
- */
93
- async sendRequest(subProtocol, request) {
94
- const requestFunction = async () => {
95
- const responseValidator = this.subProtocolValidators[subProtocol];
96
- const requestBuffer = request.toBuffer();
97
- // Get active peers
98
- const peers = this.libp2p.getPeers();
99
- // Attempt to ask all of our peers
100
- for (const peer of peers) {
101
- const response = await this.sendRequestToPeer(peer, subProtocol, requestBuffer);
102
- // If we get a response, return it, otherwise we iterate onto the next peer
103
- // We do not consider it a success if we have an empty buffer
104
- if (response && response.length > 0) {
105
- const object = subProtocolMap[subProtocol].response.fromBuffer(response);
106
- // The response validator handles peer punishment within
107
- const isValid = await responseValidator(request, object, peer);
108
- if (!isValid) {
109
- this.logger.error(`Invalid response for ${subProtocol} from ${peer.toString()}`);
110
- return undefined;
111
- }
112
- return object;
113
- }
114
- }
115
- return undefined;
116
- };
117
- try {
118
- return await executeTimeoutWithCustomError(requestFunction, this.overallRequestTimeoutMs, () => new CollectiveReqRespTimeoutError());
119
- }
120
- catch (e) {
121
- this.logger.error(`${e.message} | subProtocol: ${subProtocol}`);
122
- return undefined;
123
- }
124
- }
125
- /**
126
- * Sends a request to a specific peer
127
- *
128
- * We first dial a particular protocol for the peer, this ensures that the peer knows
129
- * what to respond with
130
- *
131
- *
132
- * @param peerId - The peer to send the request to
133
- * @param subProtocol - The protocol to use to request
134
- * @param payload - The payload to send
135
- * @returns If the request is successful, the response is returned, otherwise undefined
136
- *
137
- * @description
138
- * This method attempts to open a stream with the specified peer, send the payload,
139
- * and await a response.
140
- * If an error occurs, it penalizes the peer and returns undefined.
141
- *
142
- * The method performs the following steps:
143
- * - Opens a stream with the peer using the specified sub-protocol.
144
- * - Sends the payload and awaits a response with a timeout.
145
- *
146
- * If the stream is not closed by the dialled peer, and a timeout occurs, then
147
- * the stream is closed on the requester's end and sender (us) updates its peer score
148
- */
149
- async sendRequestToPeer(peerId, subProtocol, payload) {
150
- let stream;
151
- try {
152
- stream = await this.libp2p.dialProtocol(peerId, subProtocol);
153
- this.logger.trace(`Stream opened with ${peerId.toString()} for ${subProtocol}`);
154
- // Open the stream with a timeout
155
- const result = await executeTimeoutWithCustomError(() => pipe([payload], stream, this.readMessage), this.individualRequestTimeoutMs, () => new IndiviualReqRespTimeoutError());
156
- await stream.close();
157
- this.logger.trace(`Stream closed with ${peerId.toString()} for ${subProtocol}`);
158
- return result;
159
- }
160
- catch (e) {
161
- this.logger.error(`Error sending request to peer`, e, { peerId: peerId.toString(), subProtocol });
162
- this.peerManager.penalizePeer(peerId, PeerErrorSeverity.HighToleranceError);
163
- }
164
- finally {
165
- if (stream) {
166
- try {
167
- await stream.close();
168
- this.logger.trace(`Stream closed with ${peerId.toString()} for ${subProtocol}`);
169
- }
170
- catch (closeError) {
171
- this.logger.error(`Error closing stream: ${closeError instanceof Error ? closeError.message : 'Unknown error'}`);
172
- }
173
- }
174
- }
175
- return undefined;
176
- }
177
- /**
178
- * Read a message returned from a stream into a single buffer
179
- */
180
- async readMessage(source) {
181
- const chunks = [];
182
- for await (const chunk of source) {
183
- chunks.push(chunk.subarray());
184
- }
185
- const messageData = chunks.concat();
186
- return uncompressSync(Buffer.concat(messageData), { asBuffer: true });
187
- }
188
- /**
189
- * Stream Handler
190
- * Reads the incoming stream, determines the protocol, then triggers the appropriate handler
191
- *
192
- * @param param0 - The incoming stream data
193
- *
194
- * @description
195
- * An individual stream handler will be bound to each sub protocol, and handles returning data back
196
- * to the requesting peer.
197
- *
198
- * The sub protocol handler interface is defined within `interface.ts` and will be assigned to the
199
- * req resp service on start up.
200
- *
201
- * We check rate limits for each peer, note the peer will be penalised within the rate limiter implementation
202
- * if they exceed their peer specific limits.
203
- */
204
- async streamHandler(protocol, { stream, connection }) {
205
- // Store a reference to from this for the async generator
206
- if (!this.rateLimiter.allow(protocol, connection.remotePeer)) {
207
- this.logger.warn(`Rate limit exceeded for ${protocol} from ${connection.remotePeer}`);
208
- // TODO(#8483): handle changing peer scoring for failed rate limit, maybe differentiate between global and peer limits here when punishing
209
- await stream.close();
210
- return;
211
- }
212
- const handler = this.subProtocolHandlers[protocol];
213
- try {
214
- await pipe(stream, async function* (source) {
215
- for await (const chunkList of source) {
216
- const msg = Buffer.from(chunkList.subarray());
217
- const response = await handler(msg);
218
- yield new Uint8Array(compressSync(response));
219
- }
220
- }, stream);
221
- }
222
- catch (e) {
223
- this.logger.warn(e);
224
- }
225
- finally {
226
- await stream.close();
227
- }
228
- }
229
- }
230
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVxcmVzcC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zZXJ2aWNlL3JlcXJlc3AvcmVxcmVzcC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSw4Q0FBOEM7QUFDOUMsT0FBTyxFQUFlLFlBQVksRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ2xFLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBR3hFLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFFL0IsT0FBTyxFQUFFLFlBQVksRUFBRSxjQUFjLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFHdEQsT0FBTyxFQUFFLDZCQUE2QixFQUFFLDRCQUE0QixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFFNUcsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFdkQsT0FBTyxFQUNMLDZCQUE2QixFQUM3QiwrQkFBK0IsRUFLL0IsY0FBYyxHQUNmLE1BQU0sZ0JBQWdCLENBQUM7QUFDeEIsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFFNUU7Ozs7Ozs7Ozs7Ozs7R0FhRztBQUNILE1BQU0sT0FBTyxPQUFPO0lBWWxCLFlBQVksTUFBd0IsRUFBcUIsTUFBYyxFQUFVLFdBQXdCO1FBQWhELFdBQU0sR0FBTixNQUFNLENBQVE7UUFBVSxnQkFBVyxHQUFYLFdBQVcsQ0FBYTtRQU56RyxtSkFBbUo7UUFDM0ksd0JBQW1CLEdBQStCLDZCQUE2QixDQUFDO1FBQ2hGLDBCQUFxQixHQUFpQywrQkFBK0IsQ0FBQztRQUs1RixJQUFJLENBQUMsTUFBTSxHQUFHLFlBQVksQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUUxQyxJQUFJLENBQUMsdUJBQXVCLEdBQUcsTUFBTSxDQUFDLHVCQUF1QixDQUFDO1FBQzlELElBQUksQ0FBQywwQkFBMEIsR0FBRyxNQUFNLENBQUMsMEJBQTBCLENBQUM7UUFFcEUs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
@@ -1 +0,0 @@
1
- {"version":3,"file":"service.d.ts","sourceRoot":"","sources":["../../src/service/service.ts"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,aAAa,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAElG,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,KAAK,YAAY,MAAM,QAAQ,CAAC;AAEvC,OAAO,EAAE,KAAK,kBAAkB,EAAE,KAAK,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAEtF,oBAAY,kBAAkB;IAC5B,OAAO,YAAY;IACnB,OAAO,YAAY;CACpB;AAED;;GAEG;AACH,MAAM,WAAW,UAAU;IACzB;;;OAGG;IACH,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAEvB;;;OAGG;IACH,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAEtB;;;OAGG;IACH,SAAS,CAAC,CAAC,SAAS,UAAU,EAAE,OAAO,EAAE,CAAC,GAAG,IAAI,CAAC;IAElD;;;;;;OAMG;IACH,WAAW,CAAC,QAAQ,SAAS,kBAAkB,EAC7C,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,YAAY,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,CAAC,GACzD,OAAO,CAAC,YAAY,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC;IAG3E,6BAA6B,CAAC,QAAQ,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,OAAO,CAAC,gBAAgB,GAAG,SAAS,CAAC,GAAG,IAAI,CAAC;IAE/G,MAAM,IAAI,GAAG,GAAG,SAAS,CAAC;IAE1B,QAAQ,CAAC,cAAc,CAAC,EAAE,OAAO,GAAG,QAAQ,EAAE,CAAC;CAChD;AAED;;GAEG;AACH,MAAM,WAAW,oBAAqB,SAAQ,YAAY;IACxD;;SAEK;IACL,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAEvB;;SAEK;IACL,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAEtB;;;OAGG;IACH,WAAW,IAAI,GAAG,EAAE,CAAC;IAErB;;OAEG;IACH,mBAAmB,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAErC;;;;OAIG;IACH,eAAe,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC;IAEzC;;OAEG;IACH,EAAE,CAAC,KAAK,EAAE,iBAAiB,EAAE,QAAQ,EAAE,CAAC,GAAG,EAAE,GAAG,KAAK,IAAI,GAAG,IAAI,CAAC;IACjE,IAAI,CAAC,KAAK,EAAE,iBAAiB,EAAE,GAAG,EAAE,GAAG,GAAG,OAAO,CAAC;IAElD,SAAS,IAAI,kBAAkB,CAAC;IAEhC,MAAM,IAAI,GAAG,GAAG,SAAS,CAAC;CAC3B"}
@@ -1,2 +0,0 @@
1
- export * from './service.js';
2
- export * from './libp2p_service.js';
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes