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 5a1ad729d1 Updated README 9 years ago
artwork README updates, misc filename changes, debug trace fixes, introduction of libzt moniker 9 years ago
docs Updated FAQ, removed from docs 9 years ago
examples Added Objective-C example 9 years ago
ext Attempt (2) to resolve non-TLS h_errno build failure in Jenkins 9 years ago
include Attempt (2) to resolve non-TLS h_errno build failure in Jenkins 9 years ago
obj .gitignore for obj/ 9 years ago
res Updated Windows DLL version info resource file 9 years ago
src Build fixes for NO_STACK and ztproxy 9 years ago
test Updated README 9 years ago
zto@ee4783e3fb Updated ZTO submodule for Windows build tweak 9 years ago
.gitignore Added .conf to .gitignore 9 years ago
.gitmodules Added ZeroTierOne as a submodule 9 years ago
BUILDING.md Removed protocol version from build flags in BUILDING.md 9 years ago
FAQ.md Updated FAQ, removed from docs 9 years ago
Jenkinsfile Removed vestigial targets from Jenkinsfile 9 years ago
Makefile Updated README 9 years ago
README.md Updated README 9 years ago
RELEASE-NOTES.md Documentation update 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 Fixed typo in lwIP makefile 9 years ago
makelib.bat Added target for MSVC DLLs for use in Visual Studio 9 years ago

README.md

libzt

Embed ZeroTier directly into your app


A library version of ZeroTier, 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. We provide a POSIX-like socket API supporting SOCK_STREAM, SOCK_DGRAM, and SOCK_RAW to make the integration simple. There's no need for system-wide virtual interfaces. This connection is exclusive to your app and fully encrypted via the Salsa20 cipher. For a more in-depth discussion on the technical side of ZeroTier, check out our Manual


irc


C++ Example

#include <sys/socket.h>
#include <arpa/inet.h>
#include <netinet/in.h>

#include "libzt.h"

int main() 
{
	char *str = "welcome to the machine";
	char *nwid = "c7cd7c981b0f52a2";      // network
	char *path = "config_path";           // where this instance's keys and configs are 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 = htons(port);	

	zts_startjoin(path, nwid);

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

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.