diff options
| author | Ricardo Cerqueira <ricardo@cyngn.com> | 2015-11-05 02:00:43 +0000 |
|---|---|---|
| committer | Ricardo Cerqueira <ricardo@cyngn.com> | 2015-11-05 15:44:26 +0000 |
| commit | 90852d4675c9b7df6faf036efb7fe73b5f816293 (patch) | |
| tree | 18ea2755ab5ea68669a7951d5a07daadc4870b0a /src/com/android/settings/SaveChosenLockWorkerBase.java | |
| parent | 3dbac3fff036f5a464f6322200c59f9934ebf610 (diff) | |
| parent | 310423e73156dab1c7c8f50dc67fdbc326cd37f7 (diff) | |
| download | packages_apps_Settings-90852d4675c9b7df6faf036efb7fe73b5f816293.tar.gz packages_apps_Settings-90852d4675c9b7df6faf036efb7fe73b5f816293.tar.bz2 packages_apps_Settings-90852d4675c9b7df6faf036efb7fe73b5f816293.zip | |
Merge tag 'android-6.0.0_r26' into HEAD
Android 6.0.0 release 26
Conflicts:
res/values-fr/strings.xml
res/values-it/strings.xml
res/values-ja/strings.xml
res/values-nl/strings.xml
res/values-pl/strings.xml
res/values-ro/strings.xml
res/values-ru/strings.xml
res/values-zh-rCN/strings.xml
res/values/bools.xml
res/values/strings.xml
res/xml/development_prefs.xml
src/com/android/settings/DevelopmentSettings.java
src/com/android/settings/DeviceInfoSettings.java
src/com/android/settings/DisplaySettings.java
Change-Id: I9fd9e793cf6097d950f8a1e30771c8bdf5067906
Diffstat (limited to 'src/com/android/settings/SaveChosenLockWorkerBase.java')
| -rw-r--r-- | src/com/android/settings/SaveChosenLockWorkerBase.java | 106 |
1 files changed, 106 insertions, 0 deletions
diff --git a/src/com/android/settings/SaveChosenLockWorkerBase.java b/src/com/android/settings/SaveChosenLockWorkerBase.java new file mode 100644 index 000000000..a40871a21 --- /dev/null +++ b/src/com/android/settings/SaveChosenLockWorkerBase.java @@ -0,0 +1,106 @@ +/* + * Copyright (C) 2015 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package com.android.settings; + +import android.app.Fragment; +import android.content.Intent; +import android.os.AsyncTask; +import android.os.Bundle; +import android.os.UserHandle; + +import com.android.internal.widget.LockPatternUtils; + +/** + * An invisible retained worker fragment to track the AsyncWork that saves (and optionally + * verifies if a challenge is given) the chosen lock credential (pattern/pin/password). + */ +abstract class SaveChosenLockWorkerBase extends Fragment { + + private Listener mListener; + private boolean mFinished; + private Intent mResultData; + + protected LockPatternUtils mUtils; + protected boolean mHasChallenge; + protected long mChallenge; + protected boolean mWasSecureBefore; + + @Override + public void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setRetainInstance(true); + } + + public void setListener(Listener listener) { + if (mListener == listener) { + return; + } + + mListener = listener; + if (mFinished && mListener != null) { + mListener.onChosenLockSaveFinished(mWasSecureBefore, mResultData); + } + } + + protected void prepare(LockPatternUtils utils, boolean credentialRequired, + boolean hasChallenge, long challenge) { + mUtils = utils; + + mHasChallenge = hasChallenge; + mChallenge = challenge; + mWasSecureBefore = mUtils.isSecure(UserHandle.myUserId()); + + mUtils.setCredentialRequiredToDecrypt(credentialRequired); + + mFinished = false; + mResultData = null; + } + + protected void start() { + new Task().execute(); + } + + /** + * Executes the save and verify work in background. + * @return Intent with challenge token or null. + */ + protected abstract Intent saveAndVerifyInBackground(); + + protected void finish(Intent resultData) { + mFinished = true; + mResultData = resultData; + if (mListener != null) { + mListener.onChosenLockSaveFinished(mWasSecureBefore, mResultData); + } + } + + private class Task extends AsyncTask<Void, Void, Intent> { + @Override + protected Intent doInBackground(Void... params){ + return saveAndVerifyInBackground(); + } + + @Override + protected void onPostExecute(Intent resultData) { + finish(resultData); + } + } + + interface Listener { + public void onChosenLockSaveFinished(boolean wasSecureBefore, Intent resultData); + } +} |
