mirror of
https://github.com/chiteroman/TrickyStore.git
synced 2025-07-17 15:29:32 +00:00
support generate key
This commit is contained in:
@@ -5,6 +5,8 @@ import android.os.IBinder;
|
||||
public interface IPackageManager {
|
||||
String[] getPackagesForUid(int uid);
|
||||
|
||||
PackageInfo getPackageInfo(String packageName, long flags, int userId);
|
||||
|
||||
class Stub {
|
||||
public static IPackageManager asInterface(IBinder binder) {
|
||||
throw new RuntimeException("");
|
||||
|
||||
@@ -0,0 +1,9 @@
|
||||
package android.hardware.security.keymint;
|
||||
|
||||
public @interface Algorithm {
|
||||
int AES = 32;
|
||||
int EC = 3;
|
||||
int HMAC = 128;
|
||||
int RSA = 1;
|
||||
int TRIPLE_DES = 33;
|
||||
}
|
||||
@@ -0,0 +1,10 @@
|
||||
package android.hardware.security.keymint;
|
||||
|
||||
/* loaded from: classes2.dex */
|
||||
public @interface EcCurve {
|
||||
public static final int CURVE_25519 = 4;
|
||||
public static final int P_224 = 0;
|
||||
public static final int P_256 = 1;
|
||||
public static final int P_384 = 2;
|
||||
public static final int P_521 = 3;
|
||||
}
|
||||
@@ -0,0 +1,32 @@
|
||||
package android.hardware.security.keymint;
|
||||
|
||||
import android.os.Parcel;
|
||||
import android.os.Parcelable;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
|
||||
public class KeyParameter implements Parcelable {
|
||||
public static final Creator<KeyParameter> CREATOR = new Creator<>() {
|
||||
@Override
|
||||
public KeyParameter createFromParcel(Parcel in) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
@Override
|
||||
public KeyParameter[] newArray(int size) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
};
|
||||
public int tag = 0;
|
||||
public KeyParameterValue value;
|
||||
|
||||
@Override
|
||||
public int describeContents() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void writeToParcel(@NonNull Parcel parcel, int i) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,239 @@
|
||||
package android.hardware.security.keymint;
|
||||
|
||||
import android.os.Parcel;
|
||||
import android.os.Parcelable;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
|
||||
/* loaded from: classes2.dex */
|
||||
public final class KeyParameterValue implements Parcelable {
|
||||
public static final int algorithm = 1;
|
||||
public static final int blob = 14;
|
||||
public static final int blockMode = 2;
|
||||
public static final int boolValue = 10;
|
||||
public static final int dateTime = 13;
|
||||
public static final int digest = 4;
|
||||
public static final int ecCurve = 5;
|
||||
public static final int hardwareAuthenticatorType = 8;
|
||||
public static final int integer = 11;
|
||||
public static final int invalid = 0;
|
||||
public static final int keyPurpose = 7;
|
||||
public static final int longInteger = 12;
|
||||
public static final int origin = 6;
|
||||
public static final int paddingMode = 3;
|
||||
public static final int securityLevel = 9;
|
||||
public static final Creator<KeyParameterValue> CREATOR = new Creator<KeyParameterValue>() {
|
||||
@Override
|
||||
public KeyParameterValue createFromParcel(Parcel in) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
@Override
|
||||
public KeyParameterValue[] newArray(int size) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
};
|
||||
|
||||
public KeyParameterValue() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
protected KeyParameterValue(Parcel in) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public static KeyParameterValue invalid(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public static KeyParameterValue algorithm(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public static KeyParameterValue blockMode(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public static KeyParameterValue paddingMode(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public static KeyParameterValue digest(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public static KeyParameterValue ecCurve(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public static KeyParameterValue origin(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public static KeyParameterValue keyPurpose(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public static KeyParameterValue hardwareAuthenticatorType(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public static KeyParameterValue securityLevel(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public static KeyParameterValue boolValue(boolean _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public static KeyParameterValue integer(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public static KeyParameterValue longInteger(long _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public static KeyParameterValue dateTime(long _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public static KeyParameterValue blob(byte[] _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public int getTag() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public int getInvalid() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public void setInvalid(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public int getAlgorithm() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public void setAlgorithm(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public int getBlockMode() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public void setBlockMode(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public int getPaddingMode() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public void setPaddingMode(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public int getDigest() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public void setDigest(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public int getEcCurve() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public void setEcCurve(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public int getOrigin() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public void setOrigin(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public int getKeyPurpose() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public void setKeyPurpose(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public int getHardwareAuthenticatorType() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public void setHardwareAuthenticatorType(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public int getSecurityLevel() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public void setSecurityLevel(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public boolean getBoolValue() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public void setBoolValue(boolean _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public int getInteger() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public void setInteger(int _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public long getLongInteger() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public void setLongInteger(long _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public long getDateTime() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public void setDateTime(long _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public byte[] getBlob() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
public void setBlob(byte[] _value) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public int describeContents() {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void writeToParcel(@NonNull Parcel parcel, int i) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,11 @@
|
||||
package android.hardware.security.keymint;
|
||||
|
||||
public @interface KeyPurpose {
|
||||
int AGREE_KEY = 6;
|
||||
int ATTEST_KEY = 7;
|
||||
int DECRYPT = 1;
|
||||
int ENCRYPT = 0;
|
||||
int SIGN = 2;
|
||||
int VERIFY = 3;
|
||||
int WRAP_KEY = 5;
|
||||
}
|
||||
@@ -0,0 +1,8 @@
|
||||
package android.hardware.security.keymint;
|
||||
|
||||
public @interface SecurityLevel {
|
||||
int KEYSTORE = 100;
|
||||
int SOFTWARE = 0;
|
||||
int STRONGBOX = 2;
|
||||
int TRUSTED_ENVIRONMENT = 1;
|
||||
}
|
||||
@@ -0,0 +1,70 @@
|
||||
package android.hardware.security.keymint;
|
||||
|
||||
public @interface Tag {
|
||||
int ACTIVE_DATETIME = 1610613136;
|
||||
int ALGORITHM = 268435458;
|
||||
int ALLOW_WHILE_ON_BODY = 1879048698;
|
||||
int APPLICATION_DATA = -1879047492;
|
||||
int APPLICATION_ID = -1879047591;
|
||||
int ASSOCIATED_DATA = -1879047192;
|
||||
int ATTESTATION_APPLICATION_ID = -1879047483;
|
||||
int ATTESTATION_CHALLENGE = -1879047484;
|
||||
int ATTESTATION_ID_BRAND = -1879047482;
|
||||
int ATTESTATION_ID_DEVICE = -1879047481;
|
||||
int ATTESTATION_ID_IMEI = -1879047478;
|
||||
int ATTESTATION_ID_MANUFACTURER = -1879047476;
|
||||
int ATTESTATION_ID_MEID = -1879047477;
|
||||
int ATTESTATION_ID_MODEL = -1879047475;
|
||||
int ATTESTATION_ID_PRODUCT = -1879047480;
|
||||
int ATTESTATION_ID_SECOND_IMEI = -1879047469;
|
||||
int ATTESTATION_ID_SERIAL = -1879047479;
|
||||
int AUTH_TIMEOUT = 805306873;
|
||||
int BLOCK_MODE = 536870916;
|
||||
int BOOTLOADER_ONLY = 1879048494;
|
||||
int BOOT_PATCHLEVEL = 805307087;
|
||||
int CALLER_NONCE = 1879048199;
|
||||
int CERTIFICATE_NOT_AFTER = 1610613745;
|
||||
int CERTIFICATE_NOT_BEFORE = 1610613744;
|
||||
int CERTIFICATE_SERIAL = -2147482642;
|
||||
int CERTIFICATE_SUBJECT = -1879047185;
|
||||
int CONFIRMATION_TOKEN = -1879047187;
|
||||
int CREATION_DATETIME = 1610613437;
|
||||
int DEVICE_UNIQUE_ATTESTATION = 1879048912;
|
||||
int DIGEST = 536870917;
|
||||
int EARLY_BOOT_ONLY = 1879048497;
|
||||
int EC_CURVE = 268435466;
|
||||
int HARDWARE_TYPE = 268435760;
|
||||
int IDENTITY_CREDENTIAL_KEY = 1879048913;
|
||||
int INCLUDE_UNIQUE_ID = 1879048394;
|
||||
int INVALID = 0;
|
||||
int KEY_SIZE = 805306371;
|
||||
int MAC_LENGTH = 805307371;
|
||||
int MAX_BOOT_LEVEL = 805307378;
|
||||
int MAX_USES_PER_BOOT = 805306772;
|
||||
int MIN_MAC_LENGTH = 805306376;
|
||||
int MIN_SECONDS_BETWEEN_OPS = 805306771;
|
||||
int NONCE = -1879047191;
|
||||
int NO_AUTH_REQUIRED = 1879048695;
|
||||
int ORIGIN = 268436158;
|
||||
int ORIGINATION_EXPIRE_DATETIME = 1610613137;
|
||||
int OS_PATCHLEVEL = 805307074;
|
||||
int OS_VERSION = 805307073;
|
||||
int PADDING = 536870918;
|
||||
int PURPOSE = 536870913;
|
||||
int RESET_SINCE_ID_ROTATION = 1879049196;
|
||||
int ROLLBACK_RESISTANCE = 1879048495;
|
||||
int ROOT_OF_TRUST = -1879047488;
|
||||
int RSA_OAEP_MGF_DIGEST = 536871115;
|
||||
int RSA_PUBLIC_EXPONENT = 1342177480;
|
||||
int STORAGE_KEY = 1879048914;
|
||||
int TRUSTED_CONFIRMATION_REQUIRED = 1879048700;
|
||||
int TRUSTED_USER_PRESENCE_REQUIRED = 1879048699;
|
||||
int UNIQUE_ID = -1879047485;
|
||||
int UNLOCKED_DEVICE_REQUIRED = 1879048701;
|
||||
int USAGE_COUNT_LIMIT = 805306773;
|
||||
int USAGE_EXPIRE_DATETIME = 1610613138;
|
||||
int USER_AUTH_TYPE = 268435960;
|
||||
int USER_ID = 805306869;
|
||||
int USER_SECURE_ID = -1610612234;
|
||||
int VENDOR_PATCHLEVEL = 805307086;
|
||||
}
|
||||
@@ -0,0 +1,8 @@
|
||||
package android.system.keystore2;
|
||||
|
||||
import android.hardware.security.keymint.KeyParameter;
|
||||
|
||||
public class Authorization {
|
||||
public KeyParameter keyParameter;
|
||||
public int securityLevel = 0;
|
||||
}
|
||||
@@ -0,0 +1,20 @@
|
||||
package android.system.keystore2;
|
||||
|
||||
import android.hardware.security.keymint.KeyParameter;
|
||||
import android.os.IBinder;
|
||||
import android.os.IInterface;
|
||||
|
||||
import androidx.annotation.Nullable;
|
||||
|
||||
public interface IKeystoreSecurityLevel extends IInterface {
|
||||
String DESCRIPTOR = "android.system.keystore2.IKeystoreSecurityLevel";
|
||||
|
||||
KeyMetadata generateKey(KeyDescriptor key, @Nullable KeyDescriptor attestationKey,
|
||||
KeyParameter[] params, int flags, byte[] entropy);
|
||||
|
||||
class Stub {
|
||||
public static IKeystoreSecurityLevel asInterface(IBinder b) {
|
||||
throw new RuntimeException();
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,9 +1,15 @@
|
||||
package android.system.keystore2;
|
||||
|
||||
import android.os.IBinder;
|
||||
|
||||
public interface IKeystoreService {
|
||||
String DESCRIPTOR = "android.system.keystore2.IKeystoreService";
|
||||
|
||||
class Stub {
|
||||
IKeystoreSecurityLevel getSecurityLevel(int securityLevel);
|
||||
|
||||
class Stub {
|
||||
public static IKeystoreService asInterface(IBinder b) {
|
||||
throw new RuntimeException("");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -11,19 +11,15 @@ public class KeyDescriptor implements Parcelable {
|
||||
public int domain = 0;
|
||||
public long nspace = 0;
|
||||
|
||||
protected KeyDescriptor(Parcel in) {
|
||||
throw new RuntimeException("");
|
||||
}
|
||||
|
||||
public static final Creator<KeyDescriptor> CREATOR = new Creator<KeyDescriptor>() {
|
||||
@Override
|
||||
public KeyDescriptor createFromParcel(Parcel in) {
|
||||
return new KeyDescriptor(in);
|
||||
throw new RuntimeException();
|
||||
}
|
||||
|
||||
@Override
|
||||
public KeyDescriptor[] newArray(int size) {
|
||||
return new KeyDescriptor[size];
|
||||
throw new RuntimeException();
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
@@ -6,13 +6,9 @@ import android.os.Parcelable;
|
||||
import androidx.annotation.NonNull;
|
||||
|
||||
public class KeyEntryResponse implements Parcelable {
|
||||
// public IKeystoreSecurityLevel iSecurityLevel;
|
||||
public IKeystoreSecurityLevel iSecurityLevel;
|
||||
public KeyMetadata metadata;
|
||||
|
||||
protected KeyEntryResponse(Parcel in) {
|
||||
throw new RuntimeException("");
|
||||
}
|
||||
|
||||
public static final Creator<KeyEntryResponse> CREATOR = new Creator<KeyEntryResponse>() {
|
||||
@Override
|
||||
public KeyEntryResponse createFromParcel(Parcel in) {
|
||||
|
||||
@@ -6,17 +6,13 @@ import android.os.Parcelable;
|
||||
import androidx.annotation.NonNull;
|
||||
|
||||
public class KeyMetadata implements Parcelable {
|
||||
// public Authorization[] authorizations;
|
||||
public Authorization[] authorizations;
|
||||
public byte[] certificate;
|
||||
public byte[] certificateChain;
|
||||
public KeyDescriptor key;
|
||||
public int keySecurityLevel = 0;
|
||||
public long modificationTimeMs = 0;
|
||||
|
||||
protected KeyMetadata(Parcel in) {
|
||||
throw new RuntimeException("");
|
||||
}
|
||||
|
||||
public static final Creator<KeyMetadata> CREATOR = new Creator<KeyMetadata>() {
|
||||
@Override
|
||||
public KeyMetadata createFromParcel(Parcel in) {
|
||||
|
||||
Reference in New Issue
Block a user