nimona.io

module
v0.10.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jun 19, 2020 License: MIT

README

nimona

a new internet stack; or something like it.

Actions Status GitHub last commit GitHub issues GitHub pull requests License Status


WARNING: Nimona is still in its very early stages of design and development and will stay like this for a while.
Documentation is currently non existent but should start slowly popping up as the various design decisions mature.


Nimona

Nimona’s main goal is to provide a number of layers/components to help with the challenges presented when dealing with decentralized and peer to peer applications.

Development

Requirements
  • Go 1.13+ with modules enabled
  • Make
Getting Started
git clone https://github.com/nimona/go-nimona.git go-nimona
cd go-nimona
make deps
Process / Workflow

Nimona is developed using Git Common-Flow, which is essentially GitHub Flow with the addition of versioned releases, and optional release branches.

In addition to the Common-Flow spec, contributors are also highly encouraged to sign commits.

Library Architecture

Library Architecture

Network

Package net provides access to the basic nimona networking primitives allowing peers to connect to each other and perform negotiate their identities, certificates, and capabilities (via handshake).

A valid peer.Peer is required that includes both a public key, and one or more network addresses.

Currently the only supported protocol for peer communication is TCP over TLS. Such addresses are prefixed with tcps: followed by an ip address and port.

Network keeps a blacklist that will exponentially back-off attempts to dial unresponsive addresses.

Upon successful connection and handshake, the resulting net.Connection will hold the remote peer's keys, certificates, and capabilities.

    type Network interface {
        Dial(ctx context.Context, peer *peer.Peer) (*Connection, error)
        Listen(ctx context.Context, bindAddress string) (Listener, error)
        Accept() (*Connection, error)
        Addresses() []string
  }
Connection Manager

Package connmanager wraps net.Network in order to cache open connections when a peer with an open connection is being re-dialed.

type Network interface {
    Dial(ctx context.Context, peer *peer.Peer) (*Connection, error)
}
Exchange

Package exchange is responsible to sending and receiving objects to from peers.

It is also responsible for relaying objects when a peer is not directly accessible.

type Exchange interface {
    Send(ctx context.Context, object object.Object, p *peer.Peer) error
    Subscribe(filters ...EnvelopeFilter) EnvelopeSubscription
}
Resolver

Package resolver is responsible for looking up peers on the network that fulfill specific requirements.

type Resolver interface {
  Lookup(ctx context.Context, opts ...LookupOption) (<-chan *peer.Peer, error)
}

The currently available LookupOption are the following, and can be used on their own or in groups.

func LookupByContentHash(hash object.Hash) LookupOption { ... }
func LookupByContentType(contentType string) LookupOption { ... }
func LookupByIdentity(key crypto.PublicKey) LookupOption { ... }
func LookupByCertificateSigner(key crypto.PublicKey) LookupOption { ... }
Orchestrator

Package orchestrator deals with creating, updating, getting, and synchronizing streams.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL