@helia/routers 2.0.0 → 2.1.0-e58e49c
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/dist/index.min.js +4 -4
- package/dist/src/delegated-http-routing.d.ts +2 -1
- package/dist/src/delegated-http-routing.d.ts.map +1 -1
- package/dist/src/delegated-http-routing.js +6 -4
- package/dist/src/delegated-http-routing.js.map +1 -1
- package/dist/src/utils/delegated-http-routing-defaults.browser.d.ts +3 -0
- package/dist/src/utils/delegated-http-routing-defaults.browser.d.ts.map +1 -0
- package/dist/src/utils/delegated-http-routing-defaults.browser.js +7 -0
- package/dist/src/utils/delegated-http-routing-defaults.browser.js.map +1 -0
- package/dist/src/utils/delegated-http-routing-defaults.d.ts +3 -0
- package/dist/src/utils/delegated-http-routing-defaults.d.ts.map +1 -0
- package/dist/src/utils/delegated-http-routing-defaults.js +7 -0
- package/dist/src/utils/delegated-http-routing-defaults.js.map +1 -0
- package/package.json +7 -4
- package/src/delegated-http-routing.ts +7 -5
- package/src/utils/delegated-http-routing-defaults.browser.ts +8 -0
- package/src/utils/delegated-http-routing-defaults.ts +8 -0
- package/dist/typedoc-urls.json +0 -6
|
@@ -1,6 +1,7 @@
|
|
|
1
|
+
import type { DelegatedRoutingV1HttpApiClientInit } from '@helia/delegated-routing-v1-http-api-client';
|
|
1
2
|
import type { Routing } from '@helia/interface';
|
|
2
3
|
/**
|
|
3
4
|
* Creates a Helia Router that connects to an endpoint that supports the [Delegated Routing V1 HTTP API](https://specs.ipfs.tech/routing/http-routing-v1/) spec.
|
|
4
5
|
*/
|
|
5
|
-
export declare function delegatedHTTPRouting(url: string | URL): Routing;
|
|
6
|
+
export declare function delegatedHTTPRouting(url: string | URL, init?: DelegatedRoutingV1HttpApiClientInit): Routing;
|
|
6
7
|
//# sourceMappingURL=delegated-http-routing.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delegated-http-routing.d.ts","sourceRoot":"","sources":["../../src/delegated-http-routing.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAY,OAAO,EAAkB,MAAM,kBAAkB,CAAA;AAoFzE;;GAEG;AACH,wBAAgB,oBAAoB,CAAE,GAAG,EAAE,MAAM,GAAG,GAAG,GAAG,OAAO,
|
|
1
|
+
{"version":3,"file":"delegated-http-routing.d.ts","sourceRoot":"","sources":["../../src/delegated-http-routing.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAmC,mCAAmC,EAAE,MAAM,6CAA6C,CAAA;AACvI,OAAO,KAAK,EAAY,OAAO,EAAkB,MAAM,kBAAkB,CAAA;AAoFzE;;GAEG;AACH,wBAAgB,oBAAoB,CAAE,GAAG,EAAE,MAAM,GAAG,GAAG,EAAE,IAAI,CAAC,EAAE,mCAAmC,GAAG,OAAO,CAG5G"}
|
|
@@ -6,14 +6,15 @@ import map from 'it-map';
|
|
|
6
6
|
import { CID } from 'multiformats/cid';
|
|
7
7
|
import { equals as uint8ArrayEquals } from 'uint8arrays/equals';
|
|
8
8
|
import { fromString as uint8ArrayFromString } from 'uint8arrays/from-string';
|
|
9
|
+
import { delegatedHTTPRoutingDefaults } from './utils/delegated-http-routing-defaults.js';
|
|
9
10
|
const IPNS_PREFIX = uint8ArrayFromString('/ipns/');
|
|
10
11
|
function isIPNSKey(key) {
|
|
11
12
|
return uint8ArrayEquals(key.subarray(0, IPNS_PREFIX.byteLength), IPNS_PREFIX);
|
|
12
13
|
}
|
|
13
14
|
class DelegatedHTTPRouter {
|
|
14
15
|
client;
|
|
15
|
-
constructor(url) {
|
|
16
|
-
this.client = createDelegatedRoutingV1HttpApiClient(url);
|
|
16
|
+
constructor(url, init = {}) {
|
|
17
|
+
this.client = createDelegatedRoutingV1HttpApiClient(url, init);
|
|
17
18
|
}
|
|
18
19
|
async provide(cid, options) {
|
|
19
20
|
// noop
|
|
@@ -72,7 +73,8 @@ class DelegatedHTTPRouter {
|
|
|
72
73
|
/**
|
|
73
74
|
* Creates a Helia Router that connects to an endpoint that supports the [Delegated Routing V1 HTTP API](https://specs.ipfs.tech/routing/http-routing-v1/) spec.
|
|
74
75
|
*/
|
|
75
|
-
export function delegatedHTTPRouting(url) {
|
|
76
|
-
|
|
76
|
+
export function delegatedHTTPRouting(url, init) {
|
|
77
|
+
const config = init ?? delegatedHTTPRoutingDefaults();
|
|
78
|
+
return new DelegatedHTTPRouter(new URL(url), config);
|
|
77
79
|
}
|
|
78
80
|
//# sourceMappingURL=delegated-http-routing.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delegated-http-routing.js","sourceRoot":"","sources":["../../src/delegated-http-routing.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qCAAqC,EAAE,MAAM,6CAA6C,CAAA;AACnG,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AACjD,OAAO,EAAE,iBAAiB,EAAE,2BAA2B,EAAE,mBAAmB,EAAE,MAAM,MAAM,CAAA;AAC1F,OAAO,KAAK,MAAM,UAAU,CAAA;AAC5B,OAAO,GAAG,MAAM,QAAQ,CAAA;AACxB,OAAO,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAA;AACtC,OAAO,EAAE,MAAM,IAAI,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AAC/D,OAAO,EAAE,UAAU,IAAI,oBAAoB,EAAE,MAAM,yBAAyB,CAAA;
|
|
1
|
+
{"version":3,"file":"delegated-http-routing.js","sourceRoot":"","sources":["../../src/delegated-http-routing.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delegated-http-routing-defaults.browser.d.ts","sourceRoot":"","sources":["../../../src/utils/delegated-http-routing-defaults.browser.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mCAAmC,EAAE,MAAM,6CAA6C,CAAA;AAEtG,wBAAgB,4BAA4B,IAAK,mCAAmC,CAKnF"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export function delegatedHTTPRoutingDefaults() {
|
|
2
|
+
return {
|
|
3
|
+
filterProtocols: ['unknown', 'transport-bitswap', 'transport-ipfs-gateway-http'],
|
|
4
|
+
filterAddrs: ['https', 'webtransport', 'webrtc', 'webrtc-direct', 'wss']
|
|
5
|
+
};
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=delegated-http-routing-defaults.browser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delegated-http-routing-defaults.browser.js","sourceRoot":"","sources":["../../../src/utils/delegated-http-routing-defaults.browser.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,4BAA4B;IAC1C,OAAO;QACL,eAAe,EAAE,CAAC,SAAS,EAAE,mBAAmB,EAAE,6BAA6B,CAAC;QAChF,WAAW,EAAE,CAAC,OAAO,EAAE,cAAc,EAAE,QAAQ,EAAE,eAAe,EAAE,KAAK,CAAC;KACzE,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delegated-http-routing-defaults.d.ts","sourceRoot":"","sources":["../../../src/utils/delegated-http-routing-defaults.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mCAAmC,EAAE,MAAM,6CAA6C,CAAA;AAEtG,wBAAgB,4BAA4B,IAAK,mCAAmC,CAKnF"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export function delegatedHTTPRoutingDefaults() {
|
|
2
|
+
return {
|
|
3
|
+
filterProtocols: ['unknown', 'transport-bitswap', 'transport-ipfs-gateway-http'],
|
|
4
|
+
filterAddrs: ['https', 'tcp', 'webrtc', 'webrtc-direct', 'wss']
|
|
5
|
+
};
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=delegated-http-routing-defaults.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delegated-http-routing-defaults.js","sourceRoot":"","sources":["../../../src/utils/delegated-http-routing-defaults.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,4BAA4B;IAC1C,OAAO;QACL,eAAe,EAAE,CAAC,SAAS,EAAE,mBAAmB,EAAE,6BAA6B,CAAC;QAChF,WAAW,EAAE,CAAC,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,eAAe,EAAE,KAAK,CAAC;KAChE,CAAA;AACH,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@helia/routers",
|
|
3
|
-
"version": "2.
|
|
3
|
+
"version": "2.1.0-e58e49c",
|
|
4
4
|
"description": "Routers for Helia",
|
|
5
5
|
"license": "Apache-2.0 OR MIT",
|
|
6
6
|
"homepage": "https://github.com/ipfs/helia/tree/main/packages/routers#readme",
|
|
@@ -54,8 +54,8 @@
|
|
|
54
54
|
"test:electron-main": "aegir test -t electron-main"
|
|
55
55
|
},
|
|
56
56
|
"dependencies": {
|
|
57
|
-
"@helia/delegated-routing-v1-http-api-client": "^4.
|
|
58
|
-
"@helia/interface": "
|
|
57
|
+
"@helia/delegated-routing-v1-http-api-client": "^4.1.0",
|
|
58
|
+
"@helia/interface": "5.0.0-e58e49c",
|
|
59
59
|
"@libp2p/peer-id": "^5.0.0",
|
|
60
60
|
"@libp2p/interface": "^2.0.0",
|
|
61
61
|
"@multiformats/uri-to-multiaddr": "^8.0.0",
|
|
@@ -67,10 +67,13 @@
|
|
|
67
67
|
},
|
|
68
68
|
"devDependencies": {
|
|
69
69
|
"@libp2p/crypto": "^5.0.0",
|
|
70
|
-
"aegir": "^
|
|
70
|
+
"aegir": "^45.0.1",
|
|
71
71
|
"it-all": "^3.0.4",
|
|
72
72
|
"it-drain": "^3.0.5",
|
|
73
73
|
"sinon-ts": "^2.0.0"
|
|
74
74
|
},
|
|
75
|
+
"browser": {
|
|
76
|
+
"./dist/src/utils/delegated-http-routing-defaults.js": "./dist/src/utils/delegated-http-routing-defaults.browser.js"
|
|
77
|
+
},
|
|
75
78
|
"sideEffects": false
|
|
76
79
|
}
|
|
@@ -6,7 +6,8 @@ import map from 'it-map'
|
|
|
6
6
|
import { CID } from 'multiformats/cid'
|
|
7
7
|
import { equals as uint8ArrayEquals } from 'uint8arrays/equals'
|
|
8
8
|
import { fromString as uint8ArrayFromString } from 'uint8arrays/from-string'
|
|
9
|
-
import
|
|
9
|
+
import { delegatedHTTPRoutingDefaults } from './utils/delegated-http-routing-defaults.js'
|
|
10
|
+
import type { DelegatedRoutingV1HttpApiClient, DelegatedRoutingV1HttpApiClientInit } from '@helia/delegated-routing-v1-http-api-client'
|
|
10
11
|
import type { Provider, Routing, RoutingOptions } from '@helia/interface'
|
|
11
12
|
import type { PeerId, PeerInfo } from '@libp2p/interface'
|
|
12
13
|
import type { Version } from 'multiformats'
|
|
@@ -20,8 +21,8 @@ function isIPNSKey (key: Uint8Array): boolean {
|
|
|
20
21
|
class DelegatedHTTPRouter implements Routing {
|
|
21
22
|
private readonly client: DelegatedRoutingV1HttpApiClient
|
|
22
23
|
|
|
23
|
-
constructor (url: URL) {
|
|
24
|
-
this.client = createDelegatedRoutingV1HttpApiClient(url)
|
|
24
|
+
constructor (url: URL, init: DelegatedRoutingV1HttpApiClientInit = {}) {
|
|
25
|
+
this.client = createDelegatedRoutingV1HttpApiClient(url, init)
|
|
25
26
|
}
|
|
26
27
|
|
|
27
28
|
async provide (cid: CID, options?: RoutingOptions | undefined): Promise<void> {
|
|
@@ -94,6 +95,7 @@ class DelegatedHTTPRouter implements Routing {
|
|
|
94
95
|
/**
|
|
95
96
|
* Creates a Helia Router that connects to an endpoint that supports the [Delegated Routing V1 HTTP API](https://specs.ipfs.tech/routing/http-routing-v1/) spec.
|
|
96
97
|
*/
|
|
97
|
-
export function delegatedHTTPRouting (url: string | URL): Routing {
|
|
98
|
-
|
|
98
|
+
export function delegatedHTTPRouting (url: string | URL, init?: DelegatedRoutingV1HttpApiClientInit): Routing {
|
|
99
|
+
const config = init ?? delegatedHTTPRoutingDefaults()
|
|
100
|
+
return new DelegatedHTTPRouter(new URL(url), config)
|
|
99
101
|
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { DelegatedRoutingV1HttpApiClientInit } from '@helia/delegated-routing-v1-http-api-client'
|
|
2
|
+
|
|
3
|
+
export function delegatedHTTPRoutingDefaults (): DelegatedRoutingV1HttpApiClientInit {
|
|
4
|
+
return {
|
|
5
|
+
filterProtocols: ['unknown', 'transport-bitswap', 'transport-ipfs-gateway-http'],
|
|
6
|
+
filterAddrs: ['https', 'webtransport', 'webrtc', 'webrtc-direct', 'wss']
|
|
7
|
+
}
|
|
8
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { DelegatedRoutingV1HttpApiClientInit } from '@helia/delegated-routing-v1-http-api-client'
|
|
2
|
+
|
|
3
|
+
export function delegatedHTTPRoutingDefaults (): DelegatedRoutingV1HttpApiClientInit {
|
|
4
|
+
return {
|
|
5
|
+
filterProtocols: ['unknown', 'transport-bitswap', 'transport-ipfs-gateway-http'],
|
|
6
|
+
filterAddrs: ['https', 'tcp', 'webrtc', 'webrtc-direct', 'wss']
|
|
7
|
+
}
|
|
8
|
+
}
|
package/dist/typedoc-urls.json
DELETED
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"HTTPGatwayRouterInit": "https://ipfs.github.io/helia/interfaces/_helia_routers.HTTPGatwayRouterInit.html",
|
|
3
|
-
"delegatedHTTPRouting": "https://ipfs.github.io/helia/functions/_helia_routers.delegatedHTTPRouting.html",
|
|
4
|
-
"httpGatewayRouting": "https://ipfs.github.io/helia/functions/_helia_routers.httpGatewayRouting.html",
|
|
5
|
-
"libp2pRouting": "https://ipfs.github.io/helia/functions/_helia_routers.libp2pRouting.html"
|
|
6
|
-
}
|