NetJSON

From Guifi - Media-pool Common Repository

Revision as of 05:42, 12 May 2015 by Al (Talk | contribs)

NetJSON: data interchange format for networks

Netjson-logo.png

NetJSON is a data interchange format for encoding the basic building blocks of networking:

Reach us on the Mailing List - Consult the ML Archives

Goals

Define simple JSON data structures that contain the lowest common denominator of:

  • network device configurations
  • monitoring data extracted from devices
  • routes of a routing protocol

The resulting JSON structures should follow these general principles:

  • KISS: keep it simple, proceed one step at time
  • Principle of least astonishment: use accepted terminology
  • Explicit names: prefer verbose explicit names, eg: "operating_system" is better than "os"

Once we get to a first version, we should implement these formats in software like:

  • Firwmares and linux modules
  • Routing protocols
  • Monitoring agents
  • Node databases
  • Monitoring tools

Motivations

Developing software that deals with networks is harder than it should.

Developers have to take into account all the differences between vendors, operating systems, routing protocols, hardware and (when working with community networks) with the different approaches of each community.

Very often, each vendor develops an entire stack that works exclusively with its own hardware and software.

There exist many libraries and web apps for networking, but it is very hard to make them interoperable, that is, making them talk and understand one another with minimum effort.

Instead of creating an ecosystem, we have been creating silos that hardly talk to each other.

This is an attempt to invert this trend, following the successful example of the GeoJSON open standard.

By defining common data structures we can allow developers to focus on their goals instead of having to struggle with the differences of each vendor, firmware, routing protocol or community.

Moreover, we will lay the groundwork for an ecosystem to grow organically: once the standard JSON structures are defined and adopted it will be easier to write systems that work together, instead of creating silos.

Definitions

  • JavaScript Object Notation (JSON), and the terms object, name, value, array, and number, are defined in IETF RTC 4627.
  • The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in IETF RFC 2119.

Network Device Configuration

Definition: configuration and properties of a network device.

Example: device-configuration.json

A Network Device Configuration object must have a member with the name type and value DeviceConfiguration.

The object should be composed of the following members:

  • general
  • hardware
  • operating_system
  • resources
  • interfaces
  • physical_devices
  • routing
  • dns_servers
  • dns_search

All the values of each member must be objects which further describe each component of a network device.

Each object will be described more in detail in the future iterations of this project.

Software providing this JSON format to should return all the information it is able to access from the system, according to security and privacy rules defined by the device owner or network administrator.

Software consuming this JSON format must be able to handle missing attributes.

Software consuming this JSON format must ignore unrecognized attributes.

Device Monitoring Data

Definition: information that indicates the behaviour of a device that changes over time.

Example: monitoring-data.json

A Device Monitoring object must have a member with the name type and value DeviceMonitoring.

The object should be composed of the following members:

  • general
  • interfaces
  • resources

Each object will be described more in detail in the future iterations of this project.

Network Routes

Definition: a list of routes of a dynamic routing protocol or statically configured on the device. May be contained in a DeviceConfiguration object.

Example: network-routes.json

A Network Routes object must have a member with the name type and value NetworkRoutes.

It must define the following members:

  • protocol: the name of the routing protocol, can be static when representing static routes
  • version: the version of the routing protocol, can be null when representing static routes
  • metric: a string which indicates the name of main routing metric used by the routing protocol to determine the best routes when sending packets, can be null when representing static routes

It may also define the following optional members:

  • revision: the revision from which the routing protocol binary was built (eg: git hash, svn revision)
  • router_id: ID of the router on which the protocol is running

When contained in a DeviceConfiguration, a Network Routes object indicates either that a routing protocol is running on the device or that static routes have been set; in this case the member routes is required only for static routes.

When self contained, a NetworkRoutes object represents a routing table and must define a routes member, which contains a list of route objects.

Each route object must define the following members:

  • destination: a string indicating the ip address, prefix or mac address that will be matched to the destination of the traffic
  • next: a string indicating the ip address, prefix or mac address of the next hop
  • device: a string indicating the interface the traffic will be going to, it can be omitted when representing static routes
  • cost: the numeric value of the routing metric; lower cost is better, it can be omitted when representing static routes

A route object may also define a source member indicating the source (necessary for source-specific routing).

Network Graph

Definition: a list of nodes and links that represent the topology of a network.

Example: network-graph.json

A Network Graph object must have a member with the name type and value NetworkGraph.

It must define the following members:

  • protocol: the name of the routing protocol, can be static when representing static routes
  • version: the version of the routing protocol, can be null when representing static routes
  • metric: a string which indicates the name of main routing metric used by the routing protocol to determine the best routes when sending packets, can be null when representing static routes
  • nodes: a list of nodes
  • links: a list of links

It may also define the following optional members:

  • revision: the revision from which the routing protocol binary was built (eg: git hash, svn revision)
  • router_id: ID of the router on which the protocol is running

Each node object must define an id member and may define the following optional members:

  • label: a label for the node
  • properties: an object to store additional / custom metadata

Each link object must define the following members:

  • source: id of the target node
  • target: id of the source node
  • weight: metric value for the link

Each link object may also define a properties object to store additional / custom metadata.

FAQs

Frequentedly Asked Questions.

Is this some kind of new SNMP?

Not exactly. Think about NetJSON as a possible common language that libraries and applications can adopt in order to interoperate on different levels.

NetJSON does not aim to define how the data is exchanged, it could be exposed via an HTTP API, it could be sent through UDP packets, it could be copied from application A and pasted into application B.

Personal tools