2014-05-07 02:45:15 +00:00

34 lines
1.6 KiB
Markdown

# ZeroTier One Network Configuration Service Helper
This code will at the moment probably not be of much interest to end users.
It's a "service," which is a sub-process that ZeroTier One can execute that
provides additional functionaly not found in the core executable.
ZeroTier One communicates with services by sending and receiving string-serialized
Dictionary objects terminated by an empty line for each Dictionary.
The netconf service, written in node.js and making use of the zerotier-idtool
binary (see index.js) handles responding to virtual network config requests.
It only runs on netconf masters. It fetches its configuration information from
a Redis database.
The schama for that database is in redis-schema.txt. Some record types such
as users will not be of interest to outside people. Pay attention to the
network record type.
To install, copy the netconf-service folder to /var/lib/zerotier-one/services.d
(create services.d first). Then run "npm install" from the netconf-service
folder there and finally copy netconf.service to the parent services.d folder.
Make sure that shell script is executable. This is what the ZeroTier One
service will execute. It in turn sets up the node environment and runs index.js.
The utility zerotier-idtool must be present as /usr/local/bin/zerotier-idtool. This
is hard coded for the moment. To get it build ZeroTier One from source and then
"sudo cp zerotier-one /usr/local/bin/zerotier-idtool" (the binary determines its
personality from argv[0] on execution).
Note: Windows builds of ZeroTier One do not support services. This code has only
been tested on Linux but will probably work on Mac too.
*Adam Ierymenko @ ZeroTier*