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 0658fb623a Removed unnecessary dependency 8 years ago
artwork README updates, misc filename changes, debug trace fixes, introduction of libzt moniker 9 years ago
attic Officially deprecated old Makefile in favor of CMake 8 years ago
docs Updated FAQ, removed from docs 9 years ago
examples Windows cmake build updates 8 years ago
ext Removed unnecessary dependency 8 years ago
include Added explanation and #defines for new guarded receive buffer 8 years ago
packages/pypi Reconfigured package structure for source dist on linux 8 years ago
res Updated Windows DLL version info resource file 9 years ago
src Added explanation and #defines for new guarded receive buffer 8 years ago
test Typo 8 years ago
zto@e5d1243dd2 tweaks for Windows cmake build 8 years ago
.gitignore Removed packages directory from .gitignore 8 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
CMakeLists.txt cmake build script fixes, and fixes for selftest's winsock2 calls 8 years ago
FAQ.md Updated FAQ, removed from docs 9 years ago
Jenkinsfile Updated Jenkinsfile for cmake usage 8 years ago
LICENSE.GPL-3 Added license files for libzt and lwip 9 years ago
README.md Updated README.md 8 years ago
RELEASE-NOTES.md Updated RELEASE-NOTES 8 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 Makefile tweaks 8 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 *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


Build

We recommend using CMake for its extensive cross-platform build support.

git submodule init
git submodule update
cmake -H. -Bbuild -DCMAKE_BUILD_TYPE=DEBUG
cmake --build build 

Use libzt.a or libzt.dylib in your application. They are placed in bin\lib. Change CMAKE_BUILD_TYPE to RELEASE for a smaller and optmized build.

Install

  • Install: make install
  • Uninstall: xargs rm < install_manifest.txt

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

  • If you want a commercial license to use libzt in your product contact us directly via contact@zerotier.com.

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.