am ce6fb7bb: am 7ef77271: am bea9d7b9: Merge "Reset fingerprint lockout timer when strong auth is used." into mnc-dr-dev
* commit 'ce6fb7bba967a9b33e5d3afe60fff66c5b2ca034': Reset fingerprint lockout timer when strong auth is used.
This commit is contained in:
@@ -668,6 +668,25 @@ public class FingerprintManager {
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Reset the lockout timer when asked to do so by keyguard.
|
||||
*
|
||||
* @param token an opaque token returned by password confirmation.
|
||||
*
|
||||
* @hide
|
||||
*/
|
||||
public void resetTimeout(byte[] token) {
|
||||
if (mService != null) {
|
||||
try {
|
||||
mService.resetTimeout(token);
|
||||
} catch (RemoteException e) {
|
||||
Log.v(TAG, "Remote exception in getAuthenticatorId(): ", e);
|
||||
}
|
||||
} else {
|
||||
Log.w(TAG, "getAuthenticatorId(): Service not connected!");
|
||||
}
|
||||
}
|
||||
|
||||
private class MyHandler extends Handler {
|
||||
private MyHandler(Context context) {
|
||||
super(context.getMainLooper());
|
||||
@@ -677,6 +696,7 @@ public class FingerprintManager {
|
||||
super(looper);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void handleMessage(android.os.Message msg) {
|
||||
switch(msg.what) {
|
||||
case MSG_ENROLL_RESULT:
|
||||
|
||||
@@ -68,4 +68,7 @@ interface IFingerprintService {
|
||||
|
||||
// Gets the authenticator ID for fingerprint
|
||||
long getAuthenticatorId(String opPackageName);
|
||||
|
||||
// Reset the timeout when user authenticates with strong auth (e.g. PIN, pattern or password)
|
||||
void resetTimeout(in byte [] cryptoToken);
|
||||
}
|
||||
|
||||
@@ -2472,6 +2472,10 @@
|
||||
<permission android:name="android.permission.MANAGE_FINGERPRINT"
|
||||
android:protectionLevel="system|signature" />
|
||||
|
||||
<!-- Allows an app to reset fingerprint attempt counter. Reserved for the system. @hide -->
|
||||
<permission android:name="android.permission.RESET_FINGERPRINT_LOCKOUT"
|
||||
android:protectionLevel="signature" />
|
||||
|
||||
<!-- Allows an application to control keyguard. Only allowed for system processes.
|
||||
@hide -->
|
||||
<permission android:name="android.permission.CONTROL_KEYGUARD"
|
||||
|
||||
@@ -578,6 +578,10 @@ public class KeyguardUpdateMonitor implements TrustManager.TrustListener {
|
||||
public void reportSuccessfulStrongAuthUnlockAttempt() {
|
||||
mStrongAuthTimedOut.remove(sCurrentUser);
|
||||
scheduleStrongAuthTimeout();
|
||||
if (mFpm != null) {
|
||||
byte[] token = null; /* TODO: pass real auth token once fp HAL supports it */
|
||||
mFpm.resetTimeout(token);
|
||||
}
|
||||
}
|
||||
|
||||
private void scheduleStrongAuthTimeout() {
|
||||
|
||||
@@ -108,6 +108,7 @@
|
||||
<uses-permission android:name="android.permission.ACCESS_KEYGUARD_SECURE_STORAGE" />
|
||||
<uses-permission android:name="android.permission.TRUST_LISTENER" />
|
||||
<uses-permission android:name="android.permission.USE_FINGERPRINT" />
|
||||
<uses-permission android:name="android.permission.RESET_FINGERPRINT_LOCKOUT" />
|
||||
|
||||
<!-- Needed for WallpaperManager.clear in ImageWallpaper.updateWallpaperLocked -->
|
||||
<uses-permission android:name="android.permission.SET_WALLPAPER"/>
|
||||
|
||||
@@ -54,6 +54,7 @@ import android.hardware.fingerprint.IFingerprintServiceReceiver;
|
||||
import android.view.Display;
|
||||
|
||||
import static android.Manifest.permission.MANAGE_FINGERPRINT;
|
||||
import static android.Manifest.permission.RESET_FINGERPRINT_LOCKOUT;
|
||||
import static android.Manifest.permission.USE_FINGERPRINT;
|
||||
|
||||
import java.io.File;
|
||||
@@ -255,6 +256,9 @@ public class FingerprintService extends SystemService implements IBinder.DeathRe
|
||||
Slog.v(TAG, "Reset fingerprint lockout");
|
||||
}
|
||||
mFailedAttempts = 0;
|
||||
// If we're asked to reset failed attempts externally (i.e. from Keyguard), the runnable
|
||||
// may still be in the queue; remove it.
|
||||
mHandler.removeCallbacks(mLockoutReset);
|
||||
}
|
||||
|
||||
private boolean handleFailedAttempt(ClientMonitor clientMonitor) {
|
||||
@@ -878,6 +882,12 @@ public class FingerprintService extends SystemService implements IBinder.DeathRe
|
||||
Binder.restoreCallingIdentity(ident);
|
||||
}
|
||||
}
|
||||
@Override // Binder call
|
||||
public void resetTimeout(byte [] token) {
|
||||
checkPermission(RESET_FINGERPRINT_LOCKOUT);
|
||||
// TODO: confirm security token when we move timeout management into the HAL layer.
|
||||
mLockoutReset.run();
|
||||
}
|
||||
}
|
||||
|
||||
private void dumpInternal(PrintWriter pw) {
|
||||
|
||||
Reference in New Issue
Block a user