summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDinesh K Garg <dineshg@codeaurora.org>2015-08-07 14:47:57 -0700
committerLinux Build Service Account <lnxbuild@localhost>2015-10-06 03:27:40 -0600
commit431c525012c288086ac26d923f34b3bc523183f8 (patch)
tree89b629e5439153e8f32d37090165a286197d9116
parentc580c17d43a643ff4e83c87088193972cb4ccb9e (diff)
downloadframeworks_base-431c525012c288086ac26d923f34b3bc523183f8.zip
frameworks_base-431c525012c288086ac26d923f34b3bc523183f8.tar.gz
frameworks_base-431c525012c288086ac26d923f34b3bc523183f8.tar.bz2
Port password retention feature
Password retention feature for HW FDE is needed. Porting from L release. Change-Id: I73edbca684a055c184ad0252a359dad28f935a6f
-rw-r--r--services/core/java/com/android/server/LockSettingsService.java28
-rw-r--r--services/core/java/com/android/server/MountService.java5
2 files changed, 31 insertions, 2 deletions
diff --git a/services/core/java/com/android/server/LockSettingsService.java b/services/core/java/com/android/server/LockSettingsService.java
index 5e2fe5a..c844c2c 100644
--- a/services/core/java/com/android/server/LockSettingsService.java
+++ b/services/core/java/com/android/server/LockSettingsService.java
@@ -55,6 +55,9 @@ import com.android.server.LockSettingsStorage.CredentialHash;
import java.util.Arrays;
import java.util.List;
+import java.util.Timer;
+import java.util.TimerTask;
+
/**
* Keeps the lock pattern/password data and related settings for each user.
* Used by LockPatternUtils. Needs to be a service because Settings app also needs
@@ -74,6 +77,9 @@ public class LockSettingsService extends ILockSettings.Stub {
private LockPatternUtils mLockPatternUtils;
private boolean mFirstCallToVold;
private IGateKeeperService mGateKeeperService;
+ private static String mSavePassword = "default_password";
+ private static final long CLEAR_PASSWORD_INTERVAL = 60 * 1000; // 1m
+ protected Timer mClearPasswordTimer;
private interface CredentialUtil {
void setCredential(String credential, String savedCredential, int userId)
@@ -360,6 +366,21 @@ public class LockSettingsService extends ILockSettings.Stub {
return mStorage.hasPattern(userId);
}
+ public void retainPassword(String password) {
+ mSavePassword = password;
+ mClearPasswordTimer = new Timer();
+ mClearPasswordTimer.schedule(new TimerTask() {
+ @Override
+ public void run() {
+ mSavePassword = "default_password";
+ }
+ }, CLEAR_PASSWORD_INTERVAL);
+ }
+
+ public String getPassword() {
+ return mSavePassword;
+ }
+
private void setKeystorePassword(String password, int userHandle) {
final UserManager um = (UserManager) mContext.getSystemService(USER_SERVICE);
final KeyStore ks = KeyStore.getInstance();
@@ -546,6 +567,8 @@ public class LockSettingsService extends ILockSettings.Stub {
&& shouldReEnrollBaseZero) {
setLockPattern(pattern, patternToVerify, userId);
}
+ if (response.getResponseCode() == VerifyCredentialResponse.RESPONSE_OK)
+ retainPassword(pattern);
return response;
@@ -554,7 +577,10 @@ public class LockSettingsService extends ILockSettings.Stub {
@Override
public VerifyCredentialResponse checkPassword(String password, int userId)
throws RemoteException {
- return doVerifyPassword(password, false, 0, userId);
+ VerifyCredentialResponse response = doVerifyPassword(password, false, 0, userId);
+ if (response.getResponseCode() == VerifyCredentialResponse.RESPONSE_OK)
+ retainPassword(password);
+ return response;
}
@Override
diff --git a/services/core/java/com/android/server/MountService.java b/services/core/java/com/android/server/MountService.java
index d10a457..e2babe4 100644
--- a/services/core/java/com/android/server/MountService.java
+++ b/services/core/java/com/android/server/MountService.java
@@ -2433,9 +2433,12 @@ class MountService extends IMountService.Stub
Slog.i(TAG, "changing encryption password...");
}
+ LockSettingsService lockSettings = new LockSettingsService(mContext);
+ String currentPassword = lockSettings.getPassword();
+
try {
NativeDaemonEvent event = mCryptConnector.execute("cryptfs", "changepw", CRYPTO_TYPES[type],
- new SensitiveArg(password));
+ new SensitiveArg(currentPassword), new SensitiveArg(password));
return Integer.parseInt(event.getMessage());
} catch (NativeDaemonConnectorException e) {
// Encryption failed