Merge "Finish ConfirmDialog when another vpn app is always-on" into nyc-dev am: 98801e9f2b
am: d6d2497ebe
* commit 'd6d2497ebe90e74f0ee7ddfdd2a00f4cb2f25dce':
Finish ConfirmDialog when another vpn app is always-on
Change-Id: I7a44158b41c20d297e3e1c2869bb0a58549e84a2
This commit is contained in:
@@ -20,6 +20,7 @@
|
|||||||
package="com.android.vpndialogs">
|
package="com.android.vpndialogs">
|
||||||
|
|
||||||
<uses-permission android:name="android.permission.CONTROL_VPN" />
|
<uses-permission android:name="android.permission.CONTROL_VPN" />
|
||||||
|
<uses-permission android:name="android.permission.CONNECTIVITY_INTERNAL" />
|
||||||
|
|
||||||
<application android:label="VpnDialogs"
|
<application android:label="VpnDialogs"
|
||||||
android:allowBackup="false" >
|
android:allowBackup="false" >
|
||||||
|
|||||||
@@ -60,6 +60,12 @@ public class ConfirmDialog extends AlertActivity
|
|||||||
finish();
|
finish();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
final String alwaysOnVpnPackage = getAlwaysOnVpnPackage();
|
||||||
|
// Can't prepare new vpn app when another vpn is always-on
|
||||||
|
if (alwaysOnVpnPackage != null && !alwaysOnVpnPackage.equals(mPackage)) {
|
||||||
|
finish();
|
||||||
|
return;
|
||||||
|
}
|
||||||
View view = View.inflate(this, R.layout.confirm, null);
|
View view = View.inflate(this, R.layout.confirm, null);
|
||||||
((TextView) view.findViewById(R.id.warning)).setText(
|
((TextView) view.findViewById(R.id.warning)).setText(
|
||||||
Html.fromHtml(getString(R.string.warning, getVpnLabel()),
|
Html.fromHtml(getString(R.string.warning, getVpnLabel()),
|
||||||
@@ -76,6 +82,16 @@ public class ConfirmDialog extends AlertActivity
|
|||||||
button.setFilterTouchesWhenObscured(true);
|
button.setFilterTouchesWhenObscured(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private String getAlwaysOnVpnPackage() {
|
||||||
|
try {
|
||||||
|
return mService.getAlwaysOnVpnPackage(UserHandle.myUserId());
|
||||||
|
} catch (RemoteException e) {
|
||||||
|
Log.e(TAG, "fail to call getAlwaysOnVpnPackage", e);
|
||||||
|
// Fallback to null to show the dialog
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private boolean prepareVpn() {
|
private boolean prepareVpn() {
|
||||||
try {
|
try {
|
||||||
return mService.prepareVpn(mPackage, null, UserHandle.myUserId());
|
return mService.prepareVpn(mPackage, null, UserHandle.myUserId());
|
||||||
|
|||||||
Reference in New Issue
Block a user