Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@ndn/fw

Package Overview
Dependencies
Maintainers
1
Versions
10
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@ndn/fw - npm Package Compare versions

Comparing version 0.0.20200909 to 0.0.20210203

lib/tracer-output_browser.d.ts

11

lib/face_browser.js

@@ -0,7 +1,8 @@

import { __importDefault, __importStar } from "tslib";
import { Data, Interest, Nack } from "@ndn/packet";
import { toHex } from "@ndn/tlv";
import { EventEmitter } from "events";
import MultiSet from "mnemonist/multi-set";
import pDefer from "p-defer";
import Fifo from "p-fifo";
import _cjsDefaultImport0 from "mnemonist/multi-set.js"; const MultiSet = __importDefault(_cjsDefaultImport0).default;
import _cjsDefaultImport1 from "p-defer"; const pDefer = __importDefault(_cjsDefaultImport1).default;
import _cjsDefaultImport2 from "p-fifo"; const Fifo = __importDefault(_cjsDefaultImport2).default;
import { buffer, filter, pipeline, tap } from "streaming-iterables";

@@ -87,2 +88,6 @@ const STOP = Symbol("FaceImpl.Stop");

}
/** Determine if a route is present on the face. */
hasRoute(name) {
return this.routes.has(toHex(name.value));
}
/** Add a route toward the face. */

@@ -89,0 +94,0 @@ addRoute(name, announcement = true) {

@@ -1,11 +0,9 @@

import { createRequire } from "module";
const require = createRequire(import.meta.url);
const { __importDefault } = require("tslib");
import { __importDefault, __importStar } from "tslib";
import { Data, Interest, Nack } from "@ndn/packet";
import { toHex } from "@ndn/tlv";
import { EventEmitter } from "events";
const MultiSet = __importDefault(require("mnemonist/multi-set")).default;
const pDefer = __importDefault(require("p-defer")).default;
const Fifo = __importDefault(require("p-fifo")).default;
const { buffer, filter, pipeline, tap } = require("streaming-iterables");
import _cjsDefaultImport0 from "mnemonist/multi-set.js"; const MultiSet = __importDefault(_cjsDefaultImport0).default;
import _cjsDefaultImport1 from "p-defer"; const pDefer = __importDefault(_cjsDefaultImport1).default;
import _cjsDefaultImport2 from "p-fifo"; const Fifo = __importDefault(_cjsDefaultImport2).default;
import { buffer, filter, pipeline, tap } from "streaming-iterables";
const STOP = Symbol("FaceImpl.Stop");

@@ -90,2 +88,6 @@ function computeAnnouncement(name, announcement) {

}
/** Determine if a route is present on the face. */
hasRoute(name) {
return this.routes.has(toHex(name.value));
}
/** Add a route toward the face. */

@@ -92,0 +94,0 @@ addRoute(name, announcement = true) {

import { Name } from "@ndn/packet";
import TypedEmitter from "typed-emitter";
import type TypedEmitter from "typed-emitter";
import type { Forwarder, ForwarderImpl } from "./forwarder";

@@ -23,2 +23,4 @@ import type { FwPacket } from "./packet";

toString(): string;
/** Determine if a route is present on the face. */
hasRoute(name: Name): boolean;
/** Add a route toward the face. */

@@ -45,3 +47,3 @@ addRoute(name: Name, announcement?: FwFace.RouteAnnouncement): void;

/** A socket or network interface associated with forwarding plane. */
export interface FwFace extends Pick<FaceImpl, "attributes" | "close" | "toString" | "addRoute" | "removeRoute" | "addAnnouncement" | "removeAnnouncement" | Exclude<keyof TypedEmitter<Events>, "emit">> {
export interface FwFace extends Pick<FaceImpl, "attributes" | "close" | "toString" | "hasRoute" | "addRoute" | "removeRoute" | "addAnnouncement" | "removeAnnouncement" | Exclude<keyof TypedEmitter<Events>, "emit">> {
readonly fw: Forwarder;

@@ -48,0 +50,0 @@ readonly running: boolean;

@@ -1,4 +0,5 @@

import { toHex } from "@ndn/tlv";
import assert from "minimalistic-assert";
import DefaultMap from "mnemonist/default-map";
import { __importDefault, __importStar } from "tslib";
import { lpm } from "@ndn/packet";
import _cjsDefaultImport0 from "minimalistic-assert"; const assert = __importDefault(_cjsDefaultImport0).default;
import _cjsDefaultImport1 from "mnemonist/default-map.js"; const DefaultMap = __importDefault(_cjsDefaultImport1).default;
class FibEntry {

@@ -26,18 +27,8 @@ constructor() {

lpm(name) {
const prefixStrs = [""];
let s = "";
for (let i = 0; i < name.length; ++i) {
s += toHex(name.get(i).tlv);
prefixStrs.push(s);
const entry = lpm(name, (prefixHex) => this.table.peek(prefixHex));
if (entry) {
assert(entry.nexthops.size > 0);
}
for (let prefixLen = name.length; prefixLen >= 0; --prefixLen) {
const prefixStr = prefixStrs.pop();
const entry = this.table.peek(prefixStr);
if (entry) {
assert(entry.nexthops.size > 0);
return entry;
}
}
return undefined;
return entry;
}
}

@@ -1,7 +0,5 @@

import { createRequire } from "module";
const require = createRequire(import.meta.url);
const { __importDefault } = require("tslib");
import { toHex } from "@ndn/tlv";
const assert = __importDefault(require("minimalistic-assert")).default;
const DefaultMap = __importDefault(require("mnemonist/default-map")).default;
import { __importDefault, __importStar } from "tslib";
import { lpm } from "@ndn/packet";
import _cjsDefaultImport0 from "minimalistic-assert"; const assert = __importDefault(_cjsDefaultImport0).default;
import _cjsDefaultImport1 from "mnemonist/default-map.js"; const DefaultMap = __importDefault(_cjsDefaultImport1).default;
class FibEntry {

@@ -29,18 +27,8 @@ constructor() {

lpm(name) {
const prefixStrs = [""];
let s = "";
for (let i = 0; i < name.length; ++i) {
s += toHex(name.get(i).tlv);
prefixStrs.push(s);
const entry = lpm(name, (prefixHex) => this.table.peek(prefixHex));
if (entry) {
assert(entry.nexthops.size > 0);
}
for (let prefixLen = name.length; prefixLen >= 0; --prefixLen) {
const prefixStr = prefixStrs.pop();
const entry = this.table.peek(prefixStr);
if (entry) {
assert(entry.nexthops.size > 0);
return entry;
}
}
return undefined;
return entry;
}
}
import { Name } from "@ndn/packet";
import DefaultMap from "mnemonist/default-map";
import DefaultMap from "mnemonist/default-map.js";
import type { FaceImpl } from "./face";

@@ -4,0 +4,0 @@ declare class FibEntry {

import { Data, Interest, Nack, Name } from "@ndn/packet";
import TypedEmitter from "typed-emitter";
import type TypedEmitter from "typed-emitter";
import { FaceImpl, FwFace } from "./face";

@@ -4,0 +4,0 @@ import { Fib } from "./fib";

@@ -30,4 +30,4 @@ import type { Data, Interest, Nack } from "@ndn/packet";

constructor(l3: Interest, token?: unknown);
cancel: boolean;
readonly cancel = true;
}
export {};

@@ -0,5 +1,6 @@

import { __importDefault, __importStar } from "tslib";
import { Interest } from "@ndn/packet";
import { toHex } from "@ndn/tlv";
import hirestime from "hirestime";
import DefaultMap from "mnemonist/default-map";
import _cjsDefaultImport0 from "hirestime"; const hirestime = __importDefault(_cjsDefaultImport0).default;
import _cjsDefaultImport1 from "mnemonist/default-map.js"; const DefaultMap = __importDefault(_cjsDefaultImport1).default;
import { filter, flatMap, pipeline, reduce, tap } from "streaming-iterables";

@@ -50,4 +51,7 @@ import { FwPacket, RejectInterest } from "./packet_browser.js";

forwardInterest(face) {
const now = getNow();
this.interest.lifetime = this.lastExpire - now;
const lifetime = this.lastExpire - getNow();
if (lifetime <= 0) {
return;
}
this.interest.lifetime = lifetime;
face.send(FwPacket.create(this.interest, this.token));

@@ -113,6 +117,5 @@ }

insertEntry(entry) {
var _a;
this.byName.set(entry.key, entry);
if (!entry.token) {
entry.token = this.generateToken();
}
(_a = entry.token) !== null && _a !== void 0 ? _a : (entry.token = this.generateToken());
this.byToken.set(entry.token, entry);

@@ -137,6 +140,3 @@ }

async satisfy(face, { l3: data, token }) {
const nSentData = await pipeline(() => this.findPotentialMatches(data, token), filter(({ interest }) => data.canSatisfy(interest)), flatMap((entry) => entry.returnData(face)), tap(({ dn, token: dnToken }) => {
dn.send(FwPacket.create(data, dnToken));
// this Promise resolves when packet is sent, don't wait for it
}), reduce((count) => count + 1, 0));
const nSentData = await pipeline(() => this.findPotentialMatches(data, token), filter(({ interest }) => data.canSatisfy(interest)), flatMap((entry) => entry.returnData(face)), tap(({ dn, token: dnToken }) => dn.send(FwPacket.create(data, dnToken))), reduce((count) => count + 1, 0));
return nSentData > 0;

@@ -143,0 +143,0 @@ }

@@ -1,9 +0,7 @@

import { createRequire } from "module";
const require = createRequire(import.meta.url);
const { __importDefault } = require("tslib");
import { __importDefault, __importStar } from "tslib";
import { Interest } from "@ndn/packet";
import { toHex } from "@ndn/tlv";
const hirestime = __importDefault(require("hirestime")).default;
const DefaultMap = __importDefault(require("mnemonist/default-map")).default;
const { filter, flatMap, pipeline, reduce, tap } = require("streaming-iterables");
import _cjsDefaultImport0 from "hirestime"; const hirestime = __importDefault(_cjsDefaultImport0).default;
import _cjsDefaultImport1 from "mnemonist/default-map.js"; const DefaultMap = __importDefault(_cjsDefaultImport1).default;
import { filter, flatMap, pipeline, reduce, tap } from "streaming-iterables";
import { FwPacket, RejectInterest } from "./packet_node.js";

@@ -53,4 +51,7 @@ const getNow = hirestime();

forwardInterest(face) {
const now = getNow();
this.interest.lifetime = this.lastExpire - now;
const lifetime = this.lastExpire - getNow();
if (lifetime <= 0) {
return;
}
this.interest.lifetime = lifetime;
face.send(FwPacket.create(this.interest, this.token));

@@ -116,6 +117,5 @@ }

insertEntry(entry) {
var _a;
this.byName.set(entry.key, entry);
if (!entry.token) {
entry.token = this.generateToken();
}
(_a = entry.token) !== null && _a !== void 0 ? _a : (entry.token = this.generateToken());
this.byToken.set(entry.token, entry);

@@ -140,6 +140,3 @@ }

async satisfy(face, { l3: data, token }) {
const nSentData = await pipeline(() => this.findPotentialMatches(data, token), filter(({ interest }) => data.canSatisfy(interest)), flatMap((entry) => entry.returnData(face)), tap(({ dn, token: dnToken }) => {
dn.send(FwPacket.create(data, dnToken));
// this Promise resolves when packet is sent, don't wait for it
}), reduce((count) => count + 1, 0));
const nSentData = await pipeline(() => this.findPotentialMatches(data, token), filter(({ interest }) => data.canSatisfy(interest)), flatMap((entry) => entry.returnData(face)), tap(({ dn, token: dnToken }) => dn.send(FwPacket.create(data, dnToken))), reduce((count) => count + 1, 0));
return nSentData > 0;

@@ -146,0 +143,0 @@ }

/// <reference types="node" />
import { Data, Interest } from "@ndn/packet";
import DefaultMap from "mnemonist/default-map";
import DefaultMap from "mnemonist/default-map.js";
import type { FaceImpl } from "./face";

@@ -5,0 +5,0 @@ import { FwPacket } from "./packet";

@@ -0,6 +1,7 @@

import { __importDefault, __importStar } from "tslib";
import { Name } from "@ndn/packet";
import { fromHex } from "@ndn/tlv";
import pushable from "it-pushable";
import MultiMap from "mnemonist/multi-map";
import * as retry from "retry";
import _cjsDefaultImport0 from "it-pushable"; const pushable = __importDefault(_cjsDefaultImport0).default;
import _cjsDefaultImport1 from "mnemonist/multi-map.js"; const MultiMap = __importDefault(_cjsDefaultImport1).default;
import _cjsDefaultImport2 from "retry"; const retry = __importDefault(_cjsDefaultImport2).default;
/**

@@ -34,3 +35,3 @@ * Manage advertised prefix of the forwarder.

}
name = name !== null && name !== void 0 ? name : new Name(fromHex(nameHex));
name !== null && name !== void 0 ? name : (name = new Name(fromHex(nameHex)));
this.fw.emit("annrm", name);

@@ -37,0 +38,0 @@ for (const dest of this.destinations) {

@@ -1,9 +0,7 @@

import { createRequire } from "module";
const require = createRequire(import.meta.url);
const { __importDefault } = require("tslib");
import { __importDefault, __importStar } from "tslib";
import { Name } from "@ndn/packet";
import { fromHex } from "@ndn/tlv";
const pushable = __importDefault(require("it-pushable")).default;
const MultiMap = __importDefault(require("mnemonist/multi-map")).default;
const retry = __importDefault(require("retry")).default;
import _cjsDefaultImport0 from "it-pushable"; const pushable = __importDefault(_cjsDefaultImport0).default;
import _cjsDefaultImport1 from "mnemonist/multi-map.js"; const MultiMap = __importDefault(_cjsDefaultImport1).default;
import _cjsDefaultImport2 from "retry"; const retry = __importDefault(_cjsDefaultImport2).default;
/**

@@ -37,3 +35,3 @@ * Manage advertised prefix of the forwarder.

}
name = name !== null && name !== void 0 ? name : new Name(fromHex(nameHex));
name !== null && name !== void 0 ? name : (name = new Name(fromHex(nameHex)));
this.fw.emit("annrm", name);

@@ -40,0 +38,0 @@ for (const dest of this.destinations) {

import { Name } from "@ndn/packet";
import MultiMap from "mnemonist/multi-map";
import MultiMap from "mnemonist/multi-map.js";
import * as retry from "retry";

@@ -4,0 +4,0 @@ import type { FaceImpl } from "./face";

@@ -1,5 +0,6 @@

import pushable from "it-pushable";
import assert from "minimalistic-assert";
import DefaultWeakMap from "mnemonist/default-weak-map";
import MultiMap from "mnemonist/multi-map";
import { __importDefault, __importStar } from "tslib";
import _cjsDefaultImport0 from "it-pushable"; const pushable = __importDefault(_cjsDefaultImport0).default;
import _cjsDefaultImport1 from "minimalistic-assert"; const assert = __importDefault(_cjsDefaultImport1).default;
import _cjsDefaultImport2 from "mnemonist/default-weak-map.js"; const DefaultWeakMap = __importDefault(_cjsDefaultImport2).default;
import _cjsDefaultImport3 from "mnemonist/multi-map.js"; const MultiMap = __importDefault(_cjsDefaultImport3).default;
import { Forwarder } from "./forwarder_browser.js";

@@ -6,0 +7,0 @@ class TapRxController {

@@ -1,8 +0,6 @@

import { createRequire } from "module";
const require = createRequire(import.meta.url);
const { __importDefault } = require("tslib");
const pushable = __importDefault(require("it-pushable")).default;
const assert = __importDefault(require("minimalistic-assert")).default;
const DefaultWeakMap = __importDefault(require("mnemonist/default-weak-map")).default;
const MultiMap = __importDefault(require("mnemonist/multi-map")).default;
import { __importDefault, __importStar } from "tslib";
import _cjsDefaultImport0 from "it-pushable"; const pushable = __importDefault(_cjsDefaultImport0).default;
import _cjsDefaultImport1 from "minimalistic-assert"; const assert = __importDefault(_cjsDefaultImport1).default;
import _cjsDefaultImport2 from "mnemonist/default-weak-map.js"; const DefaultWeakMap = __importDefault(_cjsDefaultImport2).default;
import _cjsDefaultImport3 from "mnemonist/multi-map.js"; const MultiMap = __importDefault(_cjsDefaultImport3).default;
import { Forwarder } from "./forwarder_node.js";

@@ -9,0 +7,0 @@ class TapRxController {

import { Data, Interest, Nack } from "@ndn/packet";
import log from "loglevel";
import { Forwarder } from "./forwarder_browser.js";
export const logger = log.getLogger("@ndn/fw");
logger.setLevel(log.levels.TRACE);
import { makeTracerOutput } from "./tracer-output_browser.js";
/** Print trace logs from Forwarder events. */
export class Tracer {
constructor(opts) {
var _a;
constructor({ output = makeTracerOutput(), fw = Forwarder.getDefault(), face = true, prefix = true, ann = true, pkt = true, }) {
this.faceadd = (face) => {
logger.debug(`+Face ${face}`);
this.output.log(`+Face ${face}`);
};
this.facerm = (face) => {
logger.debug(`-Face ${face}`);
this.output.log(`-Face ${face}`);
};
this.prefixadd = (face, prefix) => {
logger.debug(`${face} +Prefix ${prefix}`);
this.output.log(`${face} +Prefix ${prefix}`);
};
this.prefixrm = (face, prefix) => {
logger.debug(`${face} -Prefix ${prefix}`);
this.output.log(`${face} -Prefix ${prefix}`);
};
this.annadd = (name) => {
logger.debug(`+Announcement ${name}`);
this.output.log(`+Announcement ${name}`);
};
this.annrm = (name) => {
logger.debug(`-Announcement ${name}`);
this.output.log(`-Announcement ${name}`);
};

@@ -33,5 +31,6 @@ this.pktrx = (face, pkt) => {

};
this.fw = (_a = opts.fw) !== null && _a !== void 0 ? _a : Forwarder.getDefault();
this.output = output;
this.fw = fw;
/* istanbul ignore else */
if (opts.face !== false) {
if (face) {
this.fw.on("faceadd", this.faceadd);

@@ -41,3 +40,3 @@ this.fw.on("facerm", this.facerm);

/* istanbul ignore else */
if (opts.prefix !== false) {
if (prefix) {
this.fw.on("prefixadd", this.prefixadd);

@@ -47,3 +46,3 @@ this.fw.on("prefixrm", this.prefixrm);

/* istanbul ignore else */
if (opts.ann !== false) {
if (ann) {
this.fw.on("annadd", this.annadd);

@@ -53,3 +52,3 @@ this.fw.on("annrm", this.annrm);

/* istanbul ignore else */
if (opts.pkt !== false) {
if (pkt) {
this.fw.on("pktrx", this.pktrx);

@@ -78,3 +77,3 @@ this.fw.on("pkttx", this.pkttx);

"I";
logger.debug(`${face} ${dir}${act} ${interestToString(pkt.l3)}`);
this.output.log(`${face} ${dir}${act} ${interestToString(pkt.l3)}`);
break;

@@ -84,3 +83,3 @@ }

const { name } = pkt.l3;
logger.debug(`${face} ${dir}D ${name}`);
this.output.log(`${face} ${dir}D ${name}`);
break;

@@ -90,3 +89,3 @@ }

const { interest, reason } = pkt.l3;
logger.debug(`${face} ${dir}N ${interestToString(interest)}~${reason}`);
this.output.log(`${face} ${dir}N ${interestToString(interest)}~${reason}`);
break;

@@ -100,4 +99,1 @@ }

}
(function (Tracer) {
Tracer.internalLogger = logger;
})(Tracer || (Tracer = {}));

@@ -1,29 +0,24 @@

import { createRequire } from "module";
const require = createRequire(import.meta.url);
const { __importDefault } = require("tslib");
import { Data, Interest, Nack } from "@ndn/packet";
const log = __importDefault(require("loglevel")).default;
import { Forwarder } from "./forwarder_node.js";
export const logger = log.getLogger("@ndn/fw");
logger.setLevel(log.levels.TRACE);
import { makeTracerOutput } from "./tracer-output_node.js";
/** Print trace logs from Forwarder events. */
export class Tracer {
constructor(opts) {
var _a;
constructor({ output = makeTracerOutput(), fw = Forwarder.getDefault(), face = true, prefix = true, ann = true, pkt = true, }) {
this.faceadd = (face) => {
logger.debug(`+Face ${face}`);
this.output.log(`+Face ${face}`);
};
this.facerm = (face) => {
logger.debug(`-Face ${face}`);
this.output.log(`-Face ${face}`);
};
this.prefixadd = (face, prefix) => {
logger.debug(`${face} +Prefix ${prefix}`);
this.output.log(`${face} +Prefix ${prefix}`);
};
this.prefixrm = (face, prefix) => {
logger.debug(`${face} -Prefix ${prefix}`);
this.output.log(`${face} -Prefix ${prefix}`);
};
this.annadd = (name) => {
logger.debug(`+Announcement ${name}`);
this.output.log(`+Announcement ${name}`);
};
this.annrm = (name) => {
logger.debug(`-Announcement ${name}`);
this.output.log(`-Announcement ${name}`);
};

@@ -36,5 +31,6 @@ this.pktrx = (face, pkt) => {

};
this.fw = (_a = opts.fw) !== null && _a !== void 0 ? _a : Forwarder.getDefault();
this.output = output;
this.fw = fw;
/* istanbul ignore else */
if (opts.face !== false) {
if (face) {
this.fw.on("faceadd", this.faceadd);

@@ -44,3 +40,3 @@ this.fw.on("facerm", this.facerm);

/* istanbul ignore else */
if (opts.prefix !== false) {
if (prefix) {
this.fw.on("prefixadd", this.prefixadd);

@@ -50,3 +46,3 @@ this.fw.on("prefixrm", this.prefixrm);

/* istanbul ignore else */
if (opts.ann !== false) {
if (ann) {
this.fw.on("annadd", this.annadd);

@@ -56,3 +52,3 @@ this.fw.on("annrm", this.annrm);

/* istanbul ignore else */
if (opts.pkt !== false) {
if (pkt) {
this.fw.on("pktrx", this.pktrx);

@@ -81,3 +77,3 @@ this.fw.on("pkttx", this.pkttx);

"I";
logger.debug(`${face} ${dir}${act} ${interestToString(pkt.l3)}`);
this.output.log(`${face} ${dir}${act} ${interestToString(pkt.l3)}`);
break;

@@ -87,3 +83,3 @@ }

const { name } = pkt.l3;
logger.debug(`${face} ${dir}D ${name}`);
this.output.log(`${face} ${dir}D ${name}`);
break;

@@ -93,3 +89,3 @@ }

const { interest, reason } = pkt.l3;
logger.debug(`${face} ${dir}N ${interestToString(interest)}~${reason}`);
this.output.log(`${face} ${dir}N ${interestToString(interest)}~${reason}`);
break;

@@ -103,4 +99,1 @@ }

}
(function (Tracer) {
Tracer.internalLogger = logger;
})(Tracer || (Tracer = {}));

@@ -1,15 +0,8 @@

import log from "loglevel";
import { Forwarder } from "./forwarder";
export declare const logger: log.Logger;
interface Options {
fw?: Forwarder;
face?: boolean;
prefix?: boolean;
ann?: boolean;
pkt?: boolean;
}
/** Print trace logs from Forwarder events. */
export declare class Tracer {
static enable(opts?: Options): Tracer;
static enable(opts?: Tracer.Options): Tracer;
private readonly output;
private readonly fw;
constructor(opts: Options);
constructor({ output, fw, face, prefix, ann, pkt, }: Tracer.Options);
disable(): void;

@@ -27,4 +20,37 @@ private faceadd;

export declare namespace Tracer {
const internalLogger: log.Logger;
interface Output {
log(str: string): void;
}
interface Options {
/**
* Where to write log entries.
* Default is stderr in Node and developer console in browser.
*/
output?: Output;
/**
* Logical Forwarder instance.
* @default Forwarder.getDefault()
*/
fw?: Forwarder;
/**
* Whether to log face creations and deletions.
* @default true
*/
face?: boolean;
/**
* Whether to log prefix registrations.
* @default true
*/
prefix?: boolean;
/**
* Whether to log prefix announcements.
* @default true
*/
ann?: boolean;
/**
* Whether to log packets.
* @default true
*/
pkt?: boolean;
}
}
export {};
{
"name": "@ndn/fw",
"version": "0.0.20200909",
"version": "0.0.20210203",
"description": "NDNts: Forwarding Plane",

@@ -26,17 +26,16 @@ "keywords": [

"@types/retry": "^0.12.0",
"@ndn/packet": "0.0.20200909",
"@ndn/tlv": "0.0.20200909",
"@ndn/packet": "0.0.20210203",
"@ndn/tlv": "0.0.20210203",
"hirestime": "^6.1.0",
"it-pushable": "^1.4.0",
"loglevel": "^1.7.0",
"it-pushable": "1.4.0",
"minimalistic-assert": "^1.0.1",
"mnemonist": "^0.38.0",
"mnemonist": "^0.38.1",
"p-defer": "^3.0.0",
"p-fifo": "^1.0.0",
"retry": "^0.12.0",
"streaming-iterables": "^5.0.2",
"tslib": "^2.0.1",
"typed-emitter": "^1.3.0"
"streaming-iterables": "^5.0.4",
"tslib": "^2.1.0",
"typed-emitter": "^1.3.1"
},
"types": "lib/mod.d.ts"
}
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc