You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Joseph Henry 91eb869e02 Upgraded lwIP to 2.0.3 9 years ago
artwork README updates, misc filename changes, debug trace fixes, introduction of libzt moniker 9 years ago
docs significant upgrade to selftest, added echotest, better checks for data in queue before socket closure 9 years ago
examples Added basic DNS functionality, fixed stack smashing bug, organizational improvements 9 years ago
ext Upgraded lwIP to 2.0.3 9 years ago
include Added TCP_DEBUG_TMR to lessen lwIP debug trace clutter 9 years ago
obj .gitignore for obj/ 9 years ago
src Added multithreaded unit tests to selftest, standardization pass: conditional statement spacing 9 years ago
test Minor tweaks to Makefile for ZeroTier::Utils in selftest, make-liblwip.mk for warning suppression 9 years ago
zto@59b7cbb591 Renamed SocketTap to VirtualTap and Connection to VirtualSocket to prevent confusion 9 years ago
.gitignore Managed Routes now supported, with automatic add/remove 9 years ago
.gitmodules Added ZeroTierOne as a submodule 9 years ago
BUILDING.md Slight reorganization of docs 9 years ago
FAQ.md Added differentiation of LIBZT_DEBUG and NS_DEBUG flags, other minor tweaks 9 years ago
Jenkinsfile Parallelized Jenkinsfile 9 years ago
Makefile Minor tweaks to Makefile for ZeroTier::Utils in selftest, make-liblwip.mk for warning suppression 9 years ago
README.md Added differentiation of LIBZT_DEBUG and NS_DEBUG flags, other minor tweaks 9 years ago
RELEASE-NOTES.md Updated release notes, lwip architecture port files 9 years ago
TESTING.md Minor changes to selftest, updated TESTING readme, removed old test personality conf files 9 years ago
check.sh dynamic loading of network stack no longer needed 9 years ago
make-liblwip.mk Minor tweaks to Makefile for ZeroTier::Utils in selftest, make-liblwip.mk for warning suppression 9 years ago

README.md

libzt

Embed ZeroTier directly into your app


A library version of the popular ZeroTier One, libzt makes it easy to securely connect devices, servers, cloud VMs, containers, and apps everywhere and manage them at scale. Now you can bake this ability directly into your app or service using your preferred language or framework. We provide a BSD socket-like API supporting SOCK_STREAM, SOCK_DGRAM, and SOCK_RAW to make the integration simple. There's also no longer any need for system-wide virtual interfaces. This connection is exclusive to your app and fully encrypted via the Salsa20 cipher.


irc

Pre-Built Binaries Here: zerotier.com/download.shtml.


Example

#include "libzt.h"

char *str = "welcome to the machine";
char *nwid = "c7cd7c9e1b0f52a2";      // network to join
char *path = "zt1";                   // path where this node's keys and configs will be stored
char *ip = "10.8.8.42";               // remote address
int port = 8080;                      // remote port

struct sockaddr_in addr;
addr.sin_family = AF_INET;
addr.sin_addr.s_addr = inet_addr(ip);
addr.sin_port = hton(port);	

zts_simple_start(path, nwid);

int fd, err = 0;
if ((fd = zts_socket(AF_INET, SOCK_STREAM, 0)) < 0) {
	printf("error creating socket\n");
	return -1;
}
if ((err = zts_connect(fd, (const struct sockaddr *)addr, sizeof(addr))) < 0) {
	printf("error connecting to remote host\n");
	return -1;
}
if ((err = zts_write(fd, str, strlen(str))) < 0) {
	printf("error writing to socket\n");
	return -1;
}
if ((err = zts_close(fd)) < 0) {
	printf("error closing socket\n");
	return -1;
}

zts_stop();

Bindings for various languages

For an example using only the Virtual Layer 2, see test/layer2.cpp


Building (linux, macos, bsd, win, ios)

git submodule init
git submodule update
make static_lib
make tests

All targets will output to build/. Complete instructions here


Testing and Debugging

Contributing

Please make pull requests against the dev branch. The master branch is release, and edge is for unstable and work in progress changes and is not likely to work.

License

  • Commercial, with BSD license, build using lwIP network stack with STACK_LWIP=1, then contact us directly via contact@zerotier.com to discuss commercial licensing.
  • Personal, with GPL license, build using picoTCP network stack with STACK_PICO=1, everything is free. Have fun.

Regardless of which network stack you build with, the socket API will remain the same.