Module @ndn/pyrepo

@ndn/pyrepo

This package is part of NDNts, Named Data Networking libraries for the modern web.

This package allows inserting and deleting Data in ndn-python-repo. This implementation is compatible with ndn-python-repo 2dcd229a (2024-05-09). To install and start the specified version, run:

# create Python virtual environment
python3 -m venv ~/pyrepo.venv
source ~/pyrepo.venv/bin/activate

# install ndn-python-repo
pip install git+https://github.com/UCLA-IRL/ndn-python-repo@2dcd229a4cb81927a52e8a8f1d963c55ee939ffa

# run ndn-python-repo
ndn-python-repo

PyRepoClient type is a client for ndn-python-repo protocol. PyRepoStore type implements a write-only subset of DataStore interfaces as defined in @ndn/repo-api package.

import { PyRepoStore } from "@ndn/pyrepo";

import { Forwarder } from "@ndn/fw";
import { L3Face } from "@ndn/l3face";
import { enableNfdPrefixReg } from "@ndn/nfdmgmt";
import { UnixTransport } from "@ndn/node-transport";
import { Data, digestSigning, Name } from "@ndn/packet";
import { Closer } from "@ndn/util";

const repoPrefix = process.env.DEMO_PYREPO_PREFIX;
if (!repoPrefix) {
console.log(`
To run @ndn/pyrepo demo, set the following environment variables:
DEMO_PYREPO_PREFIX= command prefix of ndn-python-repo
`);
process.exit(0);
}
const dataPrefix = new Name(`/NDNts-pyrepo/${Math.trunc(Math.random() * 1e8)}`);

const face = await UnixTransport.createFace({}, process.env.DEMO_NFD_UNIX ?? "/run/nfd/nfd.sock");
await using faceDispose = Closer.asAsyncDisposable(face);
enableNfdPrefixReg(face);

await using store = new PyRepoStore({
repoPrefix: new Name(repoPrefix),
});

const packets = await Promise.all(Array.from({ length: 100 }, async (v, i) => {
const data = new Data(dataPrefix.append(`${i}`));
await digestSigning.sign(data);
return data;
}));
console.log(`Inserting ${packets.length} packets under ${dataPrefix} in ${repoPrefix}`);
await store.insert(...packets);

const names = packets.filter((v, i) => i % 3 === 0).map(({ name }) => name);
console.log(`Deleting ${names.length} packets under ${dataPrefix} in ${repoPrefix}`);
await store.delete(...names);

Namespaces

PrpsPublisher
PrpsSubscriber
PyRepoClient
PyRepoStore

Classes

PrpsPublisher
PrpsSubscriber
PyRepoClient
PyRepoStore