Merge "Protect VPN dialogs against overlay." into qt-dev
This commit is contained in:
@@ -22,6 +22,7 @@
|
|||||||
<uses-permission android:name="android.permission.CONTROL_VPN" />
|
<uses-permission android:name="android.permission.CONTROL_VPN" />
|
||||||
<uses-permission android:name="android.permission.CONTROL_ALWAYS_ON_VPN" />
|
<uses-permission android:name="android.permission.CONTROL_ALWAYS_ON_VPN" />
|
||||||
<uses-permission android:name="android.permission.CONNECTIVITY_INTERNAL" />
|
<uses-permission android:name="android.permission.CONNECTIVITY_INTERNAL" />
|
||||||
|
<uses-permission android:name="android.permission.HIDE_NON_SYSTEM_OVERLAY_WINDOWS"/>
|
||||||
|
|
||||||
<application android:label="VpnDialogs"
|
<application android:label="VpnDialogs"
|
||||||
android:allowBackup="false">
|
android:allowBackup="false">
|
||||||
|
|||||||
@@ -16,6 +16,10 @@
|
|||||||
|
|
||||||
package com.android.vpndialogs;
|
package com.android.vpndialogs;
|
||||||
|
|
||||||
|
import static android.view.WindowManager.LayoutParams.FLAG_ALT_FOCUSABLE_IM;
|
||||||
|
import static android.view.WindowManager.LayoutParams.SYSTEM_FLAG_HIDE_NON_SYSTEM_OVERLAY_WINDOWS;
|
||||||
|
import static android.view.WindowManager.LayoutParams.TYPE_SYSTEM_ALERT;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
@@ -31,7 +35,6 @@ import android.text.method.LinkMovementMethod;
|
|||||||
import android.text.style.ClickableSpan;
|
import android.text.style.ClickableSpan;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.WindowManager;
|
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
import com.android.internal.app.AlertActivity;
|
import com.android.internal.app.AlertActivity;
|
||||||
@@ -74,8 +77,9 @@ public class AlwaysOnDisconnectedDialog extends AlertActivity
|
|||||||
setupAlert();
|
setupAlert();
|
||||||
|
|
||||||
getWindow().setCloseOnTouchOutside(false);
|
getWindow().setCloseOnTouchOutside(false);
|
||||||
getWindow().setType(WindowManager.LayoutParams.TYPE_SYSTEM_ALERT);
|
getWindow().setType(TYPE_SYSTEM_ALERT);
|
||||||
getWindow().addFlags(WindowManager.LayoutParams.FLAG_ALT_FOCUSABLE_IM);
|
getWindow().addFlags(FLAG_ALT_FOCUSABLE_IM);
|
||||||
|
getWindow().addPrivateFlags(SYSTEM_FLAG_HIDE_NON_SYSTEM_OVERLAY_WINDOWS);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -16,6 +16,8 @@
|
|||||||
|
|
||||||
package com.android.vpndialogs;
|
package com.android.vpndialogs;
|
||||||
|
|
||||||
|
import static android.view.WindowManager.LayoutParams.SYSTEM_FLAG_HIDE_NON_SYSTEM_OVERLAY_WINDOWS;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
@@ -79,6 +81,7 @@ public class ConfirmDialog extends AlertActivity
|
|||||||
setupAlert();
|
setupAlert();
|
||||||
|
|
||||||
getWindow().setCloseOnTouchOutside(false);
|
getWindow().setCloseOnTouchOutside(false);
|
||||||
|
getWindow().addPrivateFlags(SYSTEM_FLAG_HIDE_NON_SYSTEM_OVERLAY_WINDOWS);
|
||||||
Button button = mAlert.getButton(DialogInterface.BUTTON_POSITIVE);
|
Button button = mAlert.getButton(DialogInterface.BUTTON_POSITIVE);
|
||||||
button.setFilterTouchesWhenObscured(true);
|
button.setFilterTouchesWhenObscured(true);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user