abstract class sun.security.ssl.HandshakeContext implements sun.security.ssl.ConnectionContext
minor version: 0
major version: 59
flags: flags: (0x0420) ACC_SUPER, ACC_ABSTRACT
this_class: sun.security.ssl.HandshakeContext
super_class: java.lang.Object
{
static final boolean allowUnsafeRenegotiation;
descriptor: Z
flags: (0x0018) ACC_STATIC, ACC_FINAL
static final boolean allowLegacyHelloMessages;
descriptor: Z
flags: (0x0018) ACC_STATIC, ACC_FINAL
java.util.LinkedHashMap<java.lang.Byte, sun.security.ssl.SSLConsumer> handshakeConsumers;
descriptor: Ljava/util/LinkedHashMap;
flags: (0x0000)
Signature: Ljava/util/LinkedHashMap<Ljava/lang/Byte;Lsun/security/ssl/SSLConsumer;>;
final java.util.HashMap<java.lang.Byte, sun.security.ssl.HandshakeProducer> handshakeProducers;
descriptor: Ljava/util/HashMap;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/HashMap<Ljava/lang/Byte;Lsun/security/ssl/HandshakeProducer;>;
final sun.security.ssl.SSLContextImpl sslContext;
descriptor: Lsun/security/ssl/SSLContextImpl;
flags: (0x0010) ACC_FINAL
final sun.security.ssl.TransportContext conContext;
descriptor: Lsun/security/ssl/TransportContext;
flags: (0x0010) ACC_FINAL
final sun.security.ssl.SSLConfiguration sslConfig;
descriptor: Lsun/security/ssl/SSLConfiguration;
flags: (0x0010) ACC_FINAL
final java.util.List<sun.security.ssl.ProtocolVersion> activeProtocols;
descriptor: Ljava/util/List;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
final java.util.List<sun.security.ssl.CipherSuite> activeCipherSuites;
descriptor: Ljava/util/List;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
final java.security.AlgorithmConstraints algorithmConstraints;
descriptor: Ljava/security/AlgorithmConstraints;
flags: (0x0010) ACC_FINAL
final sun.security.ssl.ProtocolVersion maximumActiveProtocol;
descriptor: Lsun/security/ssl/ProtocolVersion;
flags: (0x0010) ACC_FINAL
final sun.security.ssl.HandshakeOutStream handshakeOutput;
descriptor: Lsun/security/ssl/HandshakeOutStream;
flags: (0x0010) ACC_FINAL
final sun.security.ssl.HandshakeHash handshakeHash;
descriptor: Lsun/security/ssl/HandshakeHash;
flags: (0x0010) ACC_FINAL
sun.security.ssl.SSLSessionImpl handshakeSession;
descriptor: Lsun/security/ssl/SSLSessionImpl;
flags: (0x0000)
boolean handshakeFinished;
descriptor: Z
flags: (0x0000)
boolean kickstartMessageDelivered;
descriptor: Z
flags: (0x0000)
boolean isResumption;
descriptor: Z
flags: (0x0000)
sun.security.ssl.SSLSessionImpl resumingSession;
descriptor: Lsun/security/ssl/SSLSessionImpl;
flags: (0x0000)
boolean statelessResumption;
descriptor: Z
flags: (0x0000)
final java.util.Queue<java.util.Map$Entry<java.lang.Byte, java.nio.ByteBuffer>> delegatedActions;
descriptor: Ljava/util/Queue;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/Queue<Ljava/util/Map$Entry<Ljava/lang/Byte;Ljava/nio/ByteBuffer;>;>;
volatile boolean taskDelegated;
descriptor: Z
flags: (0x0040) ACC_VOLATILE
volatile java.lang.Exception delegatedThrown;
descriptor: Ljava/lang/Exception;
flags: (0x0040) ACC_VOLATILE
sun.security.ssl.ProtocolVersion negotiatedProtocol;
descriptor: Lsun/security/ssl/ProtocolVersion;
flags: (0x0000)
sun.security.ssl.CipherSuite negotiatedCipherSuite;
descriptor: Lsun/security/ssl/CipherSuite;
flags: (0x0000)
final java.util.List<sun.security.ssl.SSLPossession> handshakePossessions;
descriptor: Ljava/util/List;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/List<Lsun/security/ssl/SSLPossession;>;
final java.util.List<sun.security.ssl.SSLCredentials> handshakeCredentials;
descriptor: Ljava/util/List;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/List<Lsun/security/ssl/SSLCredentials;>;
sun.security.ssl.SSLKeyDerivation handshakeKeyDerivation;
descriptor: Lsun/security/ssl/SSLKeyDerivation;
flags: (0x0000)
sun.security.ssl.SSLKeyExchange handshakeKeyExchange;
descriptor: Lsun/security/ssl/SSLKeyExchange;
flags: (0x0000)
javax.crypto.SecretKey baseReadSecret;
descriptor: Ljavax/crypto/SecretKey;
flags: (0x0000)
javax.crypto.SecretKey baseWriteSecret;
descriptor: Ljavax/crypto/SecretKey;
flags: (0x0000)
int clientHelloVersion;
descriptor: I
flags: (0x0000)
java.lang.String applicationProtocol;
descriptor: Ljava/lang/String;
flags: (0x0000)
sun.security.ssl.RandomCookie clientHelloRandom;
descriptor: Lsun/security/ssl/RandomCookie;
flags: (0x0000)
sun.security.ssl.RandomCookie serverHelloRandom;
descriptor: Lsun/security/ssl/RandomCookie;
flags: (0x0000)
byte[] certRequestContext;
descriptor: [B
flags: (0x0000)
final java.util.Map<sun.security.ssl.SSLExtension, sun.security.ssl.SSLExtension$SSLExtensionSpec> handshakeExtensions;
descriptor: Ljava/util/Map;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/Map<Lsun/security/ssl/SSLExtension;Lsun/security/ssl/SSLExtension$SSLExtensionSpec;>;
int maxFragmentLength;
descriptor: I
flags: (0x0000)
java.util.List<sun.security.ssl.SignatureScheme> localSupportedSignAlgs;
descriptor: Ljava/util/List;
flags: (0x0000)
Signature: Ljava/util/List<Lsun/security/ssl/SignatureScheme;>;
java.util.List<sun.security.ssl.SignatureScheme> peerRequestedSignatureSchemes;
descriptor: Ljava/util/List;
flags: (0x0000)
Signature: Ljava/util/List<Lsun/security/ssl/SignatureScheme;>;
java.util.List<sun.security.ssl.SignatureScheme> peerRequestedCertSignSchemes;
descriptor: Ljava/util/List;
flags: (0x0000)
Signature: Ljava/util/List<Lsun/security/ssl/SignatureScheme;>;
javax.security.auth.x500.X500Principal[] peerSupportedAuthorities;
descriptor: [Ljavax/security/auth/x500/X500Principal;
flags: (0x0000)
java.util.List<sun.security.ssl.NamedGroup> clientRequestedNamedGroups;
descriptor: Ljava/util/List;
flags: (0x0000)
Signature: Ljava/util/List<Lsun/security/ssl/NamedGroup;>;
sun.security.ssl.NamedGroup serverSelectedNamedGroup;
descriptor: Lsun/security/ssl/NamedGroup;
flags: (0x0000)
java.util.List<javax.net.ssl.SNIServerName> requestedServerNames;
descriptor: Ljava/util/List;
flags: (0x0000)
Signature: Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;
javax.net.ssl.SNIServerName negotiatedServerName;
descriptor: Ljavax/net/ssl/SNIServerName;
flags: (0x0000)
boolean staplingActive;
descriptor: Z
flags: (0x0000)
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=2, locals=0, args_size=0
0: ldc "sun.security.ssl.allowUnsafeRenegotiation"
iconst_0
1: invokestatic sun.security.ssl.Utilities.getBooleanProperty:(Ljava/lang/String;Z)Z
2: putstatic sun.security.ssl.HandshakeContext.allowUnsafeRenegotiation:Z
3: ldc "sun.security.ssl.allowLegacyHelloMessages"
iconst_1
4: invokestatic sun.security.ssl.Utilities.getBooleanProperty:(Ljava/lang/String;Z)Z
5: putstatic sun.security.ssl.HandshakeContext.allowLegacyHelloMessages:Z
6: return
LocalVariableTable:
Start End Slot Name Signature
protected void <init>(sun.security.ssl.SSLContextImpl, sun.security.ssl.TransportContext);
descriptor: (Lsun/security/ssl/SSLContextImpl;Lsun/security/ssl/TransportContext;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=4, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
iconst_0
putfield sun.security.ssl.HandshakeContext.statelessResumption:Z
2: aload 0
iconst_0
putfield sun.security.ssl.HandshakeContext.taskDelegated:Z
3: aload 0
aconst_null
putfield sun.security.ssl.HandshakeContext.delegatedThrown:Ljava/lang/Exception;
4: aload 0
aconst_null
putfield sun.security.ssl.HandshakeContext.peerSupportedAuthorities:[Ljavax/security/auth/x500/X500Principal;
5: aload 0
iconst_0
putfield sun.security.ssl.HandshakeContext.staplingActive:Z
6: aload 0
aload 1
putfield sun.security.ssl.HandshakeContext.sslContext:Lsun/security/ssl/SSLContextImpl;
7: aload 0
aload 2
putfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
8: aload 0
aload 2
getfield sun.security.ssl.TransportContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
invokevirtual sun.security.ssl.SSLConfiguration.clone:()Ljava/lang/Object;
checkcast sun.security.ssl.SSLConfiguration
putfield sun.security.ssl.HandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
9: aload 0
new sun.security.ssl.SSLAlgorithmConstraints
dup
10: aload 0
getfield sun.security.ssl.HandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
getfield sun.security.ssl.SSLConfiguration.userSpecifiedAlgorithmConstraints:Ljava/security/AlgorithmConstraints;
invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljava/security/AlgorithmConstraints;)V
11: putfield sun.security.ssl.HandshakeContext.algorithmConstraints:Ljava/security/AlgorithmConstraints;
12: aload 0
aload 0
getfield sun.security.ssl.HandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
getfield sun.security.ssl.SSLConfiguration.enabledProtocols:Ljava/util/List;
13: aload 0
getfield sun.security.ssl.HandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
getfield sun.security.ssl.SSLConfiguration.enabledCipherSuites:Ljava/util/List;
aload 0
getfield sun.security.ssl.HandshakeContext.algorithmConstraints:Ljava/security/AlgorithmConstraints;
14: invokestatic sun.security.ssl.HandshakeContext.getActiveProtocols:(Ljava/util/List;Ljava/util/List;Ljava/security/AlgorithmConstraints;)Ljava/util/List;
putfield sun.security.ssl.HandshakeContext.activeProtocols:Ljava/util/List;
15: aload 0
getfield sun.security.ssl.HandshakeContext.activeProtocols:Ljava/util/List;
invokeinterface java.util.List.isEmpty:()Z
ifeq 19
16: new javax.net.ssl.SSLHandshakeException
dup
17: ldc "No appropriate protocol (protocol is disabled or cipher suites are inappropriate)"
18: invokespecial javax.net.ssl.SSLHandshakeException.<init>:(Ljava/lang/String;)V
athrow
19: StackMap locals: sun.security.ssl.HandshakeContext sun.security.ssl.SSLContextImpl sun.security.ssl.TransportContext
StackMap stack:
getstatic sun.security.ssl.ProtocolVersion.NONE:Lsun/security/ssl/ProtocolVersion;
astore 3
start local 3 20: aload 0
getfield sun.security.ssl.HandshakeContext.activeProtocols:Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 5
goto 25
StackMap locals: sun.security.ssl.HandshakeContext sun.security.ssl.SSLContextImpl sun.security.ssl.TransportContext sun.security.ssl.ProtocolVersion top java.util.Iterator
StackMap stack:
21: aload 5
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast sun.security.ssl.ProtocolVersion
astore 4
start local 4 22: aload 3
getstatic sun.security.ssl.ProtocolVersion.NONE:Lsun/security/ssl/ProtocolVersion;
if_acmpeq 24
23: aload 4
aload 3
invokevirtual sun.security.ssl.ProtocolVersion.compare:(Lsun/security/ssl/ProtocolVersion;)I
ifle 25
24: StackMap locals: sun.security.ssl.HandshakeContext sun.security.ssl.SSLContextImpl sun.security.ssl.TransportContext sun.security.ssl.ProtocolVersion sun.security.ssl.ProtocolVersion java.util.Iterator
StackMap stack:
aload 4
astore 3
end local 4 25: StackMap locals: sun.security.ssl.HandshakeContext sun.security.ssl.SSLContextImpl sun.security.ssl.TransportContext sun.security.ssl.ProtocolVersion top java.util.Iterator
StackMap stack:
aload 5
invokeinterface java.util.Iterator.hasNext:()Z
ifne 21
26: aload 0
aload 3
putfield sun.security.ssl.HandshakeContext.maximumActiveProtocol:Lsun/security/ssl/ProtocolVersion;
27: aload 0
aload 0
getfield sun.security.ssl.HandshakeContext.activeProtocols:Ljava/util/List;
28: aload 0
getfield sun.security.ssl.HandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
getfield sun.security.ssl.SSLConfiguration.enabledCipherSuites:Ljava/util/List;
aload 0
getfield sun.security.ssl.HandshakeContext.algorithmConstraints:Ljava/security/AlgorithmConstraints;
29: invokestatic sun.security.ssl.HandshakeContext.getActiveCipherSuites:(Ljava/util/List;Ljava/util/List;Ljava/security/AlgorithmConstraints;)Ljava/util/List;
putfield sun.security.ssl.HandshakeContext.activeCipherSuites:Ljava/util/List;
30: aload 0
getfield sun.security.ssl.HandshakeContext.activeCipherSuites:Ljava/util/List;
invokeinterface java.util.List.isEmpty:()Z
ifeq 32
31: new javax.net.ssl.SSLHandshakeException
dup
ldc "No appropriate cipher suite"
invokespecial javax.net.ssl.SSLHandshakeException.<init>:(Ljava/lang/String;)V
athrow
32: StackMap locals: sun.security.ssl.HandshakeContext sun.security.ssl.SSLContextImpl sun.security.ssl.TransportContext sun.security.ssl.ProtocolVersion
StackMap stack:
aload 0
new java.util.LinkedHashMap
dup
invokespecial java.util.LinkedHashMap.<init>:()V
putfield sun.security.ssl.HandshakeContext.handshakeConsumers:Ljava/util/LinkedHashMap;
33: aload 0
new java.util.HashMap
dup
invokespecial java.util.HashMap.<init>:()V
putfield sun.security.ssl.HandshakeContext.handshakeProducers:Ljava/util/HashMap;
34: aload 0
aload 2
getfield sun.security.ssl.TransportContext.inputRecord:Lsun/security/ssl/InputRecord;
getfield sun.security.ssl.InputRecord.handshakeHash:Lsun/security/ssl/HandshakeHash;
putfield sun.security.ssl.HandshakeContext.handshakeHash:Lsun/security/ssl/HandshakeHash;
35: aload 0
new sun.security.ssl.HandshakeOutStream
dup
aload 2
getfield sun.security.ssl.TransportContext.outputRecord:Lsun/security/ssl/OutputRecord;
invokespecial sun.security.ssl.HandshakeOutStream.<init>:(Lsun/security/ssl/OutputRecord;)V
putfield sun.security.ssl.HandshakeContext.handshakeOutput:Lsun/security/ssl/HandshakeOutStream;
36: aload 0
iconst_0
putfield sun.security.ssl.HandshakeContext.handshakeFinished:Z
37: aload 0
iconst_0
putfield sun.security.ssl.HandshakeContext.kickstartMessageDelivered:Z
38: aload 0
new java.util.LinkedList
dup
invokespecial java.util.LinkedList.<init>:()V
putfield sun.security.ssl.HandshakeContext.delegatedActions:Ljava/util/Queue;
39: aload 0
new java.util.HashMap
dup
invokespecial java.util.HashMap.<init>:()V
putfield sun.security.ssl.HandshakeContext.handshakeExtensions:Ljava/util/Map;
40: aload 0
new java.util.LinkedList
dup
invokespecial java.util.LinkedList.<init>:()V
putfield sun.security.ssl.HandshakeContext.handshakePossessions:Ljava/util/List;
41: aload 0
new java.util.LinkedList
dup
invokespecial java.util.LinkedList.<init>:()V
putfield sun.security.ssl.HandshakeContext.handshakeCredentials:Ljava/util/List;
42: aload 0
aconst_null
putfield sun.security.ssl.HandshakeContext.requestedServerNames:Ljava/util/List;
43: aload 0
aconst_null
putfield sun.security.ssl.HandshakeContext.negotiatedServerName:Ljavax/net/ssl/SNIServerName;
44: aload 0
aload 2
getfield sun.security.ssl.TransportContext.cipherSuite:Lsun/security/ssl/CipherSuite;
putfield sun.security.ssl.HandshakeContext.negotiatedCipherSuite:Lsun/security/ssl/CipherSuite;
45: aload 0
invokevirtual sun.security.ssl.HandshakeContext.initialize:()V
46: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 47 0 this Lsun/security/ssl/HandshakeContext;
0 47 1 sslContext Lsun/security/ssl/SSLContextImpl;
0 47 2 conContext Lsun/security/ssl/TransportContext;
20 47 3 maximumVersion Lsun/security/ssl/ProtocolVersion;
22 25 4 pv Lsun/security/ssl/ProtocolVersion;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
sslContext
conContext
protected void <init>(sun.security.ssl.TransportContext);
descriptor: (Lsun/security/ssl/TransportContext;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
iconst_0
putfield sun.security.ssl.HandshakeContext.statelessResumption:Z
2: aload 0
iconst_0
putfield sun.security.ssl.HandshakeContext.taskDelegated:Z
3: aload 0
aconst_null
putfield sun.security.ssl.HandshakeContext.delegatedThrown:Ljava/lang/Exception;
4: aload 0
aconst_null
putfield sun.security.ssl.HandshakeContext.peerSupportedAuthorities:[Ljavax/security/auth/x500/X500Principal;
5: aload 0
iconst_0
putfield sun.security.ssl.HandshakeContext.staplingActive:Z
6: aload 0
aload 1
getfield sun.security.ssl.TransportContext.sslContext:Lsun/security/ssl/SSLContextImpl;
putfield sun.security.ssl.HandshakeContext.sslContext:Lsun/security/ssl/SSLContextImpl;
7: aload 0
aload 1
putfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
8: aload 0
aload 1
getfield sun.security.ssl.TransportContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
putfield sun.security.ssl.HandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
9: aload 0
aload 1
getfield sun.security.ssl.TransportContext.protocolVersion:Lsun/security/ssl/ProtocolVersion;
putfield sun.security.ssl.HandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
10: aload 0
aload 1
getfield sun.security.ssl.TransportContext.cipherSuite:Lsun/security/ssl/CipherSuite;
putfield sun.security.ssl.HandshakeContext.negotiatedCipherSuite:Lsun/security/ssl/CipherSuite;
11: aload 0
new sun.security.ssl.HandshakeOutStream
dup
aload 1
getfield sun.security.ssl.TransportContext.outputRecord:Lsun/security/ssl/OutputRecord;
invokespecial sun.security.ssl.HandshakeOutStream.<init>:(Lsun/security/ssl/OutputRecord;)V
putfield sun.security.ssl.HandshakeContext.handshakeOutput:Lsun/security/ssl/HandshakeOutStream;
12: aload 0
new java.util.LinkedList
dup
invokespecial java.util.LinkedList.<init>:()V
putfield sun.security.ssl.HandshakeContext.delegatedActions:Ljava/util/Queue;
13: aload 0
new java.util.LinkedHashMap
dup
invokespecial java.util.LinkedHashMap.<init>:()V
putfield sun.security.ssl.HandshakeContext.handshakeConsumers:Ljava/util/LinkedHashMap;
14: aload 0
aconst_null
putfield sun.security.ssl.HandshakeContext.handshakeProducers:Ljava/util/HashMap;
15: aload 0
aconst_null
putfield sun.security.ssl.HandshakeContext.handshakeHash:Lsun/security/ssl/HandshakeHash;
16: aload 0
aconst_null
putfield sun.security.ssl.HandshakeContext.activeProtocols:Ljava/util/List;
17: aload 0
aconst_null
putfield sun.security.ssl.HandshakeContext.activeCipherSuites:Ljava/util/List;
18: aload 0
aconst_null
putfield sun.security.ssl.HandshakeContext.algorithmConstraints:Ljava/security/AlgorithmConstraints;
19: aload 0
aconst_null
putfield sun.security.ssl.HandshakeContext.maximumActiveProtocol:Lsun/security/ssl/ProtocolVersion;
20: aload 0
invokestatic java.util.Collections.emptyMap:()Ljava/util/Map;
putfield sun.security.ssl.HandshakeContext.handshakeExtensions:Ljava/util/Map;
21: aload 0
aconst_null
putfield sun.security.ssl.HandshakeContext.handshakePossessions:Ljava/util/List;
22: aload 0
aconst_null
putfield sun.security.ssl.HandshakeContext.handshakeCredentials:Ljava/util/List;
23: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 24 0 this Lsun/security/ssl/HandshakeContext;
0 24 1 conContext Lsun/security/ssl/TransportContext;
MethodParameters:
Name Flags
conContext
private void initialize();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=3, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getfield sun.security.ssl.TransportContext.isNegotiated:Z
ifeq 4
1: aload 0
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getfield sun.security.ssl.TransportContext.protocolVersion:Lsun/security/ssl/ProtocolVersion;
astore 1
start local 1 2: aload 0
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getfield sun.security.ssl.TransportContext.protocolVersion:Lsun/security/ssl/ProtocolVersion;
astore 2
start local 2 3: goto 13
end local 2 end local 1 4: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.HandshakeContext.activeProtocols:Ljava/util/List;
getstatic sun.security.ssl.ProtocolVersion.SSL20Hello:Lsun/security/ssl/ProtocolVersion;
invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
ifeq 11
5: getstatic sun.security.ssl.ProtocolVersion.SSL20Hello:Lsun/security/ssl/ProtocolVersion;
astore 1
start local 1 6: aload 0
getfield sun.security.ssl.HandshakeContext.maximumActiveProtocol:Lsun/security/ssl/ProtocolVersion;
invokevirtual sun.security.ssl.ProtocolVersion.useTLS13PlusSpec:()Z
ifeq 9
7: aload 0
getfield sun.security.ssl.HandshakeContext.maximumActiveProtocol:Lsun/security/ssl/ProtocolVersion;
astore 2
start local 2 8: goto 13
end local 2 9: StackMap locals: sun.security.ssl.ProtocolVersion
StackMap stack:
getstatic sun.security.ssl.ProtocolVersion.SSL20Hello:Lsun/security/ssl/ProtocolVersion;
astore 2
start local 2 10: goto 13
end local 2 end local 1 11: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.HandshakeContext.maximumActiveProtocol:Lsun/security/ssl/ProtocolVersion;
astore 1
start local 1 12: aload 0
getfield sun.security.ssl.HandshakeContext.maximumActiveProtocol:Lsun/security/ssl/ProtocolVersion;
astore 2
start local 2 13: StackMap locals: sun.security.ssl.ProtocolVersion sun.security.ssl.ProtocolVersion
StackMap stack:
aload 0
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getfield sun.security.ssl.TransportContext.inputRecord:Lsun/security/ssl/InputRecord;
aload 1
invokevirtual sun.security.ssl.InputRecord.setHelloVersion:(Lsun/security/ssl/ProtocolVersion;)V
14: aload 0
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getfield sun.security.ssl.TransportContext.outputRecord:Lsun/security/ssl/OutputRecord;
aload 2
invokevirtual sun.security.ssl.OutputRecord.setHelloVersion:(Lsun/security/ssl/ProtocolVersion;)V
15: aload 0
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getfield sun.security.ssl.TransportContext.isNegotiated:Z
ifne 17
16: aload 0
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
aload 0
getfield sun.security.ssl.HandshakeContext.maximumActiveProtocol:Lsun/security/ssl/ProtocolVersion;
putfield sun.security.ssl.TransportContext.protocolVersion:Lsun/security/ssl/ProtocolVersion;
17: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getfield sun.security.ssl.TransportContext.outputRecord:Lsun/security/ssl/OutputRecord;
aload 0
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getfield sun.security.ssl.TransportContext.protocolVersion:Lsun/security/ssl/ProtocolVersion;
invokevirtual sun.security.ssl.OutputRecord.setVersion:(Lsun/security/ssl/ProtocolVersion;)V
18: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 19 0 this Lsun/security/ssl/HandshakeContext;
2 4 1 inputHelloVersion Lsun/security/ssl/ProtocolVersion;
6 11 1 inputHelloVersion Lsun/security/ssl/ProtocolVersion;
12 19 1 inputHelloVersion Lsun/security/ssl/ProtocolVersion;
3 4 2 outputHelloVersion Lsun/security/ssl/ProtocolVersion;
8 9 2 outputHelloVersion Lsun/security/ssl/ProtocolVersion;
10 11 2 outputHelloVersion Lsun/security/ssl/ProtocolVersion;
13 19 2 outputHelloVersion Lsun/security/ssl/ProtocolVersion;
private static java.util.List<sun.security.ssl.ProtocolVersion> getActiveProtocols(java.util.List<sun.security.ssl.ProtocolVersion>, java.util.List<sun.security.ssl.CipherSuite>, java.security.AlgorithmConstraints);
descriptor: (Ljava/util/List;Ljava/util/List;Ljava/security/AlgorithmConstraints;)Ljava/util/List;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=4, locals=11, args_size=3
start local 0 start local 1 start local 2 0: iconst_0
istore 3
start local 3 1: new java.util.ArrayList
dup
iconst_4
invokespecial java.util.ArrayList.<init>:(I)V
astore 4
start local 4 2: aload 0
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 6
goto 35
StackMap locals: java.util.List java.util.List java.security.AlgorithmConstraints int java.util.ArrayList top java.util.Iterator
StackMap stack:
3: aload 6
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast sun.security.ssl.ProtocolVersion
astore 5
start local 5 4: iload 3
ifne 7
aload 5
getstatic sun.security.ssl.ProtocolVersion.SSL20Hello:Lsun/security/ssl/ProtocolVersion;
if_acmpne 7
5: iconst_1
istore 3
6: goto 35
7: StackMap locals: java.util.List java.util.List java.security.AlgorithmConstraints int java.util.ArrayList sun.security.ssl.ProtocolVersion java.util.Iterator
StackMap stack:
aload 2
8: getstatic java.security.CryptoPrimitive.KEY_AGREEMENT:Ljava/security/CryptoPrimitive;
invokestatic java.util.EnumSet.of:(Ljava/lang/Enum;)Ljava/util/EnumSet;
9: aload 5
getfield sun.security.ssl.ProtocolVersion.name:Ljava/lang/String;
aconst_null
10: invokeinterface java.security.AlgorithmConstraints.permits:(Ljava/util/Set;Ljava/lang/String;Ljava/security/AlgorithmParameters;)Z
11: ifne 13
12: goto 35
13: StackMap locals:
StackMap stack:
iconst_0
istore 7
start local 7 14: new java.util.EnumMap
dup
ldc Lsun/security/ssl/NamedGroup$NamedGroupType;
invokespecial java.util.EnumMap.<init>:(Ljava/lang/Class;)V
15: astore 8
start local 8 16: aload 1
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 10
goto 31
StackMap locals: java.util.List java.util.List java.security.AlgorithmConstraints int java.util.ArrayList sun.security.ssl.ProtocolVersion java.util.Iterator int java.util.Map top java.util.Iterator
StackMap stack:
17: aload 10
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast sun.security.ssl.CipherSuite
astore 9
start local 9 18: aload 9
invokevirtual sun.security.ssl.CipherSuite.isAvailable:()Z
ifeq 26
aload 9
aload 5
invokevirtual sun.security.ssl.CipherSuite.supports:(Lsun/security/ssl/ProtocolVersion;)Z
ifeq 26
19: aload 9
20: aload 2
aload 8
21: invokestatic sun.security.ssl.HandshakeContext.isActivatable:(Lsun/security/ssl/CipherSuite;Ljava/security/AlgorithmConstraints;Ljava/util/Map;)Z
22: ifeq 31
23: aload 4
aload 5
invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
pop
24: iconst_1
istore 7
25: goto 32
26: StackMap locals: java.util.List java.util.List java.security.AlgorithmConstraints int java.util.ArrayList sun.security.ssl.ProtocolVersion java.util.Iterator int java.util.Map sun.security.ssl.CipherSuite java.util.Iterator
StackMap stack:
getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 31
ldc "verbose"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 31
27: new java.lang.StringBuilder
dup
ldc "Ignore unsupported cipher suite: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 9
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
28: ldc " for "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 5
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
29: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
30: invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
end local 9 31: StackMap locals: java.util.List java.util.List java.security.AlgorithmConstraints int java.util.ArrayList sun.security.ssl.ProtocolVersion java.util.Iterator int java.util.Map top java.util.Iterator
StackMap stack:
aload 10
invokeinterface java.util.Iterator.hasNext:()Z
ifne 17
32: StackMap locals: java.util.List java.util.List java.security.AlgorithmConstraints int java.util.ArrayList sun.security.ssl.ProtocolVersion java.util.Iterator int java.util.Map
StackMap stack:
iload 7
ifne 35
getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 35
ldc "handshake"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 35
33: new java.lang.StringBuilder
dup
ldc "No available cipher suite for "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 5
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
34: invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
end local 8 end local 7 end local 5 35: StackMap locals: java.util.List java.util.List java.security.AlgorithmConstraints int java.util.ArrayList top java.util.Iterator
StackMap stack:
aload 6
invokeinterface java.util.Iterator.hasNext:()Z
ifne 3
36: aload 4
invokevirtual java.util.ArrayList.isEmpty:()Z
ifne 40
37: iload 3
ifeq 39
38: aload 4
getstatic sun.security.ssl.ProtocolVersion.SSL20Hello:Lsun/security/ssl/ProtocolVersion;
invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
pop
39: StackMap locals: java.util.List java.util.List java.security.AlgorithmConstraints int java.util.ArrayList
StackMap stack:
aload 4
invokestatic java.util.Collections.sort:(Ljava/util/List;)V
40: StackMap locals:
StackMap stack:
aload 4
invokestatic java.util.Collections.unmodifiableList:(Ljava/util/List;)Ljava/util/List;
areturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 41 0 enabledProtocols Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
0 41 1 enabledCipherSuites Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
0 41 2 algorithmConstraints Ljava/security/AlgorithmConstraints;
1 41 3 enabledSSL20Hello Z
2 41 4 protocols Ljava/util/ArrayList<Lsun/security/ssl/ProtocolVersion;>;
4 35 5 protocol Lsun/security/ssl/ProtocolVersion;
14 35 7 found Z
16 35 8 cachedStatus Ljava/util/Map<Lsun/security/ssl/NamedGroup$NamedGroupType;Ljava/lang/Boolean;>;
18 31 9 suite Lsun/security/ssl/CipherSuite;
Signature: (Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;Ljava/util/List<Lsun/security/ssl/CipherSuite;>;Ljava/security/AlgorithmConstraints;)Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
MethodParameters:
Name Flags
enabledProtocols
enabledCipherSuites
algorithmConstraints
private static java.util.List<sun.security.ssl.CipherSuite> getActiveCipherSuites(java.util.List<sun.security.ssl.ProtocolVersion>, java.util.List<sun.security.ssl.CipherSuite>, java.security.AlgorithmConstraints);
descriptor: (Ljava/util/List;Ljava/util/List;Ljava/security/AlgorithmConstraints;)Ljava/util/List;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=3, locals=10, args_size=3
start local 0 start local 1 start local 2 0: new java.util.LinkedList
dup
invokespecial java.util.LinkedList.<init>:()V
astore 3
start local 3 1: aload 0
ifnull 26
aload 0
invokeinterface java.util.List.isEmpty:()Z
ifne 26
2: new java.util.EnumMap
dup
ldc Lsun/security/ssl/NamedGroup$NamedGroupType;
invokespecial java.util.EnumMap.<init>:(Ljava/lang/Class;)V
3: astore 4
start local 4 4: aload 1
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 6
goto 25
StackMap locals: java.util.List java.util.List java.security.AlgorithmConstraints java.util.List java.util.Map top java.util.Iterator
StackMap stack:
5: aload 6
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast sun.security.ssl.CipherSuite
astore 5
start local 5 6: aload 5
invokevirtual sun.security.ssl.CipherSuite.isAvailable:()Z
ifne 8
7: goto 25
8: StackMap locals: java.util.List java.util.List java.security.AlgorithmConstraints java.util.List java.util.Map sun.security.ssl.CipherSuite java.util.Iterator
StackMap stack:
iconst_0
istore 7
start local 7 9: aload 0
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 9
goto 20
StackMap locals: java.util.List java.util.List java.security.AlgorithmConstraints java.util.List java.util.Map sun.security.ssl.CipherSuite java.util.Iterator int top java.util.Iterator
StackMap stack:
10: aload 9
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast sun.security.ssl.ProtocolVersion
astore 8
start local 8 11: aload 5
aload 8
invokevirtual sun.security.ssl.CipherSuite.supports:(Lsun/security/ssl/ProtocolVersion;)Z
ifne 13
12: goto 20
13: StackMap locals: java.util.List java.util.List java.security.AlgorithmConstraints java.util.List java.util.Map sun.security.ssl.CipherSuite java.util.Iterator int sun.security.ssl.ProtocolVersion java.util.Iterator
StackMap stack:
aload 5
14: aload 2
aload 4
15: invokestatic sun.security.ssl.HandshakeContext.isActivatable:(Lsun/security/ssl/CipherSuite;Ljava/security/AlgorithmConstraints;Ljava/util/Map;)Z
16: ifeq 20
17: aload 3
aload 5
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
18: iconst_1
istore 7
19: goto 21
end local 8 20: StackMap locals: java.util.List java.util.List java.security.AlgorithmConstraints java.util.List java.util.Map sun.security.ssl.CipherSuite java.util.Iterator int top java.util.Iterator
StackMap stack:
aload 9
invokeinterface java.util.Iterator.hasNext:()Z
ifne 10
21: StackMap locals: java.util.List java.util.List java.security.AlgorithmConstraints java.util.List java.util.Map sun.security.ssl.CipherSuite java.util.Iterator int
StackMap stack:
iload 7
ifne 25
22: getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 25
ldc "verbose"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 25
23: new java.lang.StringBuilder
dup
ldc "Ignore unsupported cipher suite: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 5
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
24: invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
end local 7 end local 5 25: StackMap locals: java.util.List java.util.List java.security.AlgorithmConstraints java.util.List java.util.Map top java.util.Iterator
StackMap stack:
aload 6
invokeinterface java.util.Iterator.hasNext:()Z
ifne 5
end local 4 26: StackMap locals: java.util.List java.util.List java.security.AlgorithmConstraints java.util.List
StackMap stack:
aload 3
invokestatic java.util.Collections.unmodifiableList:(Ljava/util/List;)Ljava/util/List;
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 27 0 enabledProtocols Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
0 27 1 enabledCipherSuites Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
0 27 2 algorithmConstraints Ljava/security/AlgorithmConstraints;
1 27 3 suites Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
4 26 4 cachedStatus Ljava/util/Map<Lsun/security/ssl/NamedGroup$NamedGroupType;Ljava/lang/Boolean;>;
6 25 5 suite Lsun/security/ssl/CipherSuite;
9 25 7 isSupported Z
11 20 8 protocol Lsun/security/ssl/ProtocolVersion;
Signature: (Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;Ljava/util/List<Lsun/security/ssl/CipherSuite;>;Ljava/security/AlgorithmConstraints;)Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
MethodParameters:
Name Flags
enabledProtocols
enabledCipherSuites
algorithmConstraints
static byte getHandshakeType(sun.security.ssl.TransportContext, sun.security.ssl.Plaintext);
descriptor: (Lsun/security/ssl/TransportContext;Lsun/security/ssl/Plaintext;)B
flags: (0x0008) ACC_STATIC
Code:
stack=5, locals=4, args_size=2
start local 0 start local 1 0: aload 1
getfield sun.security.ssl.Plaintext.contentType:B
getstatic sun.security.ssl.ContentType.HANDSHAKE:Lsun/security/ssl/ContentType;
getfield sun.security.ssl.ContentType.id:B
if_icmpeq 4
1: aload 0
getstatic sun.security.ssl.Alert.INTERNAL_ERROR:Lsun/security/ssl/Alert;
2: new java.lang.StringBuilder
dup
ldc "Unexpected operation for record: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
getfield sun.security.ssl.Plaintext.contentType:B
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
3: invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
athrow
4: StackMap locals:
StackMap stack:
aload 1
getfield sun.security.ssl.Plaintext.fragment:Ljava/nio/ByteBuffer;
ifnull 5
aload 1
getfield sun.security.ssl.Plaintext.fragment:Ljava/nio/ByteBuffer;
invokevirtual java.nio.ByteBuffer.remaining:()I
iconst_4
if_icmpge 8
5: StackMap locals:
StackMap stack:
aload 0
getstatic sun.security.ssl.Alert.UNEXPECTED_MESSAGE:Lsun/security/ssl/Alert;
6: ldc "Invalid handshake message: insufficient data"
7: invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
athrow
8: StackMap locals:
StackMap stack:
aload 1
getfield sun.security.ssl.Plaintext.fragment:Ljava/nio/ByteBuffer;
invokestatic sun.security.ssl.Record.getInt8:(Ljava/nio/ByteBuffer;)I
i2b
istore 2
start local 2 9: aload 1
getfield sun.security.ssl.Plaintext.fragment:Ljava/nio/ByteBuffer;
invokestatic sun.security.ssl.Record.getInt24:(Ljava/nio/ByteBuffer;)I
istore 3
start local 3 10: iload 3
aload 1
getfield sun.security.ssl.Plaintext.fragment:Ljava/nio/ByteBuffer;
invokevirtual java.nio.ByteBuffer.remaining:()I
if_icmpeq 14
11: aload 0
getstatic sun.security.ssl.Alert.UNEXPECTED_MESSAGE:Lsun/security/ssl/Alert;
12: ldc "Invalid handshake message: insufficient handshake body"
13: invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
athrow
14: StackMap locals: int int
StackMap stack:
iload 2
ireturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 conContext Lsun/security/ssl/TransportContext;
0 15 1 plaintext Lsun/security/ssl/Plaintext;
9 15 2 handshakeType B
10 15 3 handshakeLen I
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
conContext
plaintext
void dispatch(byte, sun.security.ssl.Plaintext);
descriptor: (BLsun/security/ssl/Plaintext;)V
flags: (0x0000)
Code:
stack=5, locals=5, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getfield sun.security.ssl.TransportContext.transport:Lsun/security/ssl/SSLTransport;
invokeinterface sun.security.ssl.SSLTransport.useDelegatedTask:()Z
ifeq 22
1: aload 0
getfield sun.security.ssl.HandshakeContext.delegatedActions:Ljava/util/Queue;
invokeinterface java.util.Queue.isEmpty:()Z
ifeq 2
iconst_0
goto 3
StackMap locals:
StackMap stack:
2: iconst_1
StackMap locals:
StackMap stack: int
3: istore 3
start local 3 4: iload 3
ifne 8
5: iload 1
getstatic sun.security.ssl.SSLHandshake.FINISHED:Lsun/security/ssl/SSLHandshake;
getfield sun.security.ssl.SSLHandshake.id:B
if_icmpeq 20
6: iload 1
getstatic sun.security.ssl.SSLHandshake.KEY_UPDATE:Lsun/security/ssl/SSLHandshake;
getfield sun.security.ssl.SSLHandshake.id:B
if_icmpeq 20
7: iload 1
getstatic sun.security.ssl.SSLHandshake.NEW_SESSION_TICKET:Lsun/security/ssl/SSLHandshake;
getfield sun.security.ssl.SSLHandshake.id:B
if_icmpeq 20
8: StackMap locals: int
StackMap stack:
iload 3
ifne 11
9: aload 0
iconst_0
putfield sun.security.ssl.HandshakeContext.taskDelegated:Z
10: aload 0
aconst_null
putfield sun.security.ssl.HandshakeContext.delegatedThrown:Ljava/lang/Exception;
11: StackMap locals:
StackMap stack:
aload 2
getfield sun.security.ssl.Plaintext.fragment:Ljava/nio/ByteBuffer;
invokevirtual java.nio.ByteBuffer.remaining:()I
newarray 8
12: invokestatic java.nio.ByteBuffer.wrap:([B)Ljava/nio/ByteBuffer;
astore 4
start local 4 13: aload 4
aload 2
getfield sun.security.ssl.Plaintext.fragment:Ljava/nio/ByteBuffer;
invokevirtual java.nio.ByteBuffer.put:(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;
pop
14: aload 4
invokevirtual java.nio.ByteBuffer.rewind:()Ljava/nio/ByteBuffer;
astore 4
15: aload 0
getfield sun.security.ssl.HandshakeContext.delegatedActions:Ljava/util/Queue;
new java.util.AbstractMap$SimpleImmutableEntry
dup
16: iload 1
invokestatic java.lang.Byte.valueOf:(B)Ljava/lang/Byte;
17: aload 4
invokespecial java.util.AbstractMap$SimpleImmutableEntry.<init>:(Ljava/lang/Object;Ljava/lang/Object;)V
18: invokeinterface java.util.Queue.add:(Ljava/lang/Object;)Z
pop
end local 4 19: goto 23
20: StackMap locals:
StackMap stack:
aload 0
iload 1
aload 2
getfield sun.security.ssl.Plaintext.fragment:Ljava/nio/ByteBuffer;
invokevirtual sun.security.ssl.HandshakeContext.dispatch:(BLjava/nio/ByteBuffer;)V
end local 3 21: goto 23
22: StackMap locals:
StackMap stack:
aload 0
iload 1
aload 2
getfield sun.security.ssl.Plaintext.fragment:Ljava/nio/ByteBuffer;
invokevirtual sun.security.ssl.HandshakeContext.dispatch:(BLjava/nio/ByteBuffer;)V
23: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 24 0 this Lsun/security/ssl/HandshakeContext;
0 24 1 handshakeType B
0 24 2 plaintext Lsun/security/ssl/Plaintext;
4 21 3 hasDelegated Z
13 19 4 fragment Ljava/nio/ByteBuffer;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
handshakeType
plaintext
void dispatch(byte, java.nio.ByteBuffer);
descriptor: (BLjava/nio/ByteBuffer;)V
flags: (0x0000)
Code:
stack=5, locals=5, args_size=3
start local 0 start local 1 start local 2 0: iload 1
getstatic sun.security.ssl.SSLHandshake.HELLO_REQUEST:Lsun/security/ssl/SSLHandshake;
getfield sun.security.ssl.SSLHandshake.id:B
if_icmpne 3
1: getstatic sun.security.ssl.SSLHandshake.HELLO_REQUEST:Lsun/security/ssl/SSLHandshake;
astore 3
start local 3 2: goto 4
end local 3 3: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.HandshakeContext.handshakeConsumers:Ljava/util/LinkedHashMap;
iload 1
invokestatic java.lang.Byte.valueOf:(B)Ljava/lang/Byte;
invokevirtual java.util.LinkedHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast sun.security.ssl.SSLConsumer
astore 3
start local 3 4: StackMap locals: sun.security.ssl.SSLConsumer
StackMap stack:
aload 3
ifnonnull 10
5: aload 0
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getstatic sun.security.ssl.Alert.UNEXPECTED_MESSAGE:Lsun/security/ssl/Alert;
6: new java.lang.StringBuilder
dup
ldc "Unexpected handshake message: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
7: iload 1
invokestatic sun.security.ssl.SSLHandshake.nameOf:(B)Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
8: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
9: invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
athrow
10: StackMap locals:
StackMap stack:
aload 3
aload 0
aload 2
invokeinterface sun.security.ssl.SSLConsumer.consume:(Lsun/security/ssl/ConnectionContext;Ljava/nio/ByteBuffer;)V
11: goto 26
StackMap locals:
StackMap stack: java.lang.UnsupportedOperationException
12: astore 4
start local 4 13: aload 0
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getstatic sun.security.ssl.Alert.UNEXPECTED_MESSAGE:Lsun/security/ssl/Alert;
14: new java.lang.StringBuilder
dup
ldc "Unsupported handshake message: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
15: iload 1
invokestatic sun.security.ssl.SSLHandshake.nameOf:(B)Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
16: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
17: aload 4
18: invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
athrow
end local 4 19: StackMap locals:
StackMap stack: java.lang.RuntimeException
astore 4
start local 4 20: aload 0
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getstatic sun.security.ssl.Alert.DECODE_ERROR:Lsun/security/ssl/Alert;
21: new java.lang.StringBuilder
dup
ldc "Illegal handshake message: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
22: iload 1
invokestatic sun.security.ssl.SSLHandshake.nameOf:(B)Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
23: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
24: aload 4
25: invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
athrow
end local 4 26: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.HandshakeContext.handshakeHash:Lsun/security/ssl/HandshakeHash;
invokevirtual sun.security.ssl.HandshakeHash.consume:()V
27: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 28 0 this Lsun/security/ssl/HandshakeContext;
0 28 1 handshakeType B
0 28 2 fragment Ljava/nio/ByteBuffer;
2 3 3 consumer Lsun/security/ssl/SSLConsumer;
4 28 3 consumer Lsun/security/ssl/SSLConsumer;
13 19 4 unsoe Ljava/lang/UnsupportedOperationException;
20 26 4 be Ljava/lang/RuntimeException;
Exception table:
from to target type
10 11 12 Class java.lang.UnsupportedOperationException
10 11 19 Class java.nio.BufferUnderflowException
10 11 19 Class java.nio.BufferOverflowException
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
handshakeType
fragment
abstract void kickstart();
descriptor: ()V
flags: (0x0400) ACC_ABSTRACT
Exceptions:
throws java.io.IOException
boolean isNegotiable(sun.security.ssl.CipherSuite);
descriptor: (Lsun/security/ssl/CipherSuite;)Z
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield sun.security.ssl.HandshakeContext.activeCipherSuites:Ljava/util/List;
aload 1
invokestatic sun.security.ssl.HandshakeContext.isNegotiable:(Ljava/util/List;Lsun/security/ssl/CipherSuite;)Z
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/HandshakeContext;
0 1 1 cs Lsun/security/ssl/CipherSuite;
MethodParameters:
Name Flags
cs
static final boolean isNegotiable(java.util.List<sun.security.ssl.CipherSuite>, sun.security.ssl.CipherSuite);
descriptor: (Ljava/util/List;Lsun/security/ssl/CipherSuite;)Z
flags: (0x0018) ACC_STATIC, ACC_FINAL
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
ifeq 1
aload 1
invokevirtual sun.security.ssl.CipherSuite.isNegotiable:()Z
ifeq 1
iconst_1
ireturn
StackMap locals:
StackMap stack:
1: iconst_0
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 proposed Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
0 2 1 cs Lsun/security/ssl/CipherSuite;
Signature: (Ljava/util/List<Lsun/security/ssl/CipherSuite;>;Lsun/security/ssl/CipherSuite;)Z
MethodParameters:
Name Flags
proposed
cs
static final boolean isNegotiable(java.util.List<sun.security.ssl.CipherSuite>, sun.security.ssl.ProtocolVersion, sun.security.ssl.CipherSuite);
descriptor: (Ljava/util/List;Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/CipherSuite;)Z
flags: (0x0018) ACC_STATIC, ACC_FINAL
Code:
stack=2, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
aload 2
invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
ifeq 3
1: aload 2
invokevirtual sun.security.ssl.CipherSuite.isNegotiable:()Z
ifeq 3
aload 2
aload 1
invokevirtual sun.security.ssl.CipherSuite.supports:(Lsun/security/ssl/ProtocolVersion;)Z
ifeq 3
2: iconst_1
ireturn
StackMap locals:
StackMap stack:
3: iconst_0
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 proposed Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
0 4 1 protocolVersion Lsun/security/ssl/ProtocolVersion;
0 4 2 cs Lsun/security/ssl/CipherSuite;
Signature: (Ljava/util/List<Lsun/security/ssl/CipherSuite;>;Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/CipherSuite;)Z
MethodParameters:
Name Flags
proposed
protocolVersion
cs
boolean isNegotiable(sun.security.ssl.ProtocolVersion);
descriptor: (Lsun/security/ssl/ProtocolVersion;)Z
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield sun.security.ssl.HandshakeContext.activeProtocols:Ljava/util/List;
aload 1
invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/HandshakeContext;
0 1 1 protocolVersion Lsun/security/ssl/ProtocolVersion;
MethodParameters:
Name Flags
protocolVersion
void setVersion(sun.security.ssl.ProtocolVersion);
descriptor: (Lsun/security/ssl/ProtocolVersion;)V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
aload 1
putfield sun.security.ssl.TransportContext.protocolVersion:Lsun/security/ssl/ProtocolVersion;
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/HandshakeContext;
0 2 1 protocolVersion Lsun/security/ssl/ProtocolVersion;
MethodParameters:
Name Flags
protocolVersion
private static boolean isActivatable(sun.security.ssl.CipherSuite, java.security.AlgorithmConstraints, java.util.Map<sun.security.ssl.NamedGroup$NamedGroupType, java.lang.Boolean>);
descriptor: (Lsun/security/ssl/CipherSuite;Ljava/security/AlgorithmConstraints;Ljava/util/Map;)Z
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=4, locals=11, args_size=3
start local 0 start local 1 start local 2 0: aload 1
1: getstatic java.security.CryptoPrimitive.KEY_AGREEMENT:Ljava/security/CryptoPrimitive;
invokestatic java.util.EnumSet.of:(Ljava/lang/Enum;)Ljava/util/EnumSet;
aload 0
getfield sun.security.ssl.CipherSuite.name:Ljava/lang/String;
aconst_null
2: invokeinterface java.security.AlgorithmConstraints.permits:(Ljava/util/Set;Ljava/lang/String;Ljava/security/AlgorithmParameters;)Z
3: ifeq 30
4: aload 0
getfield sun.security.ssl.CipherSuite.keyExchange:Lsun/security/ssl/CipherSuite$KeyExchange;
ifnonnull 6
5: iconst_1
ireturn
6: StackMap locals:
StackMap stack:
iconst_0
istore 4
start local 4 7: aload 0
getfield sun.security.ssl.CipherSuite.keyExchange:Lsun/security/ssl/CipherSuite$KeyExchange;
getfield sun.security.ssl.CipherSuite$KeyExchange.groupTypes:[Lsun/security/ssl/NamedGroup$NamedGroupType;
astore 5
start local 5 8: aload 5
dup
astore 9
arraylength
istore 8
iconst_0
istore 7
goto 26
StackMap locals: sun.security.ssl.CipherSuite java.security.AlgorithmConstraints java.util.Map top int sun.security.ssl.NamedGroup$NamedGroupType[] top int int sun.security.ssl.NamedGroup$NamedGroupType[]
StackMap stack:
9: aload 9
iload 7
aaload
astore 6
start local 6 10: aload 6
getstatic sun.security.ssl.NamedGroup$NamedGroupType.NAMED_GROUP_NONE:Lsun/security/ssl/NamedGroup$NamedGroupType;
if_acmpeq 24
11: aload 2
aload 6
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.lang.Boolean
astore 10
start local 10 12: aload 10
ifnonnull 21
13: aload 1
aload 6
14: invokestatic sun.security.ssl.SupportedGroupsExtension$SupportedGroups.isActivatable:(Ljava/security/AlgorithmConstraints;Lsun/security/ssl/NamedGroup$NamedGroupType;)Z
istore 3
start local 3 15: aload 2
aload 6
iload 3
invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
16: iload 3
ifne 22
17: getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 22
ldc "verbose"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 22
18: new java.lang.StringBuilder
dup
ldc "No activated named group in "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 6
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
19: invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
20: goto 22
end local 3 21: StackMap locals: sun.security.ssl.CipherSuite java.security.AlgorithmConstraints java.util.Map top int sun.security.ssl.NamedGroup$NamedGroupType[] sun.security.ssl.NamedGroup$NamedGroupType int int sun.security.ssl.NamedGroup$NamedGroupType[] java.lang.Boolean
StackMap stack:
aload 10
invokevirtual java.lang.Boolean.booleanValue:()Z
istore 3
start local 3 22: StackMap locals: sun.security.ssl.CipherSuite java.security.AlgorithmConstraints java.util.Map int int sun.security.ssl.NamedGroup$NamedGroupType[] sun.security.ssl.NamedGroup$NamedGroupType int int sun.security.ssl.NamedGroup$NamedGroupType[] java.lang.Boolean
StackMap stack:
iload 4
iload 3
ior
istore 4
end local 10 23: goto 25
end local 3 24: StackMap locals: sun.security.ssl.CipherSuite java.security.AlgorithmConstraints java.util.Map top int sun.security.ssl.NamedGroup$NamedGroupType[] sun.security.ssl.NamedGroup$NamedGroupType int int sun.security.ssl.NamedGroup$NamedGroupType[]
StackMap stack:
iload 4
iconst_1
ior
istore 4
end local 6 25: StackMap locals: sun.security.ssl.CipherSuite java.security.AlgorithmConstraints java.util.Map top int sun.security.ssl.NamedGroup$NamedGroupType[] top int int sun.security.ssl.NamedGroup$NamedGroupType[]
StackMap stack:
iinc 7 1
StackMap locals:
StackMap stack:
26: iload 7
iload 8
if_icmplt 9
27: iload 4
ifne 29
getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 29
ldc "verbose"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 29
28: new java.lang.StringBuilder
dup
ldc "No active named group(s), ignore "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
29: StackMap locals: sun.security.ssl.CipherSuite java.security.AlgorithmConstraints java.util.Map top int sun.security.ssl.NamedGroup$NamedGroupType[]
StackMap stack:
iload 4
ireturn
end local 5 end local 4 30: StackMap locals: sun.security.ssl.CipherSuite java.security.AlgorithmConstraints java.util.Map
StackMap stack:
getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 32
ldc "verbose"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 32
31: new java.lang.StringBuilder
dup
ldc "Ignore disabled cipher suite: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
32: StackMap locals:
StackMap stack:
iconst_0
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 33 0 suite Lsun/security/ssl/CipherSuite;
0 33 1 algorithmConstraints Ljava/security/AlgorithmConstraints;
0 33 2 cachedStatus Ljava/util/Map<Lsun/security/ssl/NamedGroup$NamedGroupType;Ljava/lang/Boolean;>;
15 21 3 groupAvailable Z
22 24 3 groupAvailable Z
7 30 4 retval Z
8 30 5 groupTypes [Lsun/security/ssl/NamedGroup$NamedGroupType;
10 25 6 groupType Lsun/security/ssl/NamedGroup$NamedGroupType;
12 23 10 checkedStatus Ljava/lang/Boolean;
Signature: (Lsun/security/ssl/CipherSuite;Ljava/security/AlgorithmConstraints;Ljava/util/Map<Lsun/security/ssl/NamedGroup$NamedGroupType;Ljava/lang/Boolean;>;)Z
MethodParameters:
Name Flags
suite
algorithmConstraints
cachedStatus
java.util.List<javax.net.ssl.SNIServerName> getRequestedServerNames();
descriptor: ()Ljava/util/List;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.HandshakeContext.requestedServerNames:Ljava/util/List;
ifnonnull 2
1: invokestatic java.util.Collections.emptyList:()Ljava/util/List;
areturn
2: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.HandshakeContext.requestedServerNames:Ljava/util/List;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/HandshakeContext;
Signature: ()Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;
}
SourceFile: "HandshakeContext.java"
InnerClasses:
public SimpleImmutableEntry = java.util.AbstractMap$SimpleImmutableEntry of java.util.AbstractMap
public abstract Entry = java.util.Map$Entry of java.util.Map
final KeyExchange = sun.security.ssl.CipherSuite$KeyExchange of sun.security.ssl.CipherSuite
final NamedGroupType = sun.security.ssl.NamedGroup$NamedGroupType of sun.security.ssl.NamedGroup
abstract SSLExtensionSpec = sun.security.ssl.SSLExtension$SSLExtensionSpec of sun.security.ssl.SSLExtension
SupportedGroups = sun.security.ssl.SupportedGroupsExtension$SupportedGroups of sun.security.ssl.SupportedGroupsExtension