ndn-forwarder

0.0.18 • Public • Published

NDN-Forwarder

NDN-Forwarder is a javascript Named Data Networking forwarding daemon for node and the browser (via browserify). Whereas the principle NFD daemon is geared towards infrastructure routing and lends itself to deployment on a per-device basis, this project is aimed towards experimenting with ad-hoc overlay NDN networks for federated apps and services, with an API that lends itself to being included as a routing module within packaged and web applications. This forwarder is built upon NDN-js and uses NDN-tlv wire format.

In addition, while tcp and websocket connections are supported, the forwarder includes and prefers the javascript implimentation of telehash for it's encryption and NAT punching abilities.

Warning: Here Be Dragons

This module is in an early alpha stage of development, and while suitable for experimentation and prototyping, should not yet be used in production code. Pull requests and bug reports are welcome.

Initialization and API

Once initialized, the forwarder listens for managment commands in the "/localhost" namespace, using specially formatted interest messages to manage connections and FIB entries. For a programatic API, use ndn-io. For data storage and publishing, use level-ndn.

Example

var ndnInit = require("ndn-forwarder")
  , io = require("ndn")
  , repo = require("level-ndn")
  , IOoptions = {
    transport: 'websocket' // 'tcp' in node
    host: 'localhost'
    port: 6565 // 6464 for tcp
  }
  , namespace = "your/application/namespace"

function forwarderCallback(self){
  // self == telehash self object

  repo.tangle(namespace, null, null, repoTangleCallback)
  //the 'null' arguments here are for future versions where we allow for various transports to connect with the nfd

}

function repoTangleCallback(){
  repo.init(namespace, repoInitCallback, firstcb)
  //repoInitCallback = a callback executed every time the repo is initialized
  //firstcb = a callback executed the first time the repo is initialized on a machine, useful for importing/migrating data.
}

function repoInitCallback(){
  io.remoteTangle(IOoptions, appBegin)
}

function appBegin(){
  //your forwarder, repository, and io module are all ready to go!
}

ndnInit(forwarderCallback)

Readme

Keywords

Package Sidebar

Install

npm i ndn-forwarder

Weekly Downloads

18

Version

0.0.18

License

LGPL

Last publish

Collaborators

  • rynomad