class io.vertx.ext.jwt.CryptoKeyPair implements io.vertx.ext.jwt.Crypto
minor version: 0
major version: 59
flags: flags: (0x0020) ACC_SUPER
this_class: io.vertx.ext.jwt.CryptoKeyPair
super_class: java.lang.Object
{
private final java.lang.String id;
descriptor: Ljava/lang/String;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.security.Signature sig;
descriptor: Ljava/security/Signature;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.security.PublicKey publicKey;
descriptor: Ljava/security/PublicKey;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.security.PrivateKey privateKey;
descriptor: Ljava/security/PrivateKey;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final boolean ecdsa;
descriptor: Z
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final int ecdsaSignatureLength;
descriptor: I
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
void <init>(java.lang.String, java.security.PublicKey, java.security.PrivateKey);
descriptor: (Ljava/lang/String;Ljava/security/PublicKey;Ljava/security/PrivateKey;)V
flags: (0x0000)
Code:
stack=3, locals=6, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
invokestatic java.util.UUID.randomUUID:()Ljava/util/UUID;
invokevirtual java.util.UUID.toString:()Ljava/lang/String;
putfield io.vertx.ext.jwt.CryptoKeyPair.id:Ljava/lang/String;
2: aload 0
aload 2
putfield io.vertx.ext.jwt.CryptoKeyPair.publicKey:Ljava/security/PublicKey;
3: aload 0
aload 3
putfield io.vertx.ext.jwt.CryptoKeyPair.privateKey:Ljava/security/PrivateKey;
4: aload 0
aload 0
aload 1
invokevirtual io.vertx.ext.jwt.CryptoKeyPair.isECDSA:(Ljava/lang/String;)Z
putfield io.vertx.ext.jwt.CryptoKeyPair.ecdsa:Z
5: aload 0
aload 0
aload 1
invokevirtual io.vertx.ext.jwt.CryptoKeyPair.ECDSALength:(Ljava/lang/String;)I
putfield io.vertx.ext.jwt.CryptoKeyPair.ecdsaSignatureLength:I
6: aload 1
invokestatic java.security.Signature.getInstance:(Ljava/lang/String;)Ljava/security/Signature;
astore 4
start local 4 7: goto 10
end local 4 StackMap locals: io.vertx.ext.jwt.CryptoKeyPair java.lang.String java.security.PublicKey java.security.PrivateKey
StackMap stack: java.security.NoSuchAlgorithmException
8: astore 5
start local 5 9: new java.lang.RuntimeException
dup
aload 5
invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
athrow
end local 5 start local 4 10: StackMap locals: java.security.Signature
StackMap stack:
aload 0
aload 4
putfield io.vertx.ext.jwt.CryptoKeyPair.sig:Ljava/security/Signature;
11: return
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 this Lio/vertx/ext/jwt/CryptoKeyPair;
0 12 1 algorithm Ljava/lang/String;
0 12 2 publicKey Ljava/security/PublicKey;
0 12 3 privateKey Ljava/security/PrivateKey;
7 8 4 signature Ljava/security/Signature;
10 12 4 signature Ljava/security/Signature;
9 10 5 e Ljava/security/NoSuchAlgorithmException;
Exception table:
from to target type
6 7 8 Class java.security.NoSuchAlgorithmException
MethodParameters:
Name Flags
algorithm final
publicKey final
privateKey final
public java.lang.String getId();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield io.vertx.ext.jwt.CryptoKeyPair.id:Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lio/vertx/ext/jwt/CryptoKeyPair;
public synchronized byte[] sign(byte[]);
descriptor: ([B)[B
flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: aload 0
getfield io.vertx.ext.jwt.CryptoKeyPair.privateKey:Ljava/security/PrivateKey;
ifnonnull 2
1: new java.lang.RuntimeException
dup
ldc "Cannot sign (no private key)"
invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
aload 0
getfield io.vertx.ext.jwt.CryptoKeyPair.sig:Ljava/security/Signature;
aload 0
getfield io.vertx.ext.jwt.CryptoKeyPair.privateKey:Ljava/security/PrivateKey;
invokevirtual java.security.Signature.initSign:(Ljava/security/PrivateKey;)V
3: aload 0
getfield io.vertx.ext.jwt.CryptoKeyPair.sig:Ljava/security/Signature;
aload 1
invokevirtual java.security.Signature.update:([B)V
4: aload 0
getfield io.vertx.ext.jwt.CryptoKeyPair.ecdsa:Z
ifeq 7
5: aload 0
getfield io.vertx.ext.jwt.CryptoKeyPair.sig:Ljava/security/Signature;
invokevirtual java.security.Signature.sign:()[B
aload 0
getfield io.vertx.ext.jwt.CryptoKeyPair.ecdsaSignatureLength:I
invokestatic io.vertx.ext.jwt.impl.SignatureHelper.toJWS:([BI)[B
6: areturn
7: StackMap locals:
StackMap stack:
aload 0
getfield io.vertx.ext.jwt.CryptoKeyPair.sig:Ljava/security/Signature;
invokevirtual java.security.Signature.sign:()[B
8: areturn
9: StackMap locals:
StackMap stack: java.security.GeneralSecurityException
astore 2
start local 2 10: new java.lang.RuntimeException
dup
aload 2
invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
athrow
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lio/vertx/ext/jwt/CryptoKeyPair;
0 11 1 payload [B
10 11 2 e Ljava/security/GeneralSecurityException;
Exception table:
from to target type
2 6 9 Class java.security.SignatureException
7 8 9 Class java.security.SignatureException
2 6 9 Class java.security.InvalidKeyException
7 8 9 Class java.security.InvalidKeyException
MethodParameters:
Name Flags
payload
public synchronized boolean verify(byte[], byte[]);
descriptor: ([B[B)Z
flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
Code:
stack=3, locals=4, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield io.vertx.ext.jwt.CryptoKeyPair.publicKey:Ljava/security/PublicKey;
ifnonnull 2
1: new java.lang.RuntimeException
dup
ldc "Cannot verify (no public key)"
invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
aload 0
getfield io.vertx.ext.jwt.CryptoKeyPair.sig:Ljava/security/Signature;
aload 0
getfield io.vertx.ext.jwt.CryptoKeyPair.publicKey:Ljava/security/PublicKey;
invokevirtual java.security.Signature.initVerify:(Ljava/security/PublicKey;)V
3: aload 0
getfield io.vertx.ext.jwt.CryptoKeyPair.sig:Ljava/security/Signature;
aload 2
invokevirtual java.security.Signature.update:([B)V
4: aload 0
getfield io.vertx.ext.jwt.CryptoKeyPair.ecdsa:Z
ifeq 7
5: aload 0
getfield io.vertx.ext.jwt.CryptoKeyPair.sig:Ljava/security/Signature;
aload 1
invokestatic io.vertx.ext.jwt.impl.SignatureHelper.toDER:([B)[B
invokevirtual java.security.Signature.verify:([B)Z
6: ireturn
7: StackMap locals:
StackMap stack:
aload 0
getfield io.vertx.ext.jwt.CryptoKeyPair.sig:Ljava/security/Signature;
aload 1
invokevirtual java.security.Signature.verify:([B)Z
8: ireturn
9: StackMap locals:
StackMap stack: java.security.GeneralSecurityException
astore 3
start local 3 10: new java.lang.RuntimeException
dup
aload 3
invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
athrow
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lio/vertx/ext/jwt/CryptoKeyPair;
0 11 1 signature [B
0 11 2 payload [B
10 11 3 e Ljava/security/GeneralSecurityException;
Exception table:
from to target type
2 6 9 Class java.security.SignatureException
7 8 9 Class java.security.SignatureException
2 6 9 Class java.security.InvalidKeyException
7 8 9 Class java.security.InvalidKeyException
MethodParameters:
Name Flags
signature
payload
}
SourceFile: "Crypto.java"