Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/davlxd/NEPacketTunnelVPNDemo
iOS VPN client implementation demo based on iOS9 NetworkExtension NETunnelProvider APIs
https://github.com/davlxd/NEPacketTunnelVPNDemo
demo ios network-extension packet-tunnel swift-3 tun tunnel
Last synced: 2 months ago
JSON representation
iOS VPN client implementation demo based on iOS9 NetworkExtension NETunnelProvider APIs
- Host: GitHub
- URL: https://github.com/davlxd/NEPacketTunnelVPNDemo
- Owner: davlxd
- License: mit
- Archived: true
- Created: 2016-12-08T01:49:33.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2020-07-12T10:00:23.000Z (over 4 years ago)
- Last Synced: 2024-08-04T09:06:00.683Z (6 months ago)
- Topics: demo, ios, network-extension, packet-tunnel, swift-3, tun, tunnel
- Language: Swift
- Size: 1.22 MB
- Stars: 211
- Watchers: 15
- Forks: 73
- Open Issues: 19
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-network-stuff - **121**星
README
Apple released a new version of `Network Extension` since iOS9, which allows us to implement our own VPN protocol. This repo provides a simple demo using `Network Extension` with Swift 3.
Server side demo is [here](https://github.com/lxdcn/simple-vpn-demo).
This demo and server side demo are extremely simplified and only for demonstration purposes, a lot of stuff are hard coded. Further design and elaboration are required if you want apply this demo to your app.
Inspired by [ShadowVPN-iOS](https://github.com/clowwindy/ShadowVPN-iOS).
## Prerequisites to build
1. ~~~First, you need to request NetworkExtension entitlement for your Apple ID from Apple by filling the form here: https://developer.apple.com/contact/network-extension. From my experience, it gonna take 2-6 weeks for Apple to process your request.~~~ 2017-12-16 Update: This is no longer needed.
2. Then you need an iPhone. Network Extension App cannot run in iOS Simulators, you need a real iPhone to debug.
3. Login Apple [developer portal](https://developer.apple.com/account/ios/certificate), register 2 new App IDs, one for App target and another for NetworkExtension tunnel target. And make sure `App Groups` and `Network Extensions` are checked in `App Services` section.
4. Register an `App Group` in developer portal as well
5. Then, again in `App IDs` section of developer portal, edit the 2 App IDs you created at 3rd step, configure `App Groups` to the app group you created at 4th step.
6. Also in developer portal, generate 2 iOS App Development provision profiles for the 2 App IDs created before, ~~~make sure `Network Extension` entitlement is selected on 'Do you need additional entitlements?' page~~~ (2017-12-27 Update: This is probably not needed as well). Then download them and save them to disk.
7. Open this xcodeproj with XCode, select `NEPacketTunnelVPNDemo` target, in `General > Identity` section, change `Bundle Identifier` to App ID you created. Then import profiles you generated in `General > Signing (Debug)` section and `General > Signing (Release)` section.
8. Do the same thing for `NEPacketTunnelVPNDemoTunnel` target.
9. Find a Linux machine, build and run [simple-vpn-demo](https://github.com/lxdcn/simple-vpn-demo), fill its IP address to [ViewController.swift](https://github.com/lxdcn/NEPacketTunnelVPNDemo/blob/master/NEPacketTunnelVPNDemo/ViewController.swift#L18).
## Run
1. After build & run `simple-vpn-demo`, your terminal should be like [this](https://raw.githubusercontent.com/lxdcn/NEPacketTunnelVPNDemo/master/doc/simple-vpn-demo-terminal-before.png).
2. After build & run `NEPacketTunnelVPNDemo` on your iPhone, Xcode log window should look like [this](https://raw.githubusercontent.com/lxdcn/NEPacketTunnelVPNDemo/master/doc/xcode-log-window-before.png), iPhone screen should look like [this](https://raw.githubusercontent.com/lxdcn/NEPacketTunnelVPNDemo/master/doc/iphone-before.png).
3. The `Connect` at the center of iPhone screen is a **BUTTON**, after you click it, your iPhone screen should look like [this](https://raw.githubusercontent.com/lxdcn/NEPacketTunnelVPNDemo/master/doc/iphone-after.png), and Xcode log window should look like [this](https://raw.githubusercontent.com/lxdcn/NEPacketTunnelVPNDemo/master/doc/xcode-log-window-after.png). `simple-vpn-demo` terminal window should look like [this](https://raw.githubusercontent.com/lxdcn/NEPacketTunnelVPNDemo/master/doc/simple-vpn-demo-terminal-after.png), which means VPN server is now receiving traffic.
4. Your IP address displaying on [http://whatismyipaddress.com/](http://whatismyipaddress.com/) on your iPhone should be different before and after click the `Connect` button. thus Q.E.D.