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/docs/ios_zt_sdk.md

73 lines
2.7 KiB
Markdown
Raw Normal View History

2016-06-14 16:01:19 -07:00
iOS + ZeroTier SDK
====
Welcome!
Imagine a flat, encrypted, no-configuration LAN for all of the instances of your iOS app.
2016-07-18 17:34:18 -07:00
This short tutorial will show you how to enable ZeroTier functionality for your iOS app with little to no code modification. Check out our [ZeroTier SDK](https://www.zerotier.com/blog) page for more info on how the integration works.
2016-06-14 16:01:19 -07:00
2016-07-14 08:40:40 -07:00
***
**Step 1: Build iOS framework**
2016-06-14 16:01:19 -07:00
2016-07-14 08:40:40 -07:00
- `make ios_app_framework`
- This will output to `build/ios_app_framework/Release-iphoneos/ZeroTierSDK_iOS.framework`
2016-06-14 16:01:19 -07:00
2016-07-14 08:40:40 -07:00
**Step 2: Integrate SDK into project**
2016-06-14 16:01:19 -07:00
2016-07-14 08:40:40 -07:00
- Add the resultant framework package to your project
- Add `src` directory to *Build Settings -> Header Search Paths*
2016-07-14 08:40:40 -07:00
- Add `build/ios_app_framework/Release-iphoneos/` to *Build Settings -> Framework Search Paths*
- Add `ZeroTierSDK.frameworkiOS` to *General->Embedded Binaries*
- Add `src/SDK_XcodeWrapper.cpp` and `src/SDK_XcodeWrapper.hpp` to your project:
- Set `src/SDK_Apple-Bridging-Header.h` as your bridging-header in *Build Settings -> Objective-C Bridging-header*
2016-06-14 16:01:19 -07:00
2016-07-14 08:40:40 -07:00
**Step 3: Start the ZeroTier service**
2016-06-14 16:01:19 -07:00
2016-07-14 08:40:40 -07:00
Now find a place in your code to set up the ZeroTier service thread:
2016-06-14 16:01:19 -07:00
```
var service_thread : NSThread!
2016-07-14 08:40:40 -07:00
func zt_start_service() {
2016-06-14 16:01:19 -07:00
let path = NSSearchPathForDirectoriesInDomains(NSSearchPathDirectory.DocumentDirectory, NSSearchPathDomainMask.UserDomainMask, true)
start_service(path[0])
}
```
2016-07-14 08:40:40 -07:00
and then start it:
2016-06-14 16:01:19 -07:00
```
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_HIGH, 0), {
2016-07-14 08:40:40 -07:00
self.service_thread = NSThread(target:self, selector:"zt_start_service", object:nil)
2016-06-14 16:01:19 -07:00
self.service_thread.start()
});
```
2016-07-14 08:40:40 -07:00
**Step 4: Pick an API**
2016-06-14 16:01:19 -07:00
2016-07-18 18:27:23 -07:00
The following APIs are available for this integration:
2016-07-18 18:13:53 -07:00
- `Direct Call`: Consult [src/SDK_Apple-Bridging-Header.h](../../../../src/SDK_Apple-Bridging-Header.h).
- `Hook of BSD-like sockets`: Use BSD-like sockets as you normally would. This likely won't work for calls used by a third-party library.
- `Proxy of NSStream`: Create NSStream. Configure stream for SOCKS5 Proxy (127.0.0.1:PORT). Start Proxy. Use stream.
2016-06-14 16:01:19 -07:00
2016-07-14 08:40:40 -07:00
**Step 5: Join a network!**
2016-06-14 16:01:19 -07:00
2016-08-25 17:27:09 -07:00
Simply call `zt_join_network("nwid")`
2016-06-14 16:01:19 -07:00
***
**NSStream and SOCKS Proxy:**
As an example, here's how one would configure a NSStream object to redirect all network activity to the ZeroTier SOCKS proxy server:
```
// BEGIN proxy configuration
let myDict:NSDictionary = [NSStreamSOCKSProxyHostKey : "0.0.0.0",
NSStreamSOCKSProxyPortKey : 1337,
NSStreamSOCKSProxyVersionKey : NSStreamSOCKSProxyVersion5]
inputStream!.setProperty(myDict, forKey: NSStreamSOCKSProxyConfigurationKey)
outputStream!.setProperty(myDict, forKey: NSStreamSOCKSProxyConfigurationKey)
// END proxy configuration
```