diff options
author | Parménides GV <parmegv@sdf.org> | 2014-10-07 21:17:12 +0200 |
---|---|---|
committer | Parménides GV <parmegv@sdf.org> | 2014-10-07 21:17:12 +0200 |
commit | c4df01ab94c85ecf4a106b187a03e4859a857b1c (patch) | |
tree | 963423d6253b241d83442bba15b7abd303ea8b33 /app/src/main/java/se/leap/bitmaskclient/VoidVpnLauncher.java | |
parent | fa218f752003adcfb040053cfb88b36637060de7 (diff) |
Set up early routes on boot too.
Diffstat (limited to 'app/src/main/java/se/leap/bitmaskclient/VoidVpnLauncher.java')
-rw-r--r-- | app/src/main/java/se/leap/bitmaskclient/VoidVpnLauncher.java | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/app/src/main/java/se/leap/bitmaskclient/VoidVpnLauncher.java b/app/src/main/java/se/leap/bitmaskclient/VoidVpnLauncher.java new file mode 100644 index 00000000..23e61eab --- /dev/null +++ b/app/src/main/java/se/leap/bitmaskclient/VoidVpnLauncher.java @@ -0,0 +1,36 @@ +package se.leap.bitmaskclient; + +import android.app.Activity; +import android.content.Intent; +import android.net.VpnService; +import android.os.Bundle; + +public class VoidVpnLauncher extends Activity { + + private static final int VPN_USER_PERMISSION= 71; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setUp(); + } + + public void setUp() { + Intent blocking_intent = VpnService.prepare(getApplicationContext()); // stops the VPN connection created by another application. + if(blocking_intent != null) + startActivityForResult(blocking_intent, VPN_USER_PERMISSION); + else { + onActivityResult(VPN_USER_PERMISSION, RESULT_OK, null); + } + } + + protected void onActivityResult(int requestCode, int resultCode, Intent data){ + if(requestCode == VPN_USER_PERMISSION) { + if(resultCode == RESULT_OK) { + Intent void_vpn_service = new Intent(getApplicationContext(), VoidVpnService.class); + void_vpn_service.setAction(VoidVpnService.START_BLOCKING_VPN_PROFILE); + startService(void_vpn_service); + } + } + } +} |