@helia/interface 6.2.0 → 6.2.1-17530ed8

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.
@@ -1,4 +1,5 @@
1
- import type { AbortOptions, PeerId, PeerInfo, TraceOptions } from '@libp2p/interface';
1
+ import type { Multiaddr } from '@multiformats/multiaddr';
2
+ import type { AbortOptions } from 'abort-error';
2
3
  import type { CID } from 'multiformats/cid';
3
4
  import type { ProgressEvent, ProgressOptions } from 'progress-events';
4
5
  /**
@@ -7,7 +8,7 @@ import type { ProgressEvent, ProgressOptions } from 'progress-events';
7
8
  * local cache that may be used in preference over network calls, for example
8
9
  * when a record has a TTL.
9
10
  */
10
- export interface RoutingOptions<Event extends ProgressEvent = any> extends AbortOptions, ProgressOptions<Event>, TraceOptions {
11
+ export interface RoutingOptions<Event extends ProgressEvent = any> extends AbortOptions, ProgressOptions<Event> {
11
12
  /**
12
13
  * Pass `false` to not use the network
13
14
  *
@@ -26,11 +27,36 @@ export interface RoutingOptions<Event extends ProgressEvent = any> extends Abort
26
27
  * @default true
27
28
  */
28
29
  validate?: boolean;
30
+ /**
31
+ * Where tracing is used, this value carries tracing context
32
+ */
33
+ trace?: any;
34
+ }
35
+ /**
36
+ * A Peer is another node on the network
37
+ */
38
+ export interface Peer {
39
+ /**
40
+ * The identifier of the remote peer
41
+ */
42
+ id: CID;
43
+ /**
44
+ * The multiaddrs a peer is listening on
45
+ */
46
+ multiaddrs: Multiaddr[];
29
47
  }
30
48
  /**
31
49
  * A provider can supply the content for a CID
32
50
  */
33
- export interface Provider extends PeerInfo {
51
+ export interface Provider {
52
+ /**
53
+ * The identifier of the remote peer, a CID
54
+ */
55
+ id: CID;
56
+ /**
57
+ * The multiaddrs a peer is listening on
58
+ */
59
+ multiaddrs: Multiaddr[];
34
60
  /**
35
61
  * If present these are the methods that the peer can supply the content via.
36
62
  *
@@ -61,14 +87,14 @@ export interface RoutingFindProvidersEndEvent {
61
87
  export interface RoutingFindProvidersHttpGatewayProvider {
62
88
  routing: 'http-gateway-router';
63
89
  cid: CID;
64
- provider: PeerInfo & {
90
+ provider: Peer & {
65
91
  protocols: ['transport-ipfs-gateway-http'];
66
92
  };
67
93
  }
68
94
  export interface RoutingFindProvidersDelegatedHttpRoutingProvider {
69
95
  routing: 'delegated-http-router';
70
96
  cid: CID;
71
- provider: PeerInfo & {
97
+ provider: Peer & {
72
98
  routing: 'delegated-http-routing';
73
99
  protocols: string[];
74
100
  };
@@ -76,7 +102,7 @@ export interface RoutingFindProvidersDelegatedHttpRoutingProvider {
76
102
  export interface RoutingFindProvidersLibp2pProvider {
77
103
  routing: 'libp2p-router';
78
104
  cid: CID;
79
- provider: PeerInfo;
105
+ provider: Peer;
80
106
  }
81
107
  export type RoutingFindProvidersProviderEvent = RoutingFindProvidersHttpGatewayProvider | RoutingFindProvidersDelegatedHttpRoutingProvider | RoutingFindProvidersLibp2pProvider;
82
108
  export type RoutingFindProvidersProgressEvents = ProgressEvent<'helia:routing:find-providers:start', RoutingFindProvidersStartEvent> | ProgressEvent<'helia:routing:find-providers:provider', RoutingFindProvidersProviderEvent> | ProgressEvent<'helia:routing:find-providers:end', RoutingFindProvidersEndEvent> | RoutingFindPeerProgressEvents;
@@ -120,11 +146,11 @@ export interface RoutingGetEndEvent {
120
146
  export type RoutingGetProgressEvents = ProgressEvent<'helia:routing:get:start', RoutingGetStartEvent> | ProgressEvent<'helia:routing:get:end', RoutingGetEndEvent>;
121
147
  export interface RoutingFindPeerStartEvent {
122
148
  routing: string;
123
- peerId: PeerId;
149
+ peerId: CID;
124
150
  }
125
151
  export interface RoutingFindPeerEndEvent {
126
152
  routing: string;
127
- peerId: PeerId;
153
+ peerId: CID;
128
154
  }
129
155
  export type RoutingFindPeerProgressEvents = ProgressEvent<'helia:routing:find-peer:start', RoutingFindPeerStartEvent> | ProgressEvent<'helia:routing:find-peer:end', RoutingFindPeerEndEvent>;
130
156
  export interface RoutingGetClosestPeersStartEvent {
@@ -136,7 +162,7 @@ export interface RoutingGetClosestPeersEndEvent {
136
162
  key: Uint8Array;
137
163
  }
138
164
  export type RoutingGetClosestPeersProgressEvents = ProgressEvent<'helia:routing:get-closest-peers:start', RoutingGetClosestPeersStartEvent> | ProgressEvent<'helia:routing:get-closest-peers:end', RoutingGetClosestPeersEndEvent>;
139
- export interface Routing {
165
+ export interface Router {
140
166
  /**
141
167
  * The name of this routing implementation
142
168
  */
@@ -149,10 +175,12 @@ export interface Routing {
149
175
  *
150
176
  * ```js
151
177
  * // ...
152
- * await contentRouting.provide(cid)
178
+ * await contentRouting.provide(cid, {
179
+ * signal: AbortSignal.timeout(5_000)
180
+ * })
153
181
  * ```
154
182
  */
155
- provide(cid: CID, options?: RoutingOptions<RoutingProvideProgressEvents>): Promise<void>;
183
+ provide?(cid: CID, options?: RoutingOptions<RoutingProvideProgressEvents>): Promise<void>;
156
184
  /**
157
185
  * Helia will periodically re-provide every previously provided CID. Use this
158
186
  * method to no longer re-provide the passed CID.
@@ -161,10 +189,12 @@ export interface Routing {
161
189
  *
162
190
  * ```js
163
191
  * // ...
164
- * await contentRouting.cancelReprovide(cid)
192
+ * await contentRouting.cancelReprovide(cid, {
193
+ * signal: AbortSignal.timeout(5_000)
194
+ * })
165
195
  * ```
166
196
  */
167
- cancelReprovide(key: CID, options?: AbortOptions): Promise<void>;
197
+ cancelReprovide?(key: CID, options?: AbortOptions): Promise<void>;
168
198
  /**
169
199
  * Find the providers of the passed CID.
170
200
  *
@@ -172,12 +202,14 @@ export interface Routing {
172
202
  *
173
203
  * ```js
174
204
  * // Iterate over the providers found for the given cid
175
- * for await (const provider of contentRouting.findProviders(cid)) {
205
+ * for await (const provider of contentRouting.findProviders(cid, {
206
+ * signal: AbortSignal.timeout(5_000)
207
+ * })) {
176
208
  * console.log(provider.id, provider.multiaddrs)
177
209
  * }
178
210
  * ```
179
211
  */
180
- findProviders(cid: CID, options?: RoutingOptions<RoutingFindProvidersProgressEvents>): AsyncIterable<Provider>;
212
+ findProviders?(cid: CID, options?: RoutingOptions<RoutingFindProvidersProgressEvents>): AsyncIterable<Provider>;
181
213
  /**
182
214
  * Puts a value corresponding to the passed key in a way that can later be
183
215
  * retrieved by another network peer using the get method.
@@ -186,13 +218,15 @@ export interface Routing {
186
218
  *
187
219
  * ```js
188
220
  * // ...
189
- * const key = '/key'
221
+ * const key = uint8ArrayFromString('/key')
190
222
  * const value = uint8ArrayFromString('oh hello there')
191
223
  *
192
- * await contentRouting.put(key, value)
224
+ * await contentRouting.put(key, value, {
225
+ * signal: AbortSignal.timeout(5_000)
226
+ * })
193
227
  * ```
194
228
  */
195
- put(key: Uint8Array, value: Uint8Array, options?: RoutingOptions<RoutingPutProgressEvents>): Promise<void>;
229
+ put?(key: Uint8Array, value: Uint8Array, options?: RoutingOptions<RoutingPutProgressEvents>): Promise<void>;
196
230
  /**
197
231
  * Retrieves a value from the network corresponding to the passed key.
198
232
  *
@@ -201,11 +235,13 @@ export interface Routing {
201
235
  * ```js
202
236
  * // ...
203
237
  *
204
- * const key = '/key'
205
- * const value = await contentRouting.get(key)
238
+ * const key = uint8ArrayFromString('/key')
239
+ * const value = await contentRouting.get(key, {
240
+ * signal: AbortSignal.timeout(5_000)
241
+ * })
206
242
  * ```
207
243
  */
208
- get(key: Uint8Array, options?: RoutingOptions<RoutingGetProgressEvents>): Promise<Uint8Array>;
244
+ get?(key: Uint8Array, options?: RoutingOptions<RoutingGetProgressEvents>): Promise<Uint8Array>;
209
245
  /**
210
246
  * Searches the network for peer info corresponding to the passed peer id.
211
247
  *
@@ -213,10 +249,12 @@ export interface Routing {
213
249
  *
214
250
  * ```js
215
251
  * // ...
216
- * const peer = await peerRouting.findPeer(peerId, options)
252
+ * const peer = await peerRouting.findPeer(peerId, {
253
+ * signal: AbortSignal.timeout(5_000)
254
+ * })
217
255
  * ```
218
256
  */
219
- findPeer(peerId: PeerId, options?: RoutingOptions<RoutingFindPeerProgressEvents>): Promise<PeerInfo>;
257
+ findPeer?(peer: CID, options?: RoutingOptions<RoutingFindPeerProgressEvents>): Promise<Peer>;
220
258
  /**
221
259
  * Search the network for peers that are closer to the passed key. Peer
222
260
  * info should be yielded in ever-increasing closeness to the key.
@@ -225,11 +263,14 @@ export interface Routing {
225
263
  *
226
264
  * ```js
227
265
  * // Iterate over the closest peers found for the given key
228
- * for await (const peer of peerRouting.getClosestPeers(key)) {
266
+ * for await (const peer of peerRouting.getClosestPeers(key, {
267
+ * signal: AbortSignal.timeout(5_000)
268
+ * })) {
229
269
  * console.log(peer.id, peer.multiaddrs)
230
270
  * }
231
271
  * ```
232
272
  */
233
- getClosestPeers(key: Uint8Array, options?: RoutingOptions<RoutingGetClosestPeersProgressEvents>): AsyncIterable<PeerInfo>;
273
+ getClosestPeers?(key: Uint8Array, options?: RoutingOptions<RoutingGetClosestPeersProgressEvents>): AsyncIterable<Peer>;
234
274
  }
275
+ export type Routing = Required<Omit<Router, 'name'>>;
235
276
  //# sourceMappingURL=routing.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"routing.d.ts","sourceRoot":"","sources":["../../src/routing.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"routing.d.ts","sourceRoot":"","sources":["../../src/routing.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@helia/interface",
3
- "version": "6.2.0",
3
+ "version": "6.2.1-17530ed8",
4
4
  "description": "The Helia API",
5
5
  "license": "Apache-2.0 OR MIT",
6
6
  "homepage": "https://github.com/ipfs/helia/tree/main/packages/interface#readme",
@@ -45,19 +45,23 @@
45
45
  "exports": {
46
46
  ".": {
47
47
  "types": "./dist/src/index.d.ts",
48
- "import": "./dist/src/index.js"
48
+ "import": "./dist/src/index.js",
49
+ "module-sync": "./dist/src/index.js"
49
50
  },
50
51
  "./blocks": {
51
52
  "types": "./dist/src/blocks.d.ts",
52
- "import": "./dist/src/blocks.js"
53
+ "import": "./dist/src/blocks.js",
54
+ "module-sync": "./dist/src/blocks.js"
53
55
  },
54
56
  "./pins": {
55
57
  "types": "./dist/src/pins.d.ts",
56
- "import": "./dist/src/pins.js"
58
+ "import": "./dist/src/pins.js",
59
+ "module-sync": "./dist/src/pins.js"
57
60
  },
58
61
  "./routing": {
59
62
  "types": "./dist/src/routing.d.ts",
60
- "import": "./dist/src/routing.js"
63
+ "import": "./dist/src/routing.js",
64
+ "module-sync": "./dist/src/routing.js"
61
65
  }
62
66
  },
63
67
  "scripts": {
@@ -68,17 +72,21 @@
68
72
  "build": "aegir build"
69
73
  },
70
74
  "dependencies": {
71
- "@libp2p/interface": "^3.2.0",
72
- "@multiformats/dns": "^1.0.9",
73
- "@multiformats/multiaddr": "^13.0.1",
74
- "interface-blockstore": "^6.0.1",
75
- "interface-datastore": "^9.0.2",
76
- "interface-store": "^7.0.0",
77
- "multiformats": "^13.4.1",
78
- "progress-events": "^1.0.1"
75
+ "@ipshipyard/crypto": "^1.1.0",
76
+ "@ipshipyard/keychain": "^1.0.2",
77
+ "@libp2p/interface": "^3.2.3",
78
+ "@multiformats/dns": "^1.0.13",
79
+ "@multiformats/multiaddr": "^13.0.3",
80
+ "abort-error": "^1.0.2",
81
+ "birnam": "^1.0.0",
82
+ "interface-blockstore": "^7.0.1",
83
+ "interface-datastore": "^10.0.1",
84
+ "main-event": "^1.0.4",
85
+ "multiformats": "^14.0.0",
86
+ "progress-events": "^1.1.0"
79
87
  },
80
88
  "devDependencies": {
81
- "aegir": "^47.0.22"
89
+ "aegir": "^48.0.11"
82
90
  },
83
91
  "sideEffects": false
84
92
  }
package/src/blocks.ts CHANGED
@@ -1,8 +1,7 @@
1
1
  import type { RoutingFindProvidersProgressEvents } from './routing.ts'
2
- import type { PeerId } from '@libp2p/interface'
3
2
  import type { Multiaddr } from '@multiformats/multiaddr'
3
+ import type { AbortOptions } from 'abort-error'
4
4
  import type { Blockstore } from 'interface-blockstore'
5
- import type { AbortOptions } from 'interface-store'
6
5
  import type { CID } from 'multiformats/cid'
7
6
  import type { ProgressEvent, ProgressOptions } from 'progress-events'
8
7
 
@@ -17,7 +16,7 @@ export interface ProviderOptions {
17
16
  * child blocks, a `findProviders` routing query will be run to find peers
18
17
  * that can supply the blocks.
19
18
  */
20
- providers?: Array<PeerId | Multiaddr | Multiaddr[]>
19
+ providers?: Array<CID | Multiaddr | Multiaddr[]>
21
20
  }
22
21
 
23
22
  /**
@@ -26,7 +25,7 @@ export interface ProviderOptions {
26
25
  export interface BlockBrokerConnectProgressEvent {
27
26
  broker: string
28
27
  type: 'connect'
29
- provider: PeerId
28
+ provider: CID
30
29
  cid: CID
31
30
  }
32
31
 
@@ -36,7 +35,7 @@ export interface BlockBrokerConnectProgressEvent {
36
35
  export interface BlockBrokerConnectedProgressEvent {
37
36
  broker: string
38
37
  type: 'connected'
39
- provider: PeerId
38
+ provider: CID
40
39
  address: Multiaddr
41
40
  cid: CID
42
41
  }
@@ -47,7 +46,7 @@ export interface BlockBrokerConnectedProgressEvent {
47
46
  export interface BlockBrokerRequestBlockProgressEvent {
48
47
  broker: string
49
48
  type: 'request-block'
50
- provider: PeerId
49
+ provider: CID
51
50
  cid: CID
52
51
  }
53
52
 
@@ -57,7 +56,7 @@ export interface BlockBrokerRequestBlockProgressEvent {
57
56
  export interface BlockBrokerReceiveBlockProgressEvent {
58
57
  broker: string
59
58
  type: 'receive-block'
60
- provider: PeerId
59
+ provider: CID
61
60
  cid: CID
62
61
  }
63
62
 
@@ -151,7 +150,7 @@ ProgressOptions<DeleteBlockProgressEvents>, ProgressOptions<DeleteManyBlocksProg
151
150
  * Adds a new peer to the session if they are supported and are either
152
151
  * not already in the session and have not been evicted previously.
153
152
  */
154
- addPeer (peer: PeerId | Multiaddr | Multiaddr[], options?: AbortOptions): Promise<void>
153
+ addPeer (peer: CID | Multiaddr | Multiaddr[], options?: AbortOptions): Promise<void>
155
154
  }
156
155
 
157
156
  export interface BlockRetrievalOptions <ProgressEvents extends ProgressEvent<any, any> = ProgressEvent<any, any>> extends AbortOptions, ProgressOptions<ProgressEvents>, ProviderOptions {
@@ -233,7 +232,7 @@ export interface SessionBlockBroker<RetrieveProgressEvents extends ProgressEvent
233
232
  * Adds a new peer to the session if they are supported and are either
234
233
  * not already in the session and have not been evicted previously.
235
234
  */
236
- addPeer (peer: PeerId | Multiaddr | Multiaddr[], options?: AbortOptions): Promise<void>
235
+ addPeer (peer: CID | Multiaddr | Multiaddr[], options?: AbortOptions): Promise<void>
237
236
  }
238
237
 
239
238
  export const DEFAULT_SESSION_MIN_PROVIDERS = 1
package/src/errors.ts CHANGED
@@ -42,3 +42,8 @@ export class InvalidCodecError extends Error {
42
42
  this.name = 'InvalidCodecError'
43
43
  }
44
44
  }
45
+
46
+ export class UnknownCryptoError extends Error {
47
+ static name = 'UnknownCryptoError'
48
+ name = 'UnknownCryptoError'
49
+ }
package/src/index.ts CHANGED
@@ -14,35 +14,50 @@
14
14
  * ```
15
15
  */
16
16
 
17
- import type { Blocks } from './blocks.ts'
17
+ import type { BlockBroker, Blocks } from './blocks.ts'
18
18
  import type { Pins } from './pins.ts'
19
- import type { Routing } from './routing.ts'
20
- import type { AbortOptions, ComponentLogger, Libp2p, Metrics, TypedEventEmitter } from '@libp2p/interface'
19
+ import type { Router, Routing } from './routing.ts'
20
+ import type { CryptoLoader, Keychain } from '@ipshipyard/keychain'
21
+ import type { Metrics } from '@libp2p/interface'
21
22
  import type { DNS } from '@multiformats/dns'
23
+ import type { AbortOptions } from 'abort-error'
24
+ import type { ComponentLogger } from 'birnam'
22
25
  import type { Datastore } from 'interface-datastore'
23
- import type { Await } from 'interface-store'
26
+ import type { TypedEventEmitter } from 'main-event'
24
27
  import type { BlockCodec, MultihashHasher } from 'multiformats'
25
28
  import type { CID } from 'multiformats/cid'
26
29
  import type { ProgressEvent, ProgressOptions } from 'progress-events'
27
30
 
28
- export type { Await, AwaitIterable } from 'interface-store'
29
-
30
31
  export interface CodecLoader {
31
- <T = any, Code extends number = any>(code: Code): Await<BlockCodec<Code, T>>
32
+ <T = any, Code extends number = any>(code: Code, options?: AbortOptions): BlockCodec<Code, T> | Promise<BlockCodec<Code, T>>
32
33
  }
33
34
 
34
35
  export interface HasherLoader {
35
- (code: number): Await<MultihashHasher>
36
+ (code: number, options?: AbortOptions): MultihashHasher | Promise<MultihashHasher>
37
+ }
38
+
39
+ export type { CryptoLoader, Keychain } from '@ipshipyard/keychain'
40
+ export type { Crypto, PrivateKey, PublicKey } from '@ipshipyard/crypto'
41
+ export { isPrivateKey, isPublicKey } from '@ipshipyard/crypto'
42
+
43
+ export interface NodeInfo {
44
+ name: string
45
+ version: string
46
+ }
47
+
48
+ export interface HeliaMixin<Start extends Helia = Helia, Stop = Start> {
49
+ start?(helia: Start): Promise<void> | void
50
+ stop?(helia: Stop): Promise<void> | void
36
51
  }
37
52
 
38
53
  /**
39
54
  * The API presented by a Helia node
40
55
  */
41
- export interface Helia<T extends Libp2p = Libp2p> {
56
+ export interface Helia {
42
57
  /**
43
- * The libp2p instance
58
+ * Runtime information about the node
44
59
  */
45
- libp2p: T
60
+ info: NodeInfo
46
61
 
47
62
  /**
48
63
  * Where the blocks are stored
@@ -57,7 +72,12 @@ export interface Helia<T extends Libp2p = Libp2p> {
57
72
  /**
58
73
  * Event emitter for Helia start and stop events
59
74
  */
60
- events: TypedEventEmitter<HeliaEvents<T>>
75
+ events: TypedEventEmitter<HeliaEvents<this>>
76
+
77
+ /**
78
+ * Secure storage for private keys
79
+ */
80
+ keychain: Keychain
61
81
 
62
82
  /**
63
83
  * Pinning operations for blocks in the blockstore
@@ -87,15 +107,20 @@ export interface Helia<T extends Libp2p = Libp2p> {
87
107
  */
88
108
  metrics?: Metrics
89
109
 
110
+ /**
111
+ * The current status of the Helia node
112
+ */
113
+ status: 'starting' | 'started' | 'stopping' | 'stopped'
114
+
90
115
  /**
91
116
  * Starts the Helia node
92
117
  */
93
- start(): Promise<void>
118
+ start(options?: AbortOptions): Promise<this>
94
119
 
95
120
  /**
96
121
  * Stops the Helia node
97
122
  */
98
- stop(): Promise<void>
123
+ stop(options?: AbortOptions): Promise<this>
99
124
 
100
125
  /**
101
126
  * Remove any unpinned blocks from the blockstore
@@ -114,6 +139,36 @@ export interface Helia<T extends Libp2p = Libp2p> {
114
139
  * the hasher is being fetched from the network.
115
140
  */
116
141
  getHasher: HasherLoader
142
+
143
+ /**
144
+ * Cryptography implementations securely sign and verify data
145
+ */
146
+ getCrypto: CryptoLoader
147
+
148
+ /**
149
+ * Returns `true` if a router with the passed name has been configured
150
+ */
151
+ hasRouter (name: string): boolean
152
+
153
+ /**
154
+ * Add a router
155
+ */
156
+ addRouter(router: Router): void
157
+
158
+ /**
159
+ * Returns `true` if a block broker with the passed name has been configured
160
+ */
161
+ hasBlockBroker (name: string): boolean
162
+
163
+ /**
164
+ * Add a block broker
165
+ */
166
+ addBlockBroker(blockBroker: BlockBroker): void
167
+
168
+ /**
169
+ * Add a mixin to extend runtime functionality
170
+ */
171
+ addMixin<T extends Helia = Helia & Record<string, any>>(mixin: HeliaMixin<T>): void
117
172
  }
118
173
 
119
174
  export type GcEvents =
@@ -124,7 +179,7 @@ export interface GCOptions extends AbortOptions, ProgressOptions<GcEvents> {
124
179
 
125
180
  }
126
181
 
127
- export interface HeliaEvents<T extends Libp2p = Libp2p> {
182
+ export interface HeliaEvents<H extends Helia = Helia> {
128
183
  /**
129
184
  * This event notifies listeners that the node has started
130
185
  *
@@ -134,7 +189,7 @@ export interface HeliaEvents<T extends Libp2p = Libp2p> {
134
189
  * })
135
190
  * ```
136
191
  */
137
- start: CustomEvent<Helia<T>>
192
+ start: CustomEvent<H>
138
193
 
139
194
  /**
140
195
  * This event notifies listeners that the node has stopped
@@ -145,7 +200,7 @@ export interface HeliaEvents<T extends Libp2p = Libp2p> {
145
200
  * })
146
201
  * ```
147
202
  */
148
- stop: CustomEvent<Helia<T>>
203
+ stop: CustomEvent<H>
149
204
  }
150
205
 
151
206
  export * from './blocks.ts'
package/src/pins.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import type { GetBlockProgressEvents } from './blocks.ts'
2
- import type { AbortOptions } from '@libp2p/interface'
2
+ import type { AbortOptions } from 'abort-error'
3
3
  import type { CID } from 'multiformats/cid'
4
4
  import type { ProgressEvent, ProgressOptions } from 'progress-events'
5
5