diff --git a/briar-android/build.gradle b/briar-android/build.gradle
index 2d020aeae..bc40fdc7a 100644
--- a/briar-android/build.gradle
+++ b/briar-android/build.gradle
@@ -100,7 +100,7 @@ dependencies {
implementation project(path: ':briar-core', configuration: 'default')
implementation project(path: ':bramble-core', configuration: 'default')
implementation project(':bramble-android')
- implementation 'org.briarproject:dont-kill-me-lib:0.2.2'
+ implementation 'org.briarproject:dont-kill-me-lib:0.2.5'
implementation 'androidx.fragment:fragment:1.3.4'
implementation 'androidx.preference:preference:1.1.1'
diff --git a/briar-android/src/main/AndroidManifest.xml b/briar-android/src/main/AndroidManifest.xml
index 822717f27..984dab9c2 100644
--- a/briar-android/src/main/AndroidManifest.xml
+++ b/briar-android/src/main/AndroidManifest.xml
@@ -496,6 +496,7 @@
+
diff --git a/briar-android/src/main/java/org/briarproject/briar/android/account/DozeFragment.java b/briar-android/src/main/java/org/briarproject/briar/android/account/DozeFragment.java
index 86ec70bfb..cec359705 100644
--- a/briar-android/src/main/java/org/briarproject/briar/android/account/DozeFragment.java
+++ b/briar-android/src/main/java/org/briarproject/briar/android/account/DozeFragment.java
@@ -32,7 +32,8 @@ public class DozeFragment extends SetupFragment
private DozeView dozeView;
private HuaweiProtectedAppsView huaweiProtectedAppsView;
private HuaweiAppLaunchView huaweiAppLaunchView;
- private XiaomiView xiaomiView;
+ private XiaomiRecentAppsView xiaomiRecentAppsView;
+ private XiaomiLockAppsView xiaomiLockAppsView;
private Button next;
private boolean secondAttempt = false;
@@ -54,8 +55,10 @@ public class DozeFragment extends SetupFragment
huaweiProtectedAppsView.setOnCheckedChangedListener(this);
huaweiAppLaunchView = v.findViewById(R.id.huaweiAppLaunchView);
huaweiAppLaunchView.setOnCheckedChangedListener(this);
- xiaomiView = v.findViewById(R.id.xiaomiView);
- xiaomiView.setOnCheckedChangedListener(this);
+ xiaomiRecentAppsView = v.findViewById(R.id.xiaomiRecentAppsView);
+ xiaomiRecentAppsView.setOnCheckedChangedListener(this);
+ xiaomiLockAppsView = v.findViewById(R.id.xiaomiLockAppsView);
+ xiaomiLockAppsView.setOnCheckedChangedListener(this);
next = v.findViewById(R.id.next);
ProgressBar progressBar = v.findViewById(R.id.progress);
@@ -102,7 +105,8 @@ public class DozeFragment extends SetupFragment
next.setEnabled(dozeView.isChecked() &&
huaweiProtectedAppsView.isChecked() &&
huaweiAppLaunchView.isChecked() &&
- xiaomiView.isChecked());
+ xiaomiRecentAppsView.isChecked() &&
+ xiaomiLockAppsView.isChecked());
}
@SuppressLint("BatteryLife")
diff --git a/briar-android/src/main/java/org/briarproject/briar/android/account/DozeView.java b/briar-android/src/main/java/org/briarproject/briar/android/account/DozeView.java
index e4978bfd8..0d59345c7 100644
--- a/briar-android/src/main/java/org/briarproject/briar/android/account/DozeView.java
+++ b/briar-android/src/main/java/org/briarproject/briar/android/account/DozeView.java
@@ -50,7 +50,7 @@ class DozeView extends PowerView {
onButtonClickListener.run();
}
- public void setOnButtonClickListener(Runnable runnable) {
+ void setOnButtonClickListener(Runnable runnable) {
onButtonClickListener = runnable;
}
diff --git a/briar-android/src/main/java/org/briarproject/briar/android/account/XiaomiLockAppsView.java b/briar-android/src/main/java/org/briarproject/briar/android/account/XiaomiLockAppsView.java
new file mode 100644
index 000000000..84cfd1cd9
--- /dev/null
+++ b/briar-android/src/main/java/org/briarproject/briar/android/account/XiaomiLockAppsView.java
@@ -0,0 +1,72 @@
+package org.briarproject.briar.android.account;
+
+import android.content.Context;
+import android.util.AttributeSet;
+import android.widget.Toast;
+
+import org.briarproject.bramble.api.nullsafety.NotNullByDefault;
+import org.briarproject.briar.R;
+
+import java.util.logging.Logger;
+
+import javax.annotation.Nullable;
+
+import androidx.annotation.StringRes;
+import androidx.annotation.UiThread;
+
+import static android.widget.Toast.LENGTH_LONG;
+import static java.util.logging.Level.WARNING;
+import static java.util.logging.Logger.getLogger;
+import static org.briarproject.android.dontkillmelib.XiaomiUtils.getXiaomiLockAppsIntent;
+import static org.briarproject.android.dontkillmelib.XiaomiUtils.xiaomiLockAppsNeedsToBeShown;
+import static org.briarproject.bramble.util.LogUtils.logException;
+
+@UiThread
+@NotNullByDefault
+class XiaomiLockAppsView extends PowerView {
+
+ private static final Logger LOG =
+ getLogger(XiaomiLockAppsView.class.getName());
+
+ public XiaomiLockAppsView(Context context) {
+ this(context, null);
+ }
+
+ public XiaomiLockAppsView(Context context, @Nullable AttributeSet attrs) {
+ this(context, attrs, 0);
+ }
+
+ public XiaomiLockAppsView(Context context, @Nullable AttributeSet attrs,
+ int defStyleAttr) {
+ super(context, attrs, defStyleAttr);
+ setText(R.string.dnkm_xiaomi_lock_apps_text);
+ setButtonText(R.string.dnkm_xiaomi_lock_apps_button);
+ }
+
+ @Override
+ public boolean needsToBeShown() {
+ return xiaomiLockAppsNeedsToBeShown(getContext());
+ }
+
+ @Override
+ @StringRes
+ protected int getHelpText() {
+ return R.string.dnkm_xiaomi_lock_apps_help;
+ }
+
+ @Override
+ protected void onButtonClick() {
+ try {
+ getContext().startActivity(getXiaomiLockAppsIntent());
+ setChecked(true);
+ return;
+ } catch (SecurityException e) {
+ logException(LOG, WARNING, e);
+ }
+ Toast.makeText(getContext(),
+ R.string.dnkm_xiaomi_lock_apps_error_toast,
+ LENGTH_LONG).show();
+ // Let the user continue with setup
+ setChecked(true);
+ }
+}
diff --git a/briar-android/src/main/java/org/briarproject/briar/android/account/XiaomiView.java b/briar-android/src/main/java/org/briarproject/briar/android/account/XiaomiRecentAppsView.java
similarity index 74%
rename from briar-android/src/main/java/org/briarproject/briar/android/account/XiaomiView.java
rename to briar-android/src/main/java/org/briarproject/briar/android/account/XiaomiRecentAppsView.java
index 453896b73..0efef138f 100644
--- a/briar-android/src/main/java/org/briarproject/briar/android/account/XiaomiView.java
+++ b/briar-android/src/main/java/org/briarproject/briar/android/account/XiaomiRecentAppsView.java
@@ -1,6 +1,5 @@
package org.briarproject.briar.android.account;
-
import android.content.Context;
import android.util.AttributeSet;
@@ -12,23 +11,23 @@ import javax.annotation.Nullable;
import androidx.annotation.StringRes;
import androidx.annotation.UiThread;
-import static org.briarproject.android.dontkillmelib.XiaomiUtils.isMiuiTenOrLater;
-import static org.briarproject.android.dontkillmelib.XiaomiUtils.isXiaomiOrRedmiDevice;
+import static org.briarproject.android.dontkillmelib.XiaomiUtils.isMiuiVersionAtLeast;
+import static org.briarproject.android.dontkillmelib.XiaomiUtils.xiaomiRecentAppsNeedsToBeShown;
import static org.briarproject.briar.android.util.UiUtils.showOnboardingDialog;
@UiThread
@NotNullByDefault
-class XiaomiView extends PowerView {
+class XiaomiRecentAppsView extends PowerView {
- public XiaomiView(Context context) {
+ public XiaomiRecentAppsView(Context context) {
this(context, null);
}
- public XiaomiView(Context context, @Nullable AttributeSet attrs) {
+ public XiaomiRecentAppsView(Context context, @Nullable AttributeSet attrs) {
this(context, attrs, 0);
}
- public XiaomiView(Context context, @Nullable AttributeSet attrs,
+ public XiaomiRecentAppsView(Context context, @Nullable AttributeSet attrs,
int defStyleAttr) {
super(context, attrs, defStyleAttr);
setText(R.string.dnkm_xiaomi_text);
@@ -37,7 +36,7 @@ class XiaomiView extends PowerView {
@Override
public boolean needsToBeShown() {
- return isXiaomiOrRedmiDevice();
+ return xiaomiRecentAppsNeedsToBeShown();
}
@Override
@@ -48,7 +47,7 @@ class XiaomiView extends PowerView {
@Override
protected void onButtonClick() {
- int bodyRes = isMiuiTenOrLater()
+ int bodyRes = isMiuiVersionAtLeast(10, 0)
? R.string.dnkm_xiaomi_dialog_body_new
: R.string.dnkm_xiaomi_dialog_body_old;
showOnboardingDialog(getContext(), getContext().getString(bodyRes));
diff --git a/briar-android/src/main/res/layout/fragment_setup_doze.xml b/briar-android/src/main/res/layout/fragment_setup_doze.xml
index e32cf10b0..5a94c3592 100644
--- a/briar-android/src/main/res/layout/fragment_setup_doze.xml
+++ b/briar-android/src/main/res/layout/fragment_setup_doze.xml
@@ -38,8 +38,8 @@
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/huaweiProtectedAppsView" />
-
+
+
diff --git a/briar-android/src/main/res/values/strings.xml b/briar-android/src/main/res/values/strings.xml
index 5e4347bdf..ea321059b 100644
--- a/briar-android/src/main/res/values/strings.xml
+++ b/briar-android/src/main/res/values/strings.xml
@@ -31,7 +31,9 @@
Protect Briar
If Briar is not locked to the recent apps list, it will be unable to run in the background.
1. Open the recent apps list (also called the app switcher)\n\n2. Swipe down on the image of Briar to show the padlock icon\n\n3. If the padlock is not locked, tap to lock it
- 1. Open the recent apps list (also called the app switcher)\n\n2. Press and hold the image of Briar until the padlock button appears\n\n3. If the padlock is not locked, tap to lock it
+ 1. Open the recent apps list (also called the app switcher)\n\n2. If Briar has a small image of a padlock next to its name then you don\'t need to do anything\n\n3. If there\'s no padlock, press and hold the image of Briar until the padlock button appears, then tap it
+ Please tap the button below to open the security settings. Tap \"Boost speed\", then tap \"Lock apps\", and make sure Briar is set to \"Locked\".
+ If Briar is not set to \"Locked\" in the \"Lock apps\" screen, it will be unable to run in the background.
Password
diff --git a/briar-android/witness.gradle b/briar-android/witness.gradle
index 317c59446..3893f1f72 100644
--- a/briar-android/witness.gradle
+++ b/briar-android/witness.gradle
@@ -184,7 +184,7 @@ dependencyVerification {
'org.bouncycastle:bcpkix-jdk15on:1.56:bcpkix-jdk15on-1.56.jar:7043dee4e9e7175e93e0b36f45b1ec1ecb893c5f755667e8b916eb8dd201c6ca',
'org.bouncycastle:bcprov-jdk15on:1.56:bcprov-jdk15on-1.56.jar:963e1ee14f808ffb99897d848ddcdb28fa91ddda867eb18d303e82728f878349',
'org.bouncycastle:bcprov-jdk15on:1.65:bcprov-jdk15on-1.65.jar:e78f96eb59066c94c94fb2d6b5eb80f52feac6f5f9776898634f8addec6e2137',
- 'org.briarproject:dont-kill-me-lib:0.2.2:dont-kill-me-lib-0.2.2.aar:5e95bf79abe1342fb15be6757ac23be165127f052b93055ef1a796e5b8d6ab8a',
+ 'org.briarproject:dont-kill-me-lib:0.2.5:dont-kill-me-lib-0.2.5.aar:55cd9d511b7016ab573905d64bc54e222e2633144d36389192b8b34485b31b9d',
'org.checkerframework:checker-compat-qual:2.5.3:checker-compat-qual-2.5.3.jar:d76b9afea61c7c082908023f0cbc1427fab9abd2df915c8b8a3e7a509bccbc6d',
'org.checkerframework:checker-qual:2.5.2:checker-qual-2.5.2.jar:64b02691c8b9d4e7700f8ee2e742dce7ea2c6e81e662b7522c9ee3bf568c040a',
'org.checkerframework:checker-qual:3.5.0:checker-qual-3.5.0.jar:729990b3f18a95606fc2573836b6958bcdb44cb52bfbd1b7aa9c339cff35a5a4',