This repository has been archived on 2025-09-14. You can view files and clone it, but cannot push or open issues or pull requests.
2017-12-08 11:30:41 -08:00
2017-09-22 13:33:31 -07:00
2017-11-21 15:25:46 -08:00
2017-08-14 12:23:27 -07:00
2017-11-10 10:17:15 -08:00
2017-06-26 02:46:59 -07:00
2017-12-08 11:30:41 -08:00
2017-09-22 13:33:31 -07:00
2017-12-07 10:14:35 -08:00
2017-12-08 11:30:41 -08:00
2017-12-07 10:14:35 -08:00
2017-11-13 16:33:17 -08:00

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 *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", 0xc7cd7c981b0f52a2); // config 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.

Commercial License

  • To be released from GPLv3, contact us directly via contact@zerotier.com to discuss commercial licensing.

Adding a custom network stack

  • If you wish to use something other than lwIP or picoTCP, you can easily add your own API function calls in src/libzt.cpp or src/VirtualSocket.cpp depending on whether your stack's API exposes a POSIX-socket API or a raw API, respectively.
Description
No description provided
Readme 17 MiB
Languages
C++ 58%
C 21.6%
C# 5.8%
Java 5%
Rust 3.3%
Other 6.3%