final class com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt extends com.oracle.security.ucrypto.NativeKey implements java.security.interfaces.RSAPrivateCrtKey
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt
  super_class: com.oracle.security.ucrypto.NativeKey
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 6812507588904302831

  private final java.security.spec.RSAPrivateCrtKeySpec keySpec;
    descriptor: Ljava/security/spec/RSAPrivateCrtKeySpec;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final long keyId;
    descriptor: J
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  void <init>(java.security.spec.KeySpec);
    descriptor: (Ljava/security/spec/KeySpec;)V
    flags: (0x0000) 
    Code:
      stack=8, locals=13, args_size=2
        start local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
        start local 1 // java.security.spec.KeySpec keySpec
         0: .line 124
            aload 0 /* this */
            bipush 8
            invokespecial com.oracle.security.ucrypto.NativeKey.<init>:(I)V
         1: .line 125
            lconst_0
            lstore 2 /* pKey */
        start local 2 // long pKey
         2: .line 126
            aload 1 /* keySpec */
            instanceof java.security.spec.RSAPrivateCrtKeySpec
            ifeq 22
         3: .line 127
            aload 1 /* keySpec */
            checkcast java.security.spec.RSAPrivateCrtKeySpec
            astore 4 /* ks */
        start local 4 // java.security.spec.RSAPrivateCrtKeySpec ks
         4: .line 128
            aload 4 /* ks */
            invokevirtual java.security.spec.RSAPrivateCrtKeySpec.getModulus:()Ljava/math/BigInteger;
            astore 5 /* mod */
        start local 5 // java.math.BigInteger mod
         5: .line 129
            aload 4 /* ks */
            invokevirtual java.security.spec.RSAPrivateCrtKeySpec.getPublicExponent:()Ljava/math/BigInteger;
            astore 6 /* publicExp */
        start local 6 // java.math.BigInteger publicExp
         6: .line 130
            aload 4 /* ks */
            invokevirtual java.security.spec.RSAPrivateCrtKeySpec.getPrivateExponent:()Ljava/math/BigInteger;
            astore 7 /* privateExp */
        start local 7 // java.math.BigInteger privateExp
         7: .line 131
            aload 4 /* ks */
            invokevirtual java.security.spec.RSAPrivateCrtKeySpec.getPrimeP:()Ljava/math/BigInteger;
            astore 8 /* primeP */
        start local 8 // java.math.BigInteger primeP
         8: .line 132
            aload 4 /* ks */
            invokevirtual java.security.spec.RSAPrivateCrtKeySpec.getPrimeQ:()Ljava/math/BigInteger;
            astore 9 /* primeQ */
        start local 9 // java.math.BigInteger primeQ
         9: .line 133
            aload 4 /* ks */
            invokevirtual java.security.spec.RSAPrivateCrtKeySpec.getPrimeExponentP:()Ljava/math/BigInteger;
            astore 10 /* primeExpP */
        start local 10 // java.math.BigInteger primeExpP
        10: .line 134
            aload 4 /* ks */
            invokevirtual java.security.spec.RSAPrivateCrtKeySpec.getPrimeExponentQ:()Ljava/math/BigInteger;
            astore 11 /* primeExpQ */
        start local 11 // java.math.BigInteger primeExpQ
        11: .line 135
            aload 4 /* ks */
            invokevirtual java.security.spec.RSAPrivateCrtKeySpec.getCrtCoefficient:()Ljava/math/BigInteger;
            astore 12 /* crtCoeff */
        start local 12 // java.math.BigInteger crtCoeff
        12: .line 136
            aload 5 /* mod */
            invokestatic com.oracle.security.ucrypto.NativeKey.getMagnitude:(Ljava/math/BigInteger;)[B
        13: .line 137
            aload 6 /* publicExp */
            invokestatic com.oracle.security.ucrypto.NativeKey.getMagnitude:(Ljava/math/BigInteger;)[B
        14: .line 138
            aload 7 /* privateExp */
            invokestatic com.oracle.security.ucrypto.NativeKey.getMagnitude:(Ljava/math/BigInteger;)[B
        15: .line 139
            aload 8 /* primeP */
            invokestatic com.oracle.security.ucrypto.NativeKey.getMagnitude:(Ljava/math/BigInteger;)[B
        16: .line 140
            aload 9 /* primeQ */
            invokestatic com.oracle.security.ucrypto.NativeKey.getMagnitude:(Ljava/math/BigInteger;)[B
        17: .line 141
            aload 10 /* primeExpP */
            invokestatic com.oracle.security.ucrypto.NativeKey.getMagnitude:(Ljava/math/BigInteger;)[B
        18: .line 142
            aload 11 /* primeExpQ */
            invokestatic com.oracle.security.ucrypto.NativeKey.getMagnitude:(Ljava/math/BigInteger;)[B
        19: .line 143
            aload 12 /* crtCoeff */
            invokestatic com.oracle.security.ucrypto.NativeKey.getMagnitude:(Ljava/math/BigInteger;)[B
        20: .line 136
            invokestatic com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt.nativeInit:([B[B[B[B[B[B[B[B)J
            lstore 2 /* pKey */
        end local 12 // java.math.BigInteger crtCoeff
        end local 11 // java.math.BigInteger primeExpQ
        end local 10 // java.math.BigInteger primeExpP
        end local 9 // java.math.BigInteger primeQ
        end local 8 // java.math.BigInteger primeP
        end local 7 // java.math.BigInteger privateExp
        end local 6 // java.math.BigInteger publicExp
        end local 5 // java.math.BigInteger mod
        end local 4 // java.security.spec.RSAPrivateCrtKeySpec ks
        21: .line 144
            goto 25
        22: .line 145
      StackMap locals: com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt java.security.spec.KeySpec long
      StackMap stack:
            new java.security.spec.InvalidKeySpecException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Only supports RSAPrivateCrtKeySpec. Received: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        23: .line 146
            aload 1 /* keySpec */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        24: .line 145
            invokespecial java.security.spec.InvalidKeySpecException.<init>:(Ljava/lang/String;)V
            athrow
        25: .line 148
      StackMap locals:
      StackMap stack:
            lload 2 /* pKey */
            lconst_0
            lcmp
            ifne 27
        26: .line 149
            new com.oracle.security.ucrypto.UcryptoException
            dup
            ldc "Error constructing RSA PrivateCrtKey"
            invokespecial com.oracle.security.ucrypto.UcryptoException.<init>:(Ljava/lang/String;)V
            athrow
        27: .line 152
      StackMap locals:
      StackMap stack:
            new com.oracle.security.ucrypto.NativeKey$KeyRef
            aload 0 /* this */
            lload 2 /* pKey */
            invokespecial com.oracle.security.ucrypto.NativeKey$KeyRef.<init>:(Lcom/oracle/security/ucrypto/NativeKey;J)V
        28: .line 153
            aload 0 /* this */
            aload 1 /* keySpec */
            checkcast java.security.spec.RSAPrivateCrtKeySpec
            putfield com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt.keySpec:Ljava/security/spec/RSAPrivateCrtKeySpec;
        29: .line 154
            aload 0 /* this */
            lload 2 /* pKey */
            putfield com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt.keyId:J
        30: .line 155
            return
        end local 2 // long pKey
        end local 1 // java.security.spec.KeySpec keySpec
        end local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   31     0        this  Lcom/oracle/security/ucrypto/NativeKey$RSAPrivateCrt;
            0   31     1     keySpec  Ljava/security/spec/KeySpec;
            2   31     2        pKey  J
            4   21     4          ks  Ljava/security/spec/RSAPrivateCrtKeySpec;
            5   21     5         mod  Ljava/math/BigInteger;
            6   21     6   publicExp  Ljava/math/BigInteger;
            7   21     7  privateExp  Ljava/math/BigInteger;
            8   21     8      primeP  Ljava/math/BigInteger;
            9   21     9      primeQ  Ljava/math/BigInteger;
           10   21    10   primeExpP  Ljava/math/BigInteger;
           11   21    11   primeExpQ  Ljava/math/BigInteger;
           12   21    12    crtCoeff  Ljava/math/BigInteger;
    Exceptions:
      throws java.security.spec.InvalidKeySpecException
    MethodParameters:
         Name  Flags
      keySpec  

  long value();
    descriptor: ()J
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
         0: .line 157
            aload 0 /* this */
            getfield com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt.keyId:J
            lreturn
        end local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/security/ucrypto/NativeKey$RSAPrivateCrt;

  public java.math.BigInteger getModulus();
    descriptor: ()Ljava/math/BigInteger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
         0: .line 158
            aload 0 /* this */
            getfield com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt.keySpec:Ljava/security/spec/RSAPrivateCrtKeySpec;
            invokevirtual java.security.spec.RSAPrivateCrtKeySpec.getModulus:()Ljava/math/BigInteger;
            areturn
        end local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/security/ucrypto/NativeKey$RSAPrivateCrt;

  public java.math.BigInteger getPublicExponent();
    descriptor: ()Ljava/math/BigInteger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
         0: .line 159
            aload 0 /* this */
            getfield com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt.keySpec:Ljava/security/spec/RSAPrivateCrtKeySpec;
            invokevirtual java.security.spec.RSAPrivateCrtKeySpec.getPublicExponent:()Ljava/math/BigInteger;
            areturn
        end local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/security/ucrypto/NativeKey$RSAPrivateCrt;

  public java.math.BigInteger getPrivateExponent();
    descriptor: ()Ljava/math/BigInteger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
         0: .line 160
            aload 0 /* this */
            getfield com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt.keySpec:Ljava/security/spec/RSAPrivateCrtKeySpec;
            invokevirtual java.security.spec.RSAPrivateCrtKeySpec.getPrivateExponent:()Ljava/math/BigInteger;
            areturn
        end local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/security/ucrypto/NativeKey$RSAPrivateCrt;

  public java.math.BigInteger getPrimeP();
    descriptor: ()Ljava/math/BigInteger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
         0: .line 161
            aload 0 /* this */
            getfield com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt.keySpec:Ljava/security/spec/RSAPrivateCrtKeySpec;
            invokevirtual java.security.spec.RSAPrivateCrtKeySpec.getPrimeP:()Ljava/math/BigInteger;
            areturn
        end local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/security/ucrypto/NativeKey$RSAPrivateCrt;

  public java.math.BigInteger getPrimeQ();
    descriptor: ()Ljava/math/BigInteger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
         0: .line 162
            aload 0 /* this */
            getfield com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt.keySpec:Ljava/security/spec/RSAPrivateCrtKeySpec;
            invokevirtual java.security.spec.RSAPrivateCrtKeySpec.getPrimeQ:()Ljava/math/BigInteger;
            areturn
        end local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/security/ucrypto/NativeKey$RSAPrivateCrt;

  public java.math.BigInteger getPrimeExponentP();
    descriptor: ()Ljava/math/BigInteger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
         0: .line 163
            aload 0 /* this */
            getfield com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt.keySpec:Ljava/security/spec/RSAPrivateCrtKeySpec;
            invokevirtual java.security.spec.RSAPrivateCrtKeySpec.getPrimeExponentP:()Ljava/math/BigInteger;
            areturn
        end local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/security/ucrypto/NativeKey$RSAPrivateCrt;

  public java.math.BigInteger getPrimeExponentQ();
    descriptor: ()Ljava/math/BigInteger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
         0: .line 164
            aload 0 /* this */
            getfield com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt.keySpec:Ljava/security/spec/RSAPrivateCrtKeySpec;
            invokevirtual java.security.spec.RSAPrivateCrtKeySpec.getPrimeExponentQ:()Ljava/math/BigInteger;
            areturn
        end local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/security/ucrypto/NativeKey$RSAPrivateCrt;

  public java.math.BigInteger getCrtCoefficient();
    descriptor: ()Ljava/math/BigInteger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
         0: .line 165
            aload 0 /* this */
            getfield com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt.keySpec:Ljava/security/spec/RSAPrivateCrtKeySpec;
            invokevirtual java.security.spec.RSAPrivateCrtKeySpec.getCrtCoefficient:()Ljava/math/BigInteger;
            areturn
        end local 0 // com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/security/ucrypto/NativeKey$RSAPrivateCrt;

  private static native long nativeInit(byte[], byte[], byte[], byte[], byte[], byte[], byte[], byte[]);
    descriptor: ([B[B[B[B[B[B[B[B)J
    flags: (0x010a) ACC_PRIVATE, ACC_STATIC, ACC_NATIVE
    MethodParameters:
          Name  Flags
      mod       
      pubExp    
      privExp   
      p         
      q         
      expP      
      expQ      
      crtCoeff  
}
SourceFile: "NativeKey.java"
NestHost: com.oracle.security.ucrypto.NativeKey
InnerClasses:
  private KeyRef = com.oracle.security.ucrypto.NativeKey$KeyRef of com.oracle.security.ucrypto.NativeKey
  final RSAPrivateCrt = com.oracle.security.ucrypto.NativeKey$RSAPrivateCrt of com.oracle.security.ucrypto.NativeKey