@helia/interop 3.0.1 → 4.0.0-e554493
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/.aegir.js +46 -0
- package/README.md +11 -0
- package/dist/src/bin.d.ts +3 -0
- package/dist/src/bin.d.ts.map +1 -0
- package/dist/src/bin.js +20 -0
- package/dist/src/bin.js.map +1 -0
- package/dist/src/car.spec.d.ts +2 -0
- package/dist/src/car.spec.d.ts.map +1 -0
- package/dist/src/car.spec.js +77 -0
- package/dist/src/car.spec.js.map +1 -0
- package/dist/src/dag-cbor.spec.d.ts +2 -0
- package/dist/src/dag-cbor.spec.d.ts.map +1 -0
- package/dist/src/dag-cbor.spec.js +49 -0
- package/dist/src/dag-cbor.spec.js.map +1 -0
- package/dist/src/dag-json.spec.d.ts +2 -0
- package/dist/src/dag-json.spec.d.ts.map +1 -0
- package/dist/src/dag-json.spec.js +49 -0
- package/dist/src/dag-json.spec.js.map +1 -0
- package/dist/src/fixtures/connect.d.ts +7 -0
- package/dist/src/fixtures/connect.d.ts.map +1 -0
- package/dist/src/fixtures/connect.js +17 -0
- package/dist/src/fixtures/connect.js.map +1 -0
- package/dist/src/fixtures/create-helia-http.d.ts +4 -0
- package/dist/src/fixtures/create-helia-http.d.ts.map +1 -0
- package/dist/src/fixtures/create-helia-http.js +7 -0
- package/dist/src/fixtures/create-helia-http.js.map +1 -0
- package/dist/src/fixtures/create-helia.browser.d.ts +6 -0
- package/dist/src/fixtures/create-helia.browser.d.ts.map +1 -0
- package/dist/src/fixtures/create-helia.browser.js +56 -0
- package/dist/src/fixtures/create-helia.browser.js.map +1 -0
- package/dist/src/fixtures/create-helia.d.ts +6 -0
- package/dist/src/fixtures/create-helia.d.ts.map +1 -0
- package/dist/src/fixtures/create-helia.js +46 -0
- package/dist/src/fixtures/create-helia.js.map +1 -0
- package/dist/src/fixtures/create-kubo.browser.d.ts +3 -0
- package/dist/src/fixtures/create-kubo.browser.d.ts.map +1 -0
- package/dist/src/fixtures/create-kubo.browser.js +30 -0
- package/dist/src/fixtures/create-kubo.browser.js.map +1 -0
- package/dist/src/fixtures/create-kubo.d.ts +3 -0
- package/dist/src/fixtures/create-kubo.d.ts.map +1 -0
- package/dist/src/fixtures/create-kubo.js +32 -0
- package/dist/src/fixtures/create-kubo.js.map +1 -0
- package/dist/src/fixtures/create-peer-ids.d.ts +14 -0
- package/dist/src/fixtures/create-peer-ids.d.ts.map +1 -0
- package/dist/src/fixtures/create-peer-ids.js +37 -0
- package/dist/src/fixtures/create-peer-ids.js.map +1 -0
- package/dist/src/fixtures/key-types.d.ts +3 -0
- package/dist/src/fixtures/key-types.d.ts.map +1 -0
- package/dist/src/fixtures/key-types.js +6 -0
- package/dist/src/fixtures/key-types.js.map +1 -0
- package/dist/src/fixtures/memory-car.d.ts +7 -0
- package/dist/src/fixtures/memory-car.d.ts.map +1 -0
- package/dist/src/fixtures/memory-car.js +26 -0
- package/dist/src/fixtures/memory-car.js.map +1 -0
- package/dist/src/fixtures/wait-for.d.ts +7 -0
- package/dist/src/fixtures/wait-for.d.ts.map +1 -0
- package/dist/src/fixtures/wait-for.js +17 -0
- package/dist/src/fixtures/wait-for.js.map +1 -0
- package/dist/src/helia-blockstore.spec.d.ts +2 -0
- package/dist/src/helia-blockstore.spec.d.ts.map +1 -0
- package/dist/src/helia-blockstore.spec.js +48 -0
- package/dist/src/helia-blockstore.spec.js.map +1 -0
- package/dist/src/helia-hashes.spec.d.ts +2 -0
- package/dist/src/helia-hashes.spec.d.ts.map +1 -0
- package/dist/src/helia-hashes.spec.js +50 -0
- package/dist/src/helia-hashes.spec.js.map +1 -0
- package/dist/src/helia-pins.spec.d.ts +2 -0
- package/dist/src/helia-pins.spec.d.ts.map +1 -0
- package/dist/src/helia-pins.spec.js +48 -0
- package/dist/src/helia-pins.spec.js.map +1 -0
- package/dist/src/index.d.ts +12 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +12 -0
- package/dist/src/index.js.map +1 -1
- package/dist/src/ipns-http.spec.d.ts +2 -0
- package/dist/src/ipns-http.spec.d.ts.map +1 -0
- package/dist/src/ipns-http.spec.js +55 -0
- package/dist/src/ipns-http.spec.js.map +1 -0
- package/dist/src/ipns-pubsub.spec.d.ts +2 -0
- package/dist/src/ipns-pubsub.spec.d.ts.map +1 -0
- package/dist/src/ipns-pubsub.spec.js +151 -0
- package/dist/src/ipns-pubsub.spec.js.map +1 -0
- package/dist/src/ipns.spec.d.ts +2 -0
- package/dist/src/ipns.spec.d.ts.map +1 -0
- package/dist/src/ipns.spec.js +146 -0
- package/dist/src/ipns.spec.js.map +1 -0
- package/dist/src/json.spec.d.ts +2 -0
- package/dist/src/json.spec.d.ts.map +1 -0
- package/dist/src/json.spec.js +49 -0
- package/dist/src/json.spec.js.map +1 -0
- package/dist/src/mfs.spec.d.ts +2 -0
- package/dist/src/mfs.spec.d.ts.map +1 -0
- package/dist/src/mfs.spec.js +85 -0
- package/dist/src/mfs.spec.js.map +1 -0
- package/dist/src/strings.spec.d.ts +2 -0
- package/dist/src/strings.spec.d.ts.map +1 -0
- package/dist/src/strings.spec.js +51 -0
- package/dist/src/strings.spec.js.map +1 -0
- package/dist/src/unixfs-bitswap.spec.d.ts +2 -0
- package/dist/src/unixfs-bitswap.spec.d.ts.map +1 -0
- package/dist/src/unixfs-bitswap.spec.js +65 -0
- package/dist/src/unixfs-bitswap.spec.js.map +1 -0
- package/dist/src/unixfs-files.spec.d.ts +2 -0
- package/dist/src/unixfs-files.spec.d.ts.map +1 -0
- package/dist/src/unixfs-files.spec.js +69 -0
- package/dist/src/unixfs-files.spec.js.map +1 -0
- package/package.json +33 -20
- package/src/bin.ts +25 -0
- package/src/car.spec.ts +102 -0
- package/src/dag-cbor.spec.ts +65 -0
- package/src/dag-json.spec.ts +65 -0
- package/src/fixtures/connect.ts +19 -0
- package/src/fixtures/create-helia-http.ts +8 -0
- package/src/fixtures/create-helia.browser.ts +68 -0
- package/src/fixtures/create-helia.ts +55 -0
- package/src/fixtures/create-kubo.browser.ts +30 -0
- package/src/fixtures/create-kubo.ts +32 -0
- package/src/fixtures/create-peer-ids.ts +46 -0
- package/src/fixtures/key-types.ts +7 -0
- package/src/fixtures/memory-car.ts +33 -0
- package/src/fixtures/wait-for.ts +26 -0
- package/src/helia-blockstore.spec.ts +59 -0
- package/src/helia-hashes.spec.ts +61 -0
- package/src/helia-pins.spec.ts +64 -0
- package/src/index.ts +13 -0
- package/src/ipns-http.spec.ts +68 -0
- package/src/ipns-pubsub.spec.ts +187 -0
- package/src/ipns.spec.ts +183 -0
- package/src/json.spec.ts +65 -0
- package/src/mfs.spec.ts +105 -0
- package/src/strings.spec.ts +67 -0
- package/src/unixfs-bitswap.spec.ts +86 -0
- package/src/unixfs-files.spec.ts +89 -0
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import all from 'it-all';
|
|
2
|
+
import map from 'it-map';
|
|
3
|
+
import { sha256 } from 'multiformats/hashes/sha2';
|
|
4
|
+
import { compare as uint8ArrayCompare } from 'uint8arrays/compare';
|
|
5
|
+
import { xor as uint8ArrayXor } from 'uint8arrays/xor';
|
|
6
|
+
/**
|
|
7
|
+
* Sort peers by distance to the KadID of the passed buffer
|
|
8
|
+
*/
|
|
9
|
+
export async function sortClosestPeers(buf, peers) {
|
|
10
|
+
const kadId = await convertBuffer(buf);
|
|
11
|
+
const distances = await all(map(peers, async (peer) => {
|
|
12
|
+
const id = await convertPeerId(peer);
|
|
13
|
+
return {
|
|
14
|
+
peer,
|
|
15
|
+
distance: uint8ArrayXor(id, kadId)
|
|
16
|
+
};
|
|
17
|
+
}));
|
|
18
|
+
return distances
|
|
19
|
+
.sort((a, b) => {
|
|
20
|
+
return uint8ArrayCompare(a.distance, b.distance);
|
|
21
|
+
})
|
|
22
|
+
.map((d) => d.peer);
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Creates a DHT ID by hashing a Peer ID
|
|
26
|
+
*/
|
|
27
|
+
export async function convertPeerId(peerId) {
|
|
28
|
+
return convertBuffer(peerId.toBytes());
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Creates a DHT ID by hashing a given Uint8Array
|
|
32
|
+
*/
|
|
33
|
+
export async function convertBuffer(buf) {
|
|
34
|
+
const multihash = await sha256.digest(buf);
|
|
35
|
+
return multihash.digest;
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=create-peer-ids.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-peer-ids.js","sourceRoot":"","sources":["../../../src/fixtures/create-peer-ids.ts"],"names":[],"mappings":"AAAA,OAAO,GAAG,MAAM,QAAQ,CAAA;AACxB,OAAO,GAAG,MAAM,QAAQ,CAAA;AACxB,OAAO,EAAE,MAAM,EAAE,MAAM,0BAA0B,CAAA;AACjD,OAAO,EAAE,OAAO,IAAI,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AAClE,OAAO,EAAE,GAAG,IAAI,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAGtD;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAE,GAAe,EAAE,KAAe;IACtE,MAAM,KAAK,GAAG,MAAM,aAAa,CAAC,GAAG,CAAC,CAAA;IAEtC,MAAM,SAAS,GAAG,MAAM,GAAG,CACzB,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;QACxB,MAAM,EAAE,GAAG,MAAM,aAAa,CAAC,IAAI,CAAC,CAAA;QAEpC,OAAO;YACL,IAAI;YACJ,QAAQ,EAAE,aAAa,CAAC,EAAE,EAAE,KAAK,CAAC;SACnC,CAAA;IACH,CAAC,CAAC,CACH,CAAA;IAED,OAAO,SAAS;SACb,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;QACb,OAAO,iBAAiB,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAA;IAClD,CAAC,CAAC;SACD,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;AACvB,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,aAAa,CAAE,MAAc;IACjD,OAAO,aAAa,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,CAAA;AACxC,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,aAAa,CAAE,GAAe;IAClD,MAAM,SAAS,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;IAE1C,OAAO,SAAS,CAAC,MAAM,CAAA;AACzB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"key-types.d.ts","sourceRoot":"","sources":["../../../src/fixtures/key-types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAA;AAEnD,eAAO,MAAM,QAAQ,EAAE,UAAU,EAIhC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"key-types.js","sourceRoot":"","sources":["../../../src/fixtures/key-types.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,QAAQ,GAAiB;IACpC,SAAS;IACT,WAAW;IACX,KAAK;CACN,CAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { CarWriter } from '@ipld/car';
|
|
2
|
+
import type { CID } from 'multiformats/cid';
|
|
3
|
+
export interface MemoryCar extends Pick<CarWriter, 'put' | 'close'> {
|
|
4
|
+
bytes(): Promise<Uint8Array>;
|
|
5
|
+
}
|
|
6
|
+
export declare function memoryCarWriter(root: CID | CID[]): MemoryCar;
|
|
7
|
+
//# sourceMappingURL=memory-car.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"memory-car.d.ts","sourceRoot":"","sources":["../../../src/fixtures/memory-car.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAA;AAGrC,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAA;AAE3C,MAAM,WAAW,SAAU,SAAQ,IAAI,CAAC,SAAS,EAAE,KAAK,GAAG,OAAO,CAAC;IACjE,KAAK,IAAI,OAAO,CAAC,UAAU,CAAC,CAAA;CAC7B;AAED,wBAAgB,eAAe,CAAE,IAAI,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,SAAS,CAuB7D"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { CarWriter } from '@ipld/car';
|
|
2
|
+
import toBuffer from 'it-to-buffer';
|
|
3
|
+
import defer from 'p-defer';
|
|
4
|
+
export function memoryCarWriter(root) {
|
|
5
|
+
const deferred = defer();
|
|
6
|
+
const { writer, out } = CarWriter.create(Array.isArray(root) ? root : [root]);
|
|
7
|
+
Promise.resolve()
|
|
8
|
+
.then(async () => {
|
|
9
|
+
deferred.resolve(await toBuffer(out));
|
|
10
|
+
})
|
|
11
|
+
.catch(err => {
|
|
12
|
+
deferred.reject(err);
|
|
13
|
+
});
|
|
14
|
+
return {
|
|
15
|
+
async put(block) {
|
|
16
|
+
await writer.put(block);
|
|
17
|
+
},
|
|
18
|
+
async close() {
|
|
19
|
+
await writer.close();
|
|
20
|
+
},
|
|
21
|
+
async bytes() {
|
|
22
|
+
return deferred.promise;
|
|
23
|
+
}
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=memory-car.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"memory-car.js","sourceRoot":"","sources":["../../../src/fixtures/memory-car.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAA;AACrC,OAAO,QAAQ,MAAM,cAAc,CAAA;AACnC,OAAO,KAAK,MAAM,SAAS,CAAA;AAO3B,MAAM,UAAU,eAAe,CAAE,IAAiB;IAChD,MAAM,QAAQ,GAAG,KAAK,EAAc,CAAA;IACpC,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,GAAG,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAA;IAE7E,OAAO,CAAC,OAAO,EAAE;SACd,IAAI,CAAC,KAAK,IAAI,EAAE;QACf,QAAQ,CAAC,OAAO,CAAC,MAAM,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAA;IACvC,CAAC,CAAC;SACD,KAAK,CAAC,GAAG,CAAC,EAAE;QACX,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;IACtB,CAAC,CAAC,CAAA;IAEJ,OAAO;QACL,KAAK,CAAC,GAAG,CAAE,KAAsC;YAC/C,MAAM,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAA;QACzB,CAAC;QACD,KAAK,CAAC,KAAK;YACT,MAAM,MAAM,CAAC,KAAK,EAAE,CAAA;QACtB,CAAC;QACD,KAAK,CAAC,KAAK;YACT,OAAO,QAAQ,CAAC,OAAO,CAAA;QACzB,CAAC;KACF,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"wait-for.d.ts","sourceRoot":"","sources":["../../../src/fixtures/wait-for.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,cAAc;IAC7B,OAAO,EAAE,MAAM,CAAA;IACf,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB;AAED,wBAAsB,OAAO,CAAE,EAAE,EAAE,MAAM,OAAO,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC,CAmBjG"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export async function waitFor(fn, options) {
|
|
2
|
+
const delay = options.delay ?? 100;
|
|
3
|
+
const timeoutAt = Date.now() + options.timeout;
|
|
4
|
+
while (true) {
|
|
5
|
+
const result = await fn();
|
|
6
|
+
if (result) {
|
|
7
|
+
return;
|
|
8
|
+
}
|
|
9
|
+
await new Promise((resolve) => {
|
|
10
|
+
setTimeout(() => { resolve(); }, delay);
|
|
11
|
+
});
|
|
12
|
+
if (Date.now() > timeoutAt) {
|
|
13
|
+
throw new Error(options.message ?? 'WaitFor timed out');
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=wait-for.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"wait-for.js","sourceRoot":"","sources":["../../../src/fixtures/wait-for.ts"],"names":[],"mappings":"AAMA,MAAM,CAAC,KAAK,UAAU,OAAO,CAAE,EAA0B,EAAE,OAAuB;IAChF,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,GAAG,CAAA;IAClC,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,OAAO,CAAC,OAAO,CAAA;IAE9C,OAAO,IAAI,EAAE,CAAC;QACZ,MAAM,MAAM,GAAG,MAAM,EAAE,EAAE,CAAA;QAEzB,IAAI,MAAM,EAAE,CAAC;YACX,OAAM;QACR,CAAC;QAED,MAAM,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,EAAE;YAClC,UAAU,CAAC,GAAG,EAAE,GAAG,OAAO,EAAE,CAAA,CAAC,CAAC,EAAE,KAAK,CAAC,CAAA;QACxC,CAAC,CAAC,CAAA;QAEF,IAAI,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,EAAE,CAAC;YAC3B,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,IAAI,mBAAmB,CAAC,CAAA;QACzD,CAAC;IACH,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helia-blockstore.spec.d.ts","sourceRoot":"","sources":["../../src/helia-blockstore.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
/* eslint-env mocha */
|
|
2
|
+
import { peerIdFromString } from '@libp2p/peer-id';
|
|
3
|
+
import { expect } from 'aegir/chai';
|
|
4
|
+
import toBuffer from 'it-to-buffer';
|
|
5
|
+
import { CID } from 'multiformats/cid';
|
|
6
|
+
import * as raw from 'multiformats/codecs/raw';
|
|
7
|
+
import { sha256 } from 'multiformats/hashes/sha2';
|
|
8
|
+
import { createHeliaNode } from './fixtures/create-helia.js';
|
|
9
|
+
import { createKuboNode } from './fixtures/create-kubo.js';
|
|
10
|
+
describe('helia - blockstore', () => {
|
|
11
|
+
let helia;
|
|
12
|
+
let kubo;
|
|
13
|
+
beforeEach(async () => {
|
|
14
|
+
helia = await createHeliaNode();
|
|
15
|
+
kubo = await createKuboNode();
|
|
16
|
+
// connect the two nodes
|
|
17
|
+
await helia.libp2p.peerStore.merge(peerIdFromString(kubo.peer.id.toString()), {
|
|
18
|
+
multiaddrs: kubo.peer.addresses
|
|
19
|
+
});
|
|
20
|
+
await helia.libp2p.dial(peerIdFromString(kubo.peer.id.toString()));
|
|
21
|
+
});
|
|
22
|
+
afterEach(async () => {
|
|
23
|
+
if (helia != null) {
|
|
24
|
+
await helia.stop();
|
|
25
|
+
}
|
|
26
|
+
if (kubo != null) {
|
|
27
|
+
await kubo.stop();
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
it('should be able to send a block', async () => {
|
|
31
|
+
const input = Uint8Array.from([0, 1, 2, 3, 4]);
|
|
32
|
+
const digest = await sha256.digest(input);
|
|
33
|
+
const cid = CID.createV1(raw.code, digest);
|
|
34
|
+
await helia.blockstore.put(cid, input);
|
|
35
|
+
const output = await toBuffer(kubo.api.cat(cid));
|
|
36
|
+
expect(output).to.equalBytes(input);
|
|
37
|
+
});
|
|
38
|
+
it('should be able to receive a block', async () => {
|
|
39
|
+
const input = Uint8Array.from([0, 1, 2, 3, 4]);
|
|
40
|
+
const { cid } = await kubo.api.add({ content: input }, {
|
|
41
|
+
cidVersion: 1,
|
|
42
|
+
rawLeaves: true
|
|
43
|
+
});
|
|
44
|
+
const output = await helia.blockstore.get(CID.parse(cid.toString()));
|
|
45
|
+
expect(output).to.equalBytes(input);
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
//# sourceMappingURL=helia-blockstore.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helia-blockstore.spec.js","sourceRoot":"","sources":["../../src/helia-blockstore.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helia-hashes.spec.d.ts","sourceRoot":"","sources":["../../src/helia-hashes.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/* eslint-env mocha */
|
|
2
|
+
import { peerIdFromString } from '@libp2p/peer-id';
|
|
3
|
+
import { sha3512 } from '@multiformats/sha3';
|
|
4
|
+
import { expect } from 'aegir/chai';
|
|
5
|
+
import toBuffer from 'it-to-buffer';
|
|
6
|
+
import { CID } from 'multiformats/cid';
|
|
7
|
+
import * as raw from 'multiformats/codecs/raw';
|
|
8
|
+
import { createHeliaNode } from './fixtures/create-helia.js';
|
|
9
|
+
import { createKuboNode } from './fixtures/create-kubo.js';
|
|
10
|
+
describe('helia - hashes', () => {
|
|
11
|
+
let helia;
|
|
12
|
+
let kubo;
|
|
13
|
+
beforeEach(async () => {
|
|
14
|
+
helia = await createHeliaNode();
|
|
15
|
+
kubo = await createKuboNode();
|
|
16
|
+
// connect the two nodes
|
|
17
|
+
await helia.libp2p.peerStore.merge(peerIdFromString(kubo.peer.id.toString()), {
|
|
18
|
+
multiaddrs: kubo.peer.addresses
|
|
19
|
+
});
|
|
20
|
+
await helia.libp2p.dial(peerIdFromString(kubo.peer.id.toString()));
|
|
21
|
+
});
|
|
22
|
+
afterEach(async () => {
|
|
23
|
+
if (helia != null) {
|
|
24
|
+
await helia.stop();
|
|
25
|
+
}
|
|
26
|
+
if (kubo != null) {
|
|
27
|
+
await kubo.stop();
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
it('should be able to send a block with a non-default hash', async () => {
|
|
31
|
+
const input = Uint8Array.from([0, 1, 2, 3, 4]);
|
|
32
|
+
const digest = await sha3512.digest(input);
|
|
33
|
+
const cid = CID.createV1(raw.code, digest);
|
|
34
|
+
await helia.blockstore.put(cid, input);
|
|
35
|
+
const output = await toBuffer(kubo.api.cat(cid));
|
|
36
|
+
expect(output).to.equalBytes(input);
|
|
37
|
+
});
|
|
38
|
+
it('should be able to receive a block with a non-default hash', async () => {
|
|
39
|
+
const input = Uint8Array.from([0, 1, 2, 3, 4]);
|
|
40
|
+
const { cid } = await kubo.api.add({ content: input }, {
|
|
41
|
+
cidVersion: 1,
|
|
42
|
+
rawLeaves: true,
|
|
43
|
+
hashAlg: 'sha3-512'
|
|
44
|
+
});
|
|
45
|
+
expect(cid.multihash.code).to.equal(sha3512.code);
|
|
46
|
+
const output = await helia.blockstore.get(CID.parse(cid.toString()));
|
|
47
|
+
expect(output).to.equalBytes(input);
|
|
48
|
+
});
|
|
49
|
+
});
|
|
50
|
+
//# sourceMappingURL=helia-hashes.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helia-hashes.spec.js","sourceRoot":"","sources":["../../src/helia-hashes.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helia-pins.spec.d.ts","sourceRoot":"","sources":["../../src/helia-pins.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
/* eslint-env mocha */
|
|
2
|
+
import { expect } from 'aegir/chai';
|
|
3
|
+
import all from 'it-all';
|
|
4
|
+
import drain from 'it-drain';
|
|
5
|
+
import { CID } from 'multiformats/cid';
|
|
6
|
+
import * as raw from 'multiformats/codecs/raw';
|
|
7
|
+
import { sha256 } from 'multiformats/hashes/sha2';
|
|
8
|
+
import { createHeliaNode } from './fixtures/create-helia.js';
|
|
9
|
+
import { createKuboNode } from './fixtures/create-kubo.js';
|
|
10
|
+
describe('helia - pins', () => {
|
|
11
|
+
let helia;
|
|
12
|
+
let kubo;
|
|
13
|
+
beforeEach(async () => {
|
|
14
|
+
helia = await createHeliaNode();
|
|
15
|
+
kubo = await createKuboNode();
|
|
16
|
+
// connect the two nodes
|
|
17
|
+
await helia.libp2p.dial(kubo.peer.addresses);
|
|
18
|
+
});
|
|
19
|
+
afterEach(async () => {
|
|
20
|
+
if (helia != null) {
|
|
21
|
+
await helia.stop();
|
|
22
|
+
}
|
|
23
|
+
if (kubo != null) {
|
|
24
|
+
await kubo.stop();
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
it('pinning on kubo should pull from helia', async () => {
|
|
28
|
+
const input = Uint8Array.from([0, 1, 2, 3, 4]);
|
|
29
|
+
const digest = await sha256.digest(input);
|
|
30
|
+
const cid = CID.createV1(raw.code, digest);
|
|
31
|
+
expect((await all(kubo.api.refs.local())).map(r => r.ref)).to.not.include(cid.toString());
|
|
32
|
+
await helia.blockstore.put(cid, input);
|
|
33
|
+
const pinned = await kubo.api.pin.add(cid);
|
|
34
|
+
expect(pinned.toString()).to.equal(cid.toString());
|
|
35
|
+
expect((await all(kubo.api.refs.local())).map(r => r.ref)).to.include(cid.toString());
|
|
36
|
+
});
|
|
37
|
+
it('pinning on helia should pull from kubo', async () => {
|
|
38
|
+
const input = Uint8Array.from([0, 1, 2, 3, 4]);
|
|
39
|
+
const { cid } = await kubo.api.add({ content: input }, {
|
|
40
|
+
cidVersion: 1,
|
|
41
|
+
rawLeaves: true
|
|
42
|
+
});
|
|
43
|
+
await expect(helia.blockstore.has(CID.parse(cid.toString()))).to.eventually.be.false();
|
|
44
|
+
await drain(helia.pins.add(CID.parse(cid.toString())));
|
|
45
|
+
await expect(helia.blockstore.has(CID.parse(cid.toString()))).to.eventually.be.true();
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
//# sourceMappingURL=helia-pins.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helia-pins.spec.js","sourceRoot":"","sources":["../../src/helia-pins.spec.ts"],"names":[],"mappings":"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"}
|
package/dist/src/index.d.ts
CHANGED
|
@@ -1,2 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @packageDocumentation
|
|
3
|
+
*
|
|
4
|
+
* Runs interop tests between Helia and Kubo.
|
|
5
|
+
*
|
|
6
|
+
* @example Testing a new Kubo release
|
|
7
|
+
*
|
|
8
|
+
* ```console
|
|
9
|
+
* $ npm i @helia/interop
|
|
10
|
+
* $ KUBO_BINARY=/path/to/kubo helia-interop
|
|
11
|
+
* ```
|
|
12
|
+
*/
|
|
1
13
|
export {};
|
|
2
14
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/src/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAA"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAEH,OAAO,EAAE,CAAA"}
|
package/dist/src/index.js
CHANGED
|
@@ -1,2 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @packageDocumentation
|
|
3
|
+
*
|
|
4
|
+
* Runs interop tests between Helia and Kubo.
|
|
5
|
+
*
|
|
6
|
+
* @example Testing a new Kubo release
|
|
7
|
+
*
|
|
8
|
+
* ```console
|
|
9
|
+
* $ npm i @helia/interop
|
|
10
|
+
* $ KUBO_BINARY=/path/to/kubo helia-interop
|
|
11
|
+
* ```
|
|
12
|
+
*/
|
|
1
13
|
export {};
|
|
2
14
|
//# sourceMappingURL=index.js.map
|
package/dist/src/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAA"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAEH,OAAO,EAAE,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ipns-http.spec.d.ts","sourceRoot":"","sources":["../../src/ipns-http.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/* eslint-env mocha */
|
|
2
|
+
import { ipns } from '@helia/ipns';
|
|
3
|
+
import { delegatedHTTPRouting } from '@helia/routers';
|
|
4
|
+
import { peerIdFromString } from '@libp2p/peer-id';
|
|
5
|
+
import { expect } from 'aegir/chai';
|
|
6
|
+
import { isNode } from 'wherearewe';
|
|
7
|
+
import { createHeliaHTTP } from './fixtures/create-helia-http.js';
|
|
8
|
+
import { createKuboNode } from './fixtures/create-kubo.js';
|
|
9
|
+
describe('@helia/ipns - http', () => {
|
|
10
|
+
let helia;
|
|
11
|
+
let kubo;
|
|
12
|
+
let name;
|
|
13
|
+
/**
|
|
14
|
+
* Ensure that for the CID we are going to publish, the resolver has a peer ID that
|
|
15
|
+
* is KAD-closer to the routing key so we can predict the the resolver will receive
|
|
16
|
+
* the DHT record containing the IPNS record
|
|
17
|
+
*/
|
|
18
|
+
beforeEach(async () => {
|
|
19
|
+
kubo = await createKuboNode();
|
|
20
|
+
helia = await createHeliaHTTP({
|
|
21
|
+
routers: [
|
|
22
|
+
delegatedHTTPRouting('http://127.0.0.1:8180')
|
|
23
|
+
]
|
|
24
|
+
});
|
|
25
|
+
name = ipns(helia);
|
|
26
|
+
});
|
|
27
|
+
afterEach(async () => {
|
|
28
|
+
if (helia != null) {
|
|
29
|
+
await helia.stop();
|
|
30
|
+
}
|
|
31
|
+
if (kubo != null) {
|
|
32
|
+
await kubo.stop();
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
it('should publish on kubo and resolve on helia', async function () {
|
|
36
|
+
if (!isNode) {
|
|
37
|
+
// https://github.com/protocol/bifrost-community/issues/4#issuecomment-1898417008
|
|
38
|
+
return this.skip();
|
|
39
|
+
}
|
|
40
|
+
const keyName = 'my-ipns-key';
|
|
41
|
+
const { cid } = await kubo.api.add(Uint8Array.from([0, 1, 2, 3, 4]));
|
|
42
|
+
await kubo.api.key.gen(keyName, {
|
|
43
|
+
// @ts-expect-error the types say upper-case E, Kubo errors unless it's a
|
|
44
|
+
// lower case e
|
|
45
|
+
type: 'ed25519'
|
|
46
|
+
});
|
|
47
|
+
const res = await kubo.api.name.publish(cid, {
|
|
48
|
+
key: keyName
|
|
49
|
+
});
|
|
50
|
+
const key = peerIdFromString(res.name);
|
|
51
|
+
const resolvedCid = await name.resolve(key);
|
|
52
|
+
expect(resolvedCid.toString()).to.equal(cid.toString());
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
//# sourceMappingURL=ipns-http.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ipns-http.spec.js","sourceRoot":"","sources":["../../src/ipns-http.spec.ts"],"names":[],"mappings":"AAAA,sBAAsB;AAEtB,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAClC,OAAO,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAA;AACrD,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAA;AAClD,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAA;AACnC,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAA;AACnC,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAA;AACjE,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAA;AAK1D,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,IAAI,KAAY,CAAA;IAChB,IAAI,IAAgB,CAAA;IACpB,IAAI,IAAU,CAAA;IAEd;;;;OAIG;IACH,UAAU,CAAC,KAAK,IAAI,EAAE;QACpB,IAAI,GAAG,MAAM,cAAc,EAAE,CAAA;QAC7B,KAAK,GAAG,MAAM,eAAe,CAAC;YAC5B,OAAO,EAAE;gBACP,oBAAoB,CAAC,uBAAuB,CAAC;aAC9C;SACF,CAAC,CAAA;QACF,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAA;IACpB,CAAC,CAAC,CAAA;IAEF,SAAS,CAAC,KAAK,IAAI,EAAE;QACnB,IAAI,KAAK,IAAI,IAAI,EAAE,CAAC;YAClB,MAAM,KAAK,CAAC,IAAI,EAAE,CAAA;QACpB,CAAC;QAED,IAAI,IAAI,IAAI,IAAI,EAAE,CAAC;YACjB,MAAM,IAAI,CAAC,IAAI,EAAE,CAAA;QACnB,CAAC;IACH,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,6CAA6C,EAAE,KAAK;QACrD,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,iFAAiF;YACjF,OAAO,IAAI,CAAC,IAAI,EAAE,CAAA;QACpB,CAAC;QAED,MAAM,OAAO,GAAG,aAAa,CAAA;QAC7B,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAA;QAEpE,MAAM,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,OAAO,EAAE;YAC9B,yEAAyE;YACzE,eAAe;YACf,IAAI,EAAE,SAAS;SAChB,CAAC,CAAA;QAEF,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE;YAC3C,GAAG,EAAE,OAAO;SACb,CAAC,CAAA;QAEF,MAAM,GAAG,GAAG,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;QAEtC,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAA;QAC3C,MAAM,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAA;IACzD,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ipns-pubsub.spec.d.ts","sourceRoot":"","sources":["../../src/ipns-pubsub.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
/* eslint-env mocha */
|
|
2
|
+
/* eslint max-nested-callbacks: ["error", 5] */
|
|
3
|
+
import { gossipsub } from '@chainsafe/libp2p-gossipsub';
|
|
4
|
+
import { ipns } from '@helia/ipns';
|
|
5
|
+
import { pubsub } from '@helia/ipns/routing';
|
|
6
|
+
import { peerIdFromKeys } from '@libp2p/peer-id';
|
|
7
|
+
import { expect } from 'aegir/chai';
|
|
8
|
+
import last from 'it-last';
|
|
9
|
+
import { base36 } from 'multiformats/bases/base36';
|
|
10
|
+
import { CID } from 'multiformats/cid';
|
|
11
|
+
import * as raw from 'multiformats/codecs/raw';
|
|
12
|
+
import { identity } from 'multiformats/hashes/identity';
|
|
13
|
+
import { sha256 } from 'multiformats/hashes/sha2';
|
|
14
|
+
import { concat as uint8ArrayConcat } from 'uint8arrays/concat';
|
|
15
|
+
import { fromString as uint8ArrayFromString } from 'uint8arrays/from-string';
|
|
16
|
+
import { toString as uint8ArrayToString } from 'uint8arrays/to-string';
|
|
17
|
+
import { connect } from './fixtures/connect.js';
|
|
18
|
+
import { createHeliaNode } from './fixtures/create-helia.js';
|
|
19
|
+
import { createKuboNode } from './fixtures/create-kubo.js';
|
|
20
|
+
import { keyTypes } from './fixtures/key-types.js';
|
|
21
|
+
import { waitFor } from './fixtures/wait-for.js';
|
|
22
|
+
const LIBP2P_KEY_CODEC = 0x72;
|
|
23
|
+
// skip RSA tests because we need the DHT enabled to find the public key
|
|
24
|
+
// component of the keypair, but that means we can't test pubsub
|
|
25
|
+
// resolution because Kubo will use the DHT as well
|
|
26
|
+
keyTypes.filter(keyType => keyType !== 'RSA').forEach(keyType => {
|
|
27
|
+
describe(`@helia/ipns - pubsub routing with ${keyType} keys`, () => {
|
|
28
|
+
let helia;
|
|
29
|
+
let kubo;
|
|
30
|
+
let name;
|
|
31
|
+
beforeEach(async () => {
|
|
32
|
+
helia = await createHeliaNode({
|
|
33
|
+
services: {
|
|
34
|
+
pubsub: gossipsub()
|
|
35
|
+
}
|
|
36
|
+
});
|
|
37
|
+
kubo = await createKuboNode();
|
|
38
|
+
// connect the two nodes
|
|
39
|
+
await connect(helia, kubo, '/meshsub/1.1.0');
|
|
40
|
+
name = ipns(helia, {
|
|
41
|
+
routers: [
|
|
42
|
+
pubsub(helia)
|
|
43
|
+
]
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
afterEach(async () => {
|
|
47
|
+
if (helia != null) {
|
|
48
|
+
await helia.stop();
|
|
49
|
+
}
|
|
50
|
+
if (kubo != null) {
|
|
51
|
+
await kubo.stop();
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
it('should publish on helia and resolve on kubo', async () => {
|
|
55
|
+
const input = Uint8Array.from([0, 1, 2, 3, 4]);
|
|
56
|
+
const digest = await sha256.digest(input);
|
|
57
|
+
const cid = CID.createV1(raw.code, digest);
|
|
58
|
+
const keyName = 'my-ipns-key';
|
|
59
|
+
await helia.libp2p.services.keychain.createKey(keyName, keyType);
|
|
60
|
+
const peerId = await helia.libp2p.services.keychain.exportPeerId(keyName);
|
|
61
|
+
if (peerId.publicKey == null) {
|
|
62
|
+
throw new Error('No public key present');
|
|
63
|
+
}
|
|
64
|
+
// first publish should fail because kubo isn't subscribed to key update channel
|
|
65
|
+
await expect(name.publish(peerId, cid)).to.eventually.be.rejected()
|
|
66
|
+
.with.property('message', 'PublishError.InsufficientPeers');
|
|
67
|
+
// should fail to resolve the first time as kubo was not subscribed to the pubsub channel
|
|
68
|
+
// @ts-expect-error kubo deps are out of date
|
|
69
|
+
await expect(last(kubo.api.name.resolve(peerId, {
|
|
70
|
+
timeout: 100
|
|
71
|
+
}))).to.eventually.be.undefined();
|
|
72
|
+
// magic pubsub subscription name
|
|
73
|
+
const subscriptionName = `/ipns/${CID.createV1(LIBP2P_KEY_CODEC, identity.digest(peerId.publicKey)).toString(base36)}`;
|
|
74
|
+
// wait for kubo to be subscribed to updates
|
|
75
|
+
await waitFor(async () => {
|
|
76
|
+
const subs = await kubo.api.name.pubsub.subs();
|
|
77
|
+
return subs.includes(subscriptionName);
|
|
78
|
+
}, {
|
|
79
|
+
timeout: 30000
|
|
80
|
+
});
|
|
81
|
+
// publish should now succeed
|
|
82
|
+
await name.publish(peerId, cid);
|
|
83
|
+
// kubo should now be able to resolve IPNS name
|
|
84
|
+
// @ts-expect-error kubo deps are out of date
|
|
85
|
+
const resolved = await last(kubo.api.name.resolve(peerId, {
|
|
86
|
+
timeout: 100
|
|
87
|
+
}));
|
|
88
|
+
expect(resolved).to.equal(`/ipfs/${cid.toString()}`);
|
|
89
|
+
});
|
|
90
|
+
it('should publish on kubo and resolve on helia', async function () {
|
|
91
|
+
if (keyType === 'secp256k1') {
|
|
92
|
+
// Kubo cannot generate secp256k1 keys
|
|
93
|
+
return this.skip();
|
|
94
|
+
}
|
|
95
|
+
const keyName = 'my-ipns-key';
|
|
96
|
+
const { cid } = await kubo.api.add(Uint8Array.from([0, 1, 2, 3, 4]));
|
|
97
|
+
const result = await kubo.api.key.gen(keyName, {
|
|
98
|
+
// @ts-expect-error kubo needs this in lower case
|
|
99
|
+
type: keyType.toLowerCase()
|
|
100
|
+
});
|
|
101
|
+
// the generated id is libp2p-key CID with the public key as an identity multihash
|
|
102
|
+
const peerCid = CID.parse(result.id, base36);
|
|
103
|
+
const peerId = await peerIdFromKeys(peerCid.multihash.digest);
|
|
104
|
+
// first call to pubsub resolver should fail but we should now be subscribed for updates
|
|
105
|
+
await expect(name.resolve(peerId)).to.eventually.be.rejected();
|
|
106
|
+
// actual pubsub subscription name
|
|
107
|
+
const subscriptionName = `/record/${uint8ArrayToString(uint8ArrayConcat([
|
|
108
|
+
uint8ArrayFromString('/ipns/'),
|
|
109
|
+
peerId.toBytes()
|
|
110
|
+
]), 'base64url')}`;
|
|
111
|
+
// wait for helia to be subscribed to the topic for record updates
|
|
112
|
+
await waitFor(async () => {
|
|
113
|
+
return helia.libp2p.services.pubsub.getTopics().includes(subscriptionName);
|
|
114
|
+
}, {
|
|
115
|
+
timeout: 30000,
|
|
116
|
+
message: 'Helia did not register for record updates'
|
|
117
|
+
});
|
|
118
|
+
// wait for kubo to see that helia is subscribed to the topic for record updates
|
|
119
|
+
await waitFor(async () => {
|
|
120
|
+
const peers = await kubo.api.pubsub.peers(subscriptionName);
|
|
121
|
+
return peers.map(p => p.toString()).includes(helia.libp2p.peerId.toString());
|
|
122
|
+
}, {
|
|
123
|
+
timeout: 30000,
|
|
124
|
+
message: 'Kubo did not see that Helia was registered for record updates'
|
|
125
|
+
});
|
|
126
|
+
// now publish, this should cause a pubsub message on the topic for record updates
|
|
127
|
+
await kubo.api.name.publish(cid, {
|
|
128
|
+
key: keyName
|
|
129
|
+
});
|
|
130
|
+
let resolvedCid;
|
|
131
|
+
// we should get an update eventually
|
|
132
|
+
await waitFor(async () => {
|
|
133
|
+
try {
|
|
134
|
+
resolvedCid = await name.resolve(peerId);
|
|
135
|
+
return true;
|
|
136
|
+
}
|
|
137
|
+
catch {
|
|
138
|
+
return false;
|
|
139
|
+
}
|
|
140
|
+
}, {
|
|
141
|
+
timeout: 10000,
|
|
142
|
+
message: 'Helia could not resolve the IPNS record'
|
|
143
|
+
});
|
|
144
|
+
if (resolvedCid == null) {
|
|
145
|
+
throw new Error('Failed to resolve CID');
|
|
146
|
+
}
|
|
147
|
+
expect(resolvedCid.toString()).to.equal(cid.toString());
|
|
148
|
+
});
|
|
149
|
+
});
|
|
150
|
+
});
|
|
151
|
+
//# sourceMappingURL=ipns-pubsub.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ipns-pubsub.spec.js","sourceRoot":"","sources":["../../src/ipns-pubsub.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ipns.spec.d.ts","sourceRoot":"","sources":["../../src/ipns.spec.ts"],"names":[],"mappings":""}
|