Merge "Add KeyChain.createManageCredentialsIntent"

This commit is contained in:
Treehugger Robot
2021-02-14 21:28:40 +00:00
committed by Gerrit Code Review
3 changed files with 41 additions and 0 deletions

View File

@@ -36030,6 +36030,7 @@ package android.security {
method public static void choosePrivateKeyAlias(@NonNull android.app.Activity, @NonNull android.security.KeyChainAliasCallback, @Nullable String[], @Nullable java.security.Principal[], @Nullable String, int, @Nullable String);
method public static void choosePrivateKeyAlias(@NonNull android.app.Activity, @NonNull android.security.KeyChainAliasCallback, @Nullable String[], @Nullable java.security.Principal[], @Nullable android.net.Uri, @Nullable String);
method @NonNull public static android.content.Intent createInstallIntent();
method @NonNull public static android.content.Intent createManageCredentialsIntent(@NonNull android.security.AppUriAuthenticationPolicy);
method @Nullable @WorkerThread public static java.security.cert.X509Certificate[] getCertificateChain(@NonNull android.content.Context, @NonNull String) throws java.lang.InterruptedException, android.security.KeyChainException;
method @Nullable @WorkerThread public static java.security.PrivateKey getPrivateKey(@NonNull android.content.Context, @NonNull String) throws java.lang.InterruptedException, android.security.KeyChainException;
method @Deprecated public static boolean isBoundKeyAlgorithm(@NonNull String);

View File

@@ -49,6 +49,8 @@ public class Credentials {
public static final String INSTALL_AS_USER_ACTION = "android.credentials.INSTALL_AS_USER";
public static final String ACTION_MANAGE_CREDENTIALS = "android.security.MANAGE_CREDENTIALS";
/**
* Key prefix for CA certificates.
*

View File

@@ -15,6 +15,8 @@
*/
package android.security;
import static android.security.Credentials.ACTION_MANAGE_CREDENTIALS;
import android.annotation.NonNull;
import android.annotation.Nullable;
import android.annotation.SdkConstant;
@@ -121,6 +123,11 @@ public final class KeyChain {
*/
private static final String CERT_INSTALLER_PACKAGE = "com.android.certinstaller";
/**
* Package name for Settings.
*/
private static final String SETTINGS_PACKAGE = "com.android.settings";
/**
* Extra for use with {@link #ACTION_CHOOSER}
* @hide Also used by KeyChainActivity implementation
@@ -201,6 +208,20 @@ public final class KeyChain {
// Compatible with old android.security.Credentials.PKCS12
public static final String EXTRA_PKCS12 = "PKCS12";
/**
* Extra used by {@link #createManageCredentialsIntent(AppUriAuthenticationPolicy)} to specify
* the authentication policy of the credential management app.
*
* <p>The authentication policy declares which alias for a private key and certificate pair
* should be used for authentication, given a list of apps and URIs.
*
* <p>The extra value should be a {@link AppUriAuthenticationPolicy}.
*
* @hide
*/
public static final String EXTRA_AUTHENTICATION_POLICY =
"android.security.extra.AUTHENTICATION_POLICY";
/**
* Broadcast Action: Indicates the trusted storage has changed. Sent when
* one of this happens:
@@ -385,6 +406,23 @@ public final class KeyChain {
return intent;
}
/**
* Returns an {@code Intent} that should be used by an app to request to manage the user's
* credentials. This is limited to unmanaged devices. The authentication policy must be
* provided to be able to make this request successfully.
*
* @param policy The authentication policy determines which alias for a private key and
* certificate pair should be used for authentication.
*/
@NonNull
public static Intent createManageCredentialsIntent(@NonNull AppUriAuthenticationPolicy policy) {
Intent intent = new Intent(ACTION_MANAGE_CREDENTIALS);
intent.setComponent(ComponentName.createRelative(SETTINGS_PACKAGE,
".security.RequestManageCredentials"));
intent.putExtra(EXTRA_AUTHENTICATION_POLICY, policy);
return intent;
}
/**
* Launches an {@code Activity} for the user to select the alias
* for a private key and certificate pair for authentication. The