Mirror of Hyperboria peers repository.

Tim Akinbo 9694665251 removed defunct peer in Nigeria (#190) 9 月之前
af 9694665251 removed defunct peer in Nigeria (#190) 9 月之前
as 19de90c214 Revert "add peers in Singapore and Sydney (#148)" (#170) 5 年之前
eu 250f3a0afb update theswissbay.ch (#191) 9 月之前
na e97ad137bf Update kusoneko.moe.k (#182) 1 年之前
sa e7a31d7656 Add the first ever brazilian public cjdns peer (#162) 5 年之前
.gitignore fd95e35979 bump package.json because of readme 8 年之前
.travis.yml 74b19f6b99 Use new build system (followed old docs before) 9 年之前
README.md cf7a3c6d8c add testing to our PR procedure 6 年之前
index.js a0f73582b4 serialize pub location along with peering data 7 年之前
package.json 556a1b096a bump version 5 年之前
testAvailable.py b0545875f5 tool for ping nodes (#153) 5 年之前
tests.js c49d352f99 make peerName required in js 7 年之前
tests.py 20b2c044ba Make peerName a required field (#118) 7 年之前

README.md

Build Status

A geographically sorted list of public peering credentials for joining Hyperboria.

Hyperboria uses cjdns to construct an end-to-end-encrypted ipv6 mesh network. Connections between nodes are established manually, and traffic is restricted to the resulting social graph.

This repository exists for those who don't already know somebody on Hyperboria.

Using credentials

First, set up a cjdns node.

To connect your node to one of these public peers, follow the steps in the cjdns README.

Adding your public node's credentials

If you've created a public node, and would like to have it listed here, fork the repo, add a keyfile, run ./tests.py (make sure your file passes the test), and submit a PR.

We won't merge your credentials until our tests are passing.

Filepath conventions

Credentials are sorted geographically, by continent code. Nodes may be classified further, at the discretion of the node operator, and the administrators of the repository.

The suggested format is /continent/country/region/municipality. For example, /na/ca/ontario/toronto/.

Region and municipality codes are based on self identification, not any ISO standard. An operator might prefer to list their node in Cascadia instead of Washington state. For simplicity's sake, we'd prefer that new credentials conform to existing structures.

JSON formatting

We have tried to standardize the structure of the actual credential files, as such, they have the strictest requirements of anything in this repository.

  • Your credentials must be valid JSON.
  • They must contain the necessary fields:
    • ip/port
    • password
    • publicKey
    • contact (a means of contacting the operator)
  • The following fields are not yet required, but are recommended:
    • gpg, listing your 16 character pgp fingerprint (all caps, no spaces)
    • peerName, a human-readable name for the node
  • credentials should be formatted such that:
    • indentation uses four spaces
    • the file ends with a newline character.
  • credentials must use IP:port strings for keys
    • credentials using hostnames will not be accepted
  • If you are hosting it on a major server provider, please provide the name and shorthand for server.

    • On digitalocean, That may be digitalocean sfo2
    • On linode, that may be linode uswest or linode tokyo2
    • On AWS, use the region, followed by the city. Usable Server names are listed can be found on found on the AWS WEBSITE

    EX: useastnorthernvirginia,useastohio,southamericasaopaulo

    {
    "192.168.1.5:10326":{
        "contact":"alice@bob.com",
        "gpg":"FC00FC00FC00FC00",
        "login":"default-login",
        "password":"nq1uhmf06k8c5594jqmpgy26813b81s",
        "peerName":"your-name-goes-here",
        "publicKey":"ssxlh80x0bqjfrnbkm1801xsxyd8zd45jkwn1zhlnccqj4hdqun0.k"
    }
    }
    

Naming your entry

Credential files must end with .k. Otherwise, you can name your file whatever you want, but for simplicity's sake, avoid characters which will need to be escaped at the command line (or within the javascript api).

Javascript API

Peering credentials in this repository can be accessed via a simple Javascript API (using Nodejs).

It's available as a module on npm:

npm install hyperboria-peers

Usage

var Peers = require("hyperboria-peers");

/*  return a list of public peers located in North America */
Peers.filter(function (creds, path) {
    return path.indexOf('NA') !== -1;
});

/*  return a list of public keys */
Peers.map(function (creds, path) {
    return creds[Object.keys(creds)[0]].publicKey;
});

/*  the underlying data is exposed in a nested json structure */
console.log(Peers.peers);

console.log(Peers.peers.na.us.california);