final class sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher extends sun.security.ssl.SSLCipher$SSLReadCipher
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher
super_class: sun.security.ssl.SSLCipher$SSLReadCipher
{
private final javax.crypto.Cipher cipher;
descriptor: Ljavax/crypto/Cipher;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final int tagSize;
descriptor: I
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.security.Key key;
descriptor: Ljava/security/Key;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final byte[] iv;
descriptor: [B
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.security.SecureRandom random;
descriptor: Ljava/security/SecureRandom;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
void <init>(sun.security.ssl.Authenticator, sun.security.ssl.ProtocolVersion, sun.security.ssl.SSLCipher, java.lang.String, java.security.Key, java.security.spec.AlgorithmParameterSpec, java.security.SecureRandom);
descriptor: (Lsun/security/ssl/Authenticator;Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/SSLCipher;Ljava/lang/String;Ljava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
flags: (0x0000)
Code:
stack=3, locals=8, args_size=8
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 0: aload 0
aload 1
aload 2
invokespecial sun.security.ssl.SSLCipher$SSLReadCipher.<init>:(Lsun/security/ssl/Authenticator;Lsun/security/ssl/ProtocolVersion;)V
1: aload 0
aload 4
invokestatic sun.security.ssl.JsseJce.getCipher:(Ljava/lang/String;)Ljavax/crypto/Cipher;
putfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.cipher:Ljavax/crypto/Cipher;
2: aload 0
aload 3
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
pop
bipush 16
putfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.tagSize:I
3: aload 0
aload 5
putfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.key:Ljava/security/Key;
4: aload 0
aload 6
checkcast javax.crypto.spec.IvParameterSpec
invokevirtual javax.crypto.spec.IvParameterSpec.getIV:()[B
putfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.iv:[B
5: aload 0
aload 7
putfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.random:Ljava/security/SecureRandom;
6: return
end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lsun/security/ssl/SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher;
0 7 1 authenticator Lsun/security/ssl/Authenticator;
0 7 2 protocolVersion Lsun/security/ssl/ProtocolVersion;
0 7 3 sslCipher Lsun/security/ssl/SSLCipher;
0 7 4 algorithm Ljava/lang/String;
0 7 5 key Ljava/security/Key;
0 7 6 params Ljava/security/spec/AlgorithmParameterSpec;
0 7 7 random Ljava/security/SecureRandom;
Exceptions:
throws java.security.GeneralSecurityException
MethodParameters:
Name Flags
authenticator
protocolVersion
sslCipher
algorithm
key
params
random
public sun.security.ssl.Plaintext decrypt(byte, java.nio.ByteBuffer, byte[]);
descriptor: (BLjava/nio/ByteBuffer;[B)Lsun/security/ssl/Plaintext;
flags: (0x0001) ACC_PUBLIC
Code:
stack=9, locals=12, args_size=4
start local 0 start local 1 start local 2 start local 3 0: iload 1
getstatic sun.security.ssl.ContentType.CHANGE_CIPHER_SPEC:Lsun/security/ssl/ContentType;
getfield sun.security.ssl.ContentType.id:B
if_icmpne 5
1: new sun.security.ssl.Plaintext
dup
iload 1
2: getstatic sun.security.ssl.ProtocolVersion.NONE:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.major:B
getstatic sun.security.ssl.ProtocolVersion.NONE:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.minor:B
3: iconst_m1
ldc -1
aload 2
invokevirtual java.nio.ByteBuffer.slice:()Ljava/nio/ByteBuffer;
4: invokespecial sun.security.ssl.Plaintext.<init>:(BBBIJLjava/nio/ByteBuffer;)V
areturn
5: StackMap locals:
StackMap stack:
aload 2
invokevirtual java.nio.ByteBuffer.remaining:()I
aload 0
getfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.tagSize:I
if_icmpgt 12
6: new javax.crypto.BadPaddingException
dup
7: new java.lang.StringBuilder
dup
ldc "Insufficient buffer remaining for AEAD cipher fragment ("
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
8: aload 2
invokevirtual java.nio.ByteBuffer.remaining:()I
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
ldc "). Needs to be "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
9: ldc "more than tag size ("
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 0
getfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.tagSize:I
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
ldc ")"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
10: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
11: invokespecial javax.crypto.BadPaddingException.<init>:(Ljava/lang/String;)V
athrow
12: StackMap locals:
StackMap stack:
aload 3
astore 4
start local 4 13: aload 4
ifnonnull 15
14: aload 0
getfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.authenticator:Lsun/security/ssl/Authenticator;
invokevirtual sun.security.ssl.Authenticator.sequenceNumber:()[B
astore 4
15: StackMap locals: byte[]
StackMap stack:
aload 0
getfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.iv:[B
arraylength
newarray 8
astore 5
start local 5 16: aload 4
iconst_0
aload 5
aload 5
arraylength
aload 4
arraylength
isub
17: aload 4
arraylength
18: invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
19: iconst_0
istore 6
start local 6 20: goto 23
21: StackMap locals: byte[] int
StackMap stack:
aload 5
iload 6
dup2
baload
aload 0
getfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.iv:[B
iload 6
baload
ixor
i2b
bastore
22: iinc 6 1
StackMap locals:
StackMap stack:
23: iload 6
aload 5
arraylength
if_icmplt 21
end local 6 24: new javax.crypto.spec.IvParameterSpec
dup
aload 5
invokespecial javax.crypto.spec.IvParameterSpec.<init>:([B)V
astore 6
start local 6 25: aload 0
getfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.cipher:Ljavax/crypto/Cipher;
iconst_2
aload 0
getfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.key:Ljava/security/Key;
aload 6
aload 0
getfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.random:Ljava/security/SecureRandom;
invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
26: goto 31
27: StackMap locals: sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher int java.nio.ByteBuffer byte[] byte[] byte[] java.security.spec.AlgorithmParameterSpec
StackMap stack: java.security.GeneralSecurityException
astore 7
start local 7 28: new java.lang.RuntimeException
dup
29: ldc "invalid key or spec in AEAD mode"
aload 7
30: invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 7 31: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.authenticator:Lsun/security/ssl/Authenticator;
32: iload 1
aload 2
invokevirtual java.nio.ByteBuffer.remaining:()I
aload 4
33: invokevirtual sun.security.ssl.Authenticator.acquireAuthenticationBytes:(BI[B)[B
astore 7
start local 7 34: aload 0
getfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.cipher:Ljavax/crypto/Cipher;
aload 7
invokevirtual javax.crypto.Cipher.updateAAD:([B)V
35: aload 2
invokevirtual java.nio.ByteBuffer.remaining:()I
istore 8
start local 8 36: aload 2
invokevirtual java.nio.ByteBuffer.position:()I
istore 9
start local 9 37: aload 2
invokevirtual java.nio.ByteBuffer.duplicate:()Ljava/nio/ByteBuffer;
astore 10
start local 10 38: aload 0
getfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.cipher:Ljavax/crypto/Cipher;
aload 10
aload 2
invokevirtual javax.crypto.Cipher.doFinal:(Ljava/nio/ByteBuffer;Ljava/nio/ByteBuffer;)I
istore 8
39: goto 50
StackMap locals: sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher int java.nio.ByteBuffer byte[] byte[] byte[] java.security.spec.AlgorithmParameterSpec byte[] int int java.nio.ByteBuffer
StackMap stack: javax.crypto.IllegalBlockSizeException
40: astore 11
start local 11 41: new java.lang.RuntimeException
dup
42: new java.lang.StringBuilder
dup
ldc "Cipher error in AEAD mode \""
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 11
invokevirtual javax.crypto.IllegalBlockSizeException.getMessage:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
43: ldc " \"in JCE provider "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 0
getfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.cipher:Ljavax/crypto/Cipher;
invokevirtual javax.crypto.Cipher.getProvider:()Ljava/security/Provider;
invokevirtual java.security.Provider.getName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
44: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
45: invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
athrow
end local 11 46: StackMap locals:
StackMap stack: javax.crypto.ShortBufferException
astore 11
start local 11 47: new java.lang.RuntimeException
dup
new java.lang.StringBuilder
dup
ldc "Cipher buffering error in JCE provider "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
48: aload 0
getfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.cipher:Ljavax/crypto/Cipher;
invokevirtual javax.crypto.Cipher.getProvider:()Ljava/security/Provider;
invokevirtual java.security.Provider.getName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
aload 11
49: invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 11 50: StackMap locals:
StackMap stack:
aload 2
iload 9
invokevirtual java.nio.ByteBuffer.position:(I)Ljava/nio/ByteBuffer;
pop
51: aload 2
iload 9
iload 8
iadd
invokevirtual java.nio.ByteBuffer.limit:(I)Ljava/nio/ByteBuffer;
pop
52: aload 2
invokevirtual java.nio.ByteBuffer.limit:()I
iconst_1
isub
istore 11
start local 11 53: goto 55
StackMap locals: int
StackMap stack:
54: iinc 11 -1
StackMap locals:
StackMap stack:
55: iload 11
ifle 56
aload 2
iload 11
invokevirtual java.nio.ByteBuffer.get:(I)B
ifeq 54
56: StackMap locals:
StackMap stack:
iload 11
iload 9
iconst_1
iadd
if_icmpge 60
57: new javax.crypto.BadPaddingException
dup
58: ldc "Incorrect inner plaintext: no content type"
59: invokespecial javax.crypto.BadPaddingException.<init>:(Ljava/lang/String;)V
athrow
60: StackMap locals:
StackMap stack:
aload 2
iload 11
invokevirtual java.nio.ByteBuffer.get:(I)B
istore 1
61: aload 2
iload 11
invokevirtual java.nio.ByteBuffer.limit:(I)Ljava/nio/ByteBuffer;
pop
62: getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 65
ldc "plaintext"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 65
63: ldc "Plaintext after DECRYPTION"
iconst_1
anewarray java.lang.Object
dup
iconst_0
aload 2
invokevirtual java.nio.ByteBuffer.duplicate:()Ljava/nio/ByteBuffer;
aastore
64: invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
65: StackMap locals:
StackMap stack:
new sun.security.ssl.Plaintext
dup
iload 1
66: getstatic sun.security.ssl.ProtocolVersion.NONE:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.major:B
getstatic sun.security.ssl.ProtocolVersion.NONE:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.minor:B
67: iconst_m1
ldc -1
aload 2
invokevirtual java.nio.ByteBuffer.slice:()Ljava/nio/ByteBuffer;
68: invokespecial sun.security.ssl.Plaintext.<init>:(BBBIJLjava/nio/ByteBuffer;)V
areturn
end local 11 end local 10 end local 9 end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 69 0 this Lsun/security/ssl/SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher;
0 69 1 contentType B
0 69 2 bb Ljava/nio/ByteBuffer;
0 69 3 sequence [B
13 69 4 sn [B
16 69 5 nonce [B
20 24 6 i I
25 69 6 spec Ljava/security/spec/AlgorithmParameterSpec;
28 31 7 ikae Ljava/security/GeneralSecurityException;
34 69 7 aad [B
36 69 8 len I
37 69 9 pos I
38 69 10 dup Ljava/nio/ByteBuffer;
41 46 11 ibse Ljavax/crypto/IllegalBlockSizeException;
47 50 11 sbe Ljavax/crypto/ShortBufferException;
53 69 11 i I
Exception table:
from to target type
25 26 27 Class java.security.InvalidKeyException
25 26 27 Class java.security.InvalidAlgorithmParameterException
38 39 40 Class javax.crypto.IllegalBlockSizeException
38 39 46 Class javax.crypto.ShortBufferException
Exceptions:
throws java.security.GeneralSecurityException
MethodParameters:
Name Flags
contentType
bb
sequence
void dispose();
descriptor: ()V
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.cipher:Ljavax/crypto/Cipher;
ifnull 4
1: aload 0
getfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.cipher:Ljavax/crypto/Cipher;
invokevirtual javax.crypto.Cipher.doFinal:()[B
pop
2: goto 4
StackMap locals:
StackMap stack: java.lang.Exception
3: pop
4: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lsun/security/ssl/SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher;
Exception table:
from to target type
1 2 3 Class java.lang.Exception
int estimateFragmentSize(int, int);
descriptor: (II)I
flags: (0x0000)
Code:
stack=2, locals=3, args_size=3
start local 0 start local 1 start local 2 0: iload 1
iload 2
isub
aload 0
getfield sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher.tagSize:I
isub
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher;
0 1 1 packetSize I
0 1 2 headerSize I
MethodParameters:
Name Flags
packetSize
headerSize
}
SourceFile: "SSLCipher.java"
NestHost: sun.security.ssl.SSLCipher
InnerClasses:
abstract SSLReadCipher = sun.security.ssl.SSLCipher$SSLReadCipher of sun.security.ssl.SSLCipher
private final T13CC20P1305ReadCipherGenerator = sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator of sun.security.ssl.SSLCipher
final CC20P1305ReadCipher = sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator$CC20P1305ReadCipher of sun.security.ssl.SSLCipher$T13CC20P1305ReadCipherGenerator