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.
Files
zhangyang-libzt/README.md

87 lines
3.1 KiB
Markdown
Raw Normal View History

2017-06-14 16:58:48 -07:00
# libzt
*Embed ZeroTier directly into your app*
***
2017-05-05 18:51:04 -07:00
2017-08-01 14:25:43 -07:00
<a href="https://www.zerotier.com/?pk_campaign=github_libzt"><img src="https://raw.githubusercontent.com/zerotier/ZeroTierOne/master/artwork/ZeroTierIcon.png" width="128" height="128" align="left" hspace="20" vspace="9"></a>
2017-05-05 18:51:04 -07:00
2017-08-01 14:34:46 -07:00
A library version of the popular [ZeroTier One](https://github.com/zerotier/ZeroTierOne), **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](https://en.wikipedia.org/wiki/Salsa20) cipher.
2017-05-05 19:12:46 -07:00
2017-05-05 19:15:30 -07:00
<hr>
2017-05-05 19:05:36 -07:00
2017-05-05 19:15:30 -07:00
[![irc](https://img.shields.io/badge/IRC-%23zerotier%20on%20freenode-orange.svg)](https://webchat.freenode.net/?channels=zerotier)
Pre-Built Binaries Here: [zerotier.com/download.shtml](https://zerotier.com/download.shtml?pk_campaign=github_libzt).
2017-05-30 12:35:18 -07:00
2017-06-14 17:09:18 -07:00
***
2017-05-30 13:50:27 -07:00
### Example
```
#include "libzt.h"
char *str = "welcome to the machine";
2017-06-14 17:53:32 -07:00
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
2017-06-14 17:53:32 -07:00
struct sockaddr_in addr;
addr.sin_family = AF_INET;
addr.sin_addr.s_addr = inet_addr(ip);
addr.sin_port = hton(port);
2017-05-30 13:17:39 -07:00
2017-06-14 17:38:06 -07:00
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();
```
2017-06-14 17:53:32 -07:00
Bindings for various [languages](examples)
2017-05-30 13:50:27 -07:00
2017-08-01 14:25:03 -07:00
For an example using only the [Virtual Layer 2](https://www.zerotier.com/manual.shtml#2_2?pk_campaign=github_libzt), see [test/layer2.cpp](test/layer2.cpp)
2017-08-01 14:18:21 -07:00
2017-05-30 13:50:27 -07:00
***
2017-06-14 17:38:06 -07:00
### Building (linux, macos, bsd, win, ios)
2017-06-14 17:15:51 -07:00
2017-07-18 11:36:18 -07:00
```
git submodule init
git submodule update
make static_lib
make tests
2017-07-18 11:36:18 -07:00
```
2017-07-18 11:33:04 -07:00
All targets will output to `build/`. Complete instructions [here](BUILDING.md)
2017-05-30 13:50:27 -07:00
2017-05-30 12:35:18 -07:00
***
2017-06-14 17:38:06 -07:00
### Testing and Debugging
- See [TESTING.md](TESTING.md)
### 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.