|
// Example of direct connect of 2 helia noeds between browser and nodejs |
|
// resolve cid from browser to nodejs, then resolve other cid from nodejs to browser |
|
import {CID} from "multiformats/cid"; |
|
import {unixfs} from "@helia/unixfs"; |
|
|
|
import {chromium} from "playwright"; |
|
import {createServer} from "http-server"; |
|
|
|
import {createNode} from "./nodejs.js"; |
|
|
|
// [1. nodejs helia node] |
|
const node = await createNode(); |
|
console.log("[peerId on nodejs]", `${node.libp2p.peerId}`); |
|
|
|
// [2. http server for url to playwright] |
|
const httpServer = createServer(); |
|
await new Promise(f => httpServer.server.listen(f)); |
|
const pageUrl = `http://localhost:${httpServer.server.address().port}/index.html`; // importmap only html |
|
console.log("[page server url]", pageUrl); |
|
|
|
// [3. helia node on playwright] |
|
const browser = await chromium.launch(); |
|
const page1 = await browser.newPage(); |
|
await page1.goto(pageUrl); |
|
page1.on("console", msg => { |
|
if (msg.type() === "log") console.log(msg.location(), msg.text()); |
|
//if (msg.type() === "error") console.log(msg.location(), msg.text()); |
|
}); |
|
const cidStr = await page1.evaluate(({multiaddrs}) => (async () => { |
|
const {createHeliaFromMultiaddrs} = await import("./browser.js"); |
|
|
|
globalThis.ctx = await createHeliaFromMultiaddrs(multiaddrs); |
|
console.log("[peerId on browser]", `${ctx.node.libp2p.peerId}`); |
|
|
|
// [4. serve content on browser helia node] |
|
const cid = await ctx.nodefs.addBytes(new TextEncoder().encode("Hello from browser")); |
|
try {ctx.node.pins.add(cid);} catch (error) {} |
|
return `${cid}`; |
|
})(), {multiaddrs: node.libp2p.getMultiaddrs().map(ma => `${ma}`)}); |
|
console.log("[serving cid on browser]", cidStr); |
|
|
|
|
|
const nodefs = unixfs(node); |
|
// [5. resolve cid from nodejs to browser] |
|
{ |
|
const cid = CID.parse(cidStr); |
|
const stat = await nodefs.stat(cid); |
|
console.log("[stat of cid from browser]", stat); |
|
const decoder = new TextDecoder(); |
|
const texts = []; |
|
for await (const chunk of nodefs.cat(cid)) { |
|
texts.push(decoder.decode(chunk, {stream: true})); |
|
} |
|
console.log("[text of cid from browser]", texts.join("")); |
|
|
|
// print findProviders on nodejs |
|
if (1) for await (const peer of node.libp2p.contentRouting.findProviders(cid)) { |
|
console.log("[peer.id]", `${peer.id}`); |
|
console.log("[peer.multiaddrs.length]", peer.multiaddrs.length); |
|
for (const ma of peer.multiaddrs) console.log("[peer.multiaddrs]", `${ma}`); |
|
console.log("[peer.protocolss.length]", peer.protocols.length); |
|
for (const proto of peer.protocols) console.log("[peer.protocols]", `${proto}`); |
|
break; |
|
} |
|
} |
|
|
|
// [6. serve content on nodejs helia node] |
|
const cid = await nodefs.addBytes(new TextEncoder().encode("Hello from nodejs")); |
|
try {node.pins.add(cid);} catch (error) {} |
|
console.log("[served from browser]") |
|
|
|
// [7. access cid from browser to nodejs] |
|
await page1.evaluate(({cidStr}) => (async () => { |
|
const cid = ctx.CID.parse(cidStr); |
|
// print result of findProviders(cid) |
|
for await (const peer of ctx.node.libp2p.contentRouting.findProviders(cid)) { |
|
console.log("[peer.id]", `${peer.id}`); |
|
console.log("[peer.multiaddrs.length]", peer.multiaddrs.length); |
|
for (const ma of peer.multiaddrs) console.log("[peer.multiaddrs]", `${ma}`); |
|
console.log("[peer.protocolss.length]", peer.protocols.length); |
|
for (const proto of peer.protocols) console.log("[peer.protocols]", `${proto}`); |
|
break; |
|
} |
|
|
|
const stat = await ctx.nodefs.stat(cid); // halt |
|
console.log("[stat of cid from nodejs]", stat); |
|
const decoder = new TextDecoder(); |
|
const texts = []; |
|
for await (const chunk of ctx.nodefs.cat(cid)) { |
|
texts.push(decoder.decode(chunk, {stream: true})); |
|
} |
|
console.log("[text of cid from nodejs]", texts.join("")); |
|
|
|
// print findProviders on browser |
|
if (1) for await (const peer of ctx.node.libp2p.contentRouting.findProviders(cid)) { |
|
console.log("[peer.id]", `${peer.id}`); |
|
console.log("[peer.multiaddrs.length]", peer.multiaddrs.length); |
|
for (const ma of peer.multiaddrs) console.log("[peer.multiaddrs]", `${ma}`); |
|
console.log("[peer.protocolss.length]", peer.protocols.length); |
|
for (const proto of peer.protocols) console.log("[peer.protocols]", `${proto}`); |
|
break; |
|
} |
|
|
|
})(), {cidStr: `${cid}`}); |
|
|
|
// [8. closing] |
|
console.log("[closing...]"); |
|
await page1.evaluate(() => ctx.node.stop()); |
|
await browser.close(); |
|
await new Promise(f => httpServer.server.close(f)); |
|
await node.stop(); |