@ndn/pyrepo
v0.0.20240630
Published
NDNts: ndn-python-repo client
Downloads
5
Readme
@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);