/* * Copyright (C) 2014 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.password; import android.app.Activity; import android.app.KeyguardManager; import android.app.admin.DevicePolicyManager; import android.content.Context; import android.content.Intent; import android.os.Bundle; import android.os.UserManager; import android.util.Log; import com.android.internal.widget.LockPatternUtils; import com.android.settings.Utils; /** * Launch this when you want to confirm the user is present by asking them to enter their * PIN/password/pattern. */ public class ConfirmDeviceCredentialActivity extends Activity { public static final String TAG = ConfirmDeviceCredentialActivity.class.getSimpleName(); public static class InternalActivity extends ConfirmDeviceCredentialActivity { } public static Intent createIntent(CharSequence title, CharSequence details) { Intent intent = new Intent(); intent.setClassName("com.android.settings", ConfirmDeviceCredentialActivity.class.getName()); intent.putExtra(KeyguardManager.EXTRA_TITLE, title); intent.putExtra(KeyguardManager.EXTRA_DESCRIPTION, details); return intent; } public static Intent createIntent(CharSequence title, CharSequence details, long challenge) { Intent intent = new Intent(); intent.setClassName("com.android.settings", ConfirmDeviceCredentialActivity.class.getName()); intent.putExtra(KeyguardManager.EXTRA_TITLE, title); intent.putExtra(KeyguardManager.EXTRA_DESCRIPTION, details); intent.putExtra(ChooseLockSettingsHelper.EXTRA_KEY_CHALLENGE, challenge); intent.putExtra(ChooseLockSettingsHelper.EXTRA_KEY_HAS_CHALLENGE, true); return intent; } @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); Intent intent = getIntent(); String title = intent.getStringExtra(KeyguardManager.EXTRA_TITLE); String details = intent.getStringExtra(KeyguardManager.EXTRA_DESCRIPTION); String alternateButton = intent.getStringExtra( KeyguardManager.EXTRA_ALTERNATE_BUTTON_LABEL); boolean frp = KeyguardManager.ACTION_CONFIRM_FRP_CREDENTIAL.equals(intent.getAction()); int userId = Utils.getCredentialOwnerUserId(this); if (isInternalActivity()) { try { userId = Utils.getUserIdFromBundle(this, intent.getExtras()); } catch (SecurityException se) { Log.e(TAG, "Invalid intent extra", se); } } final boolean isManagedProfile = UserManager.get(this).isManagedProfile(userId); // if the client app did not hand in a title and we are about to show the work challenge, // check whether there is a policy setting the organization name and use that as title if ((title == null) && isManagedProfile) { title = getTitleFromOrganizationName(userId); } ChooseLockSettingsHelper helper = new ChooseLockSettingsHelper(this); final LockPatternUtils lockPatternUtils = new LockPatternUtils(this); boolean launched; // If the target is a managed user and user key not unlocked yet, we will force unlock // tied profile so it will enable work mode and unlock managed profile, when personal // challenge is unlocked. if (frp) { launched = helper.launchFrpConfirmationActivity(0, title, details, alternateButton); } else if (isManagedProfile && isInternalActivity() && !lockPatternUtils.isSeparateProfileChallengeEnabled(userId)) { // We set the challenge as 0L, so it will force to unlock managed profile when it // unlocks primary profile screen lock, by calling verifyTiedProfileChallenge() launched = helper.launchConfirmationActivityWithExternalAndChallenge( 0 /* request code */, null /* title */, title, details, true /* isExternal */, 0L /* challenge */, userId); } else { launched = helper.launchConfirmationActivity(0 /* request code */, null /* title */, title, details, false /* returnCredentials */, true /* isExternal */, userId); } if (!launched) { Log.d(TAG, "No pattern, password or PIN set."); setResult(Activity.RESULT_OK); } finish(); } private boolean isInternalActivity() { return this instanceof ConfirmDeviceCredentialActivity.InternalActivity; } private String getTitleFromOrganizationName(int userId) { DevicePolicyManager dpm = (DevicePolicyManager) getSystemService( Context.DEVICE_POLICY_SERVICE); CharSequence organizationNameForUser = (dpm != null) ? dpm.getOrganizationNameForUser(userId) : null; return organizationNameForUser != null ? organizationNameForUser.toString() : null; } }