Preparation
- An android device, in this case, Sony xperia Z is used
- Root permission required
- Linux Deploy for deploy image via chroot/proot
- OpenVPN
Step
1. Root android device for superuser permission
2. Install Linux Deploy from play store or custom apk.
- Install Linux Deploy
3. Install linux
- Click download icon to select which image to deploy
data:image/s3,"s3://crabby-images/a65bc/a65bc25fdf873a95b725280582ca2da16dcdcdb9" alt=""
- Select which distribution and suite to use
- Set user name & password
- Allow init system
- Enable SSH server
data:image/s3,"s3://crabby-images/e3732/e373271452fc3ab638ab3b6568a2be7ba48fee9a" alt=""
data:image/s3,"s3://crabby-images/3b232/3b23284a4c37a3a1b4b879b291403d77e4934ee2" alt=""
data:image/s3,"s3://crabby-images/c9994/c999429f5870deaf95ea476eeeb94d338f660192" alt=""
data:image/s3,"s3://crabby-images/23c3a/23c3a9b49d837de2ef6b306b5097d06a9ff3952b" alt=""
- Deploy distribution
data:image/s3,"s3://crabby-images/7b38a/7b38aad68c88a0db6b7c1036cdd07bca4a339d98" alt=""
data:image/s3,"s3://crabby-images/afb5a/afb5a666cef2f997e731197a598cd362ee895e1f" alt=""
data:image/s3,"s3://crabby-images/53e6f/53e6ff31395bea96723f4730ce3d09c4b7de61fa" alt=""
- After installation completed, start linux
data:image/s3,"s3://crabby-images/f3ee7/f3ee797a33129086998b4a775adc09c488f1ee2e" alt=""
data:image/s3,"s3://crabby-images/387dd/387dd95cf114c66d90ddea7a3e611ae13c9bc754" alt=""
4. Connect to android via SSH
5. Install OpenVPN
- Install required packages
- Create certification folder and edit vars configuration
- Edit vars as blow
- Build ca, server and client certification
- Copy required certification to the path of openvpn
- Clone configuration file from sample config
- Edit server.conf
- Edit server.conf as blow, modify what your need
- Modify networking config sysctl.conf
- Modify content to allow transfer traffic from vpn
- Make changes work
- Edit firewall rules
- Add following content to allow route from vpn subnet to wireless
- Edit firewall configuration
- Allow forward policy
- Add firewall rule for vpn and ssh
- Make changes work. (In this case, there was some error but I ignore that)
- Start openvpn
- Validate result