final class sun.security.ssl.ExtendedMasterSecretExtension$CHExtendedMasterSecretConsumer implements sun.security.ssl.SSLExtension$ExtensionConsumer
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: sun.security.ssl.ExtendedMasterSecretExtension$CHExtendedMasterSecretConsumer
super_class: java.lang.Object
{
private void <init>();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=1, locals=1, args_size=1
start local 0 // sun.security.ssl.ExtendedMasterSecretExtension$CHExtendedMasterSecretConsumer this
0: .line 150
aload 0 /* this */
invokespecial java.lang.Object.<init>:()V
1: .line 152
return
end local 0 // sun.security.ssl.ExtendedMasterSecretExtension$CHExtendedMasterSecretConsumer this
LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/ExtendedMasterSecretExtension$CHExtendedMasterSecretConsumer;
public void consume(sun.security.ssl.ConnectionContext, sun.security.ssl.SSLHandshake$HandshakeMessage, java.nio.ByteBuffer);
descriptor: (Lsun/security/ssl/ConnectionContext;Lsun/security/ssl/SSLHandshake$HandshakeMessage;Ljava/nio/ByteBuffer;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=5, args_size=4
start local 0 // sun.security.ssl.ExtendedMasterSecretExtension$CHExtendedMasterSecretConsumer this
start local 1 // sun.security.ssl.ConnectionContext context
start local 2 // sun.security.ssl.SSLHandshake$HandshakeMessage message
start local 3 // java.nio.ByteBuffer buffer
0: .line 159
aload 1 /* context */
checkcast sun.security.ssl.ServerHandshakeContext
astore 4 /* shc */
start local 4 // sun.security.ssl.ServerHandshakeContext shc
1: .line 162
aload 4 /* shc */
getfield sun.security.ssl.ServerHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
getstatic sun.security.ssl.SSLExtension.CH_EXTENDED_MASTER_SECRET:Lsun/security/ssl/SSLExtension;
invokevirtual sun.security.ssl.SSLConfiguration.isAvailable:(Lsun/security/ssl/SSLExtension;)Z
ifeq 4
2: .line 163
getstatic sun.security.ssl.SSLConfiguration.useExtendedMasterSecret:Z
ifeq 4
3: .line 164
aload 4 /* shc */
getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
invokevirtual sun.security.ssl.ProtocolVersion.useTLS10PlusSpec:()Z
ifne 9
4: .line 165
StackMap locals: sun.security.ssl.ServerHandshakeContext
StackMap stack:
getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 8
ldc "ssl,handshake"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 8
5: .line 166
new java.lang.StringBuilder
dup
ldc "Ignore unavailable extension: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
6: .line 167
getstatic sun.security.ssl.SSLExtension.CH_EXTENDED_MASTER_SECRET:Lsun/security/ssl/SSLExtension;
getfield sun.security.ssl.SSLExtension.name:Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
7: .line 166
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
8: .line 169
StackMap locals:
StackMap stack:
return
9: .line 174
StackMap locals:
StackMap stack:
new sun.security.ssl.ExtendedMasterSecretExtension$ExtendedMasterSecretSpec
aload 4 /* shc */
aload 3 /* buffer */
invokespecial sun.security.ssl.ExtendedMasterSecretExtension$ExtendedMasterSecretSpec.<init>:(Lsun/security/ssl/HandshakeContext;Ljava/nio/ByteBuffer;)V
10: .line 175
aload 4 /* shc */
getfield sun.security.ssl.ServerHandshakeContext.isResumption:Z
ifeq 17
aload 4 /* shc */
getfield sun.security.ssl.ServerHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
ifnull 17
11: .line 176
aload 4 /* shc */
getfield sun.security.ssl.ServerHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
getfield sun.security.ssl.SSLSessionImpl.useExtendedMasterSecret:Z
ifne 17
12: .line 183
aload 4 /* shc */
iconst_0
putfield sun.security.ssl.ServerHandshakeContext.isResumption:Z
13: .line 184
aload 4 /* shc */
aconst_null
putfield sun.security.ssl.ServerHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
14: .line 185
getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 17
ldc "ssl,handshake"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 17
15: .line 187
ldc "abort session resumption which did not use Extended Master Secret extension"
iconst_0
anewarray java.lang.Object
16: .line 186
invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
17: .line 194
StackMap locals:
StackMap stack:
aload 4 /* shc */
getfield sun.security.ssl.ServerHandshakeContext.handshakeExtensions:Ljava/util/Map;
18: .line 195
getstatic sun.security.ssl.SSLExtension.CH_EXTENDED_MASTER_SECRET:Lsun/security/ssl/SSLExtension;
getstatic sun.security.ssl.ExtendedMasterSecretExtension$ExtendedMasterSecretSpec.NOMINAL:Lsun/security/ssl/ExtendedMasterSecretExtension$ExtendedMasterSecretSpec;
19: .line 194
invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
20: .line 198
return
end local 4 // sun.security.ssl.ServerHandshakeContext shc
end local 3 // java.nio.ByteBuffer buffer
end local 2 // sun.security.ssl.SSLHandshake$HandshakeMessage message
end local 1 // sun.security.ssl.ConnectionContext context
end local 0 // sun.security.ssl.ExtendedMasterSecretExtension$CHExtendedMasterSecretConsumer this
LocalVariableTable:
Start End Slot Name Signature
0 21 0 this Lsun/security/ssl/ExtendedMasterSecretExtension$CHExtendedMasterSecretConsumer;
0 21 1 context Lsun/security/ssl/ConnectionContext;
0 21 2 message Lsun/security/ssl/SSLHandshake$HandshakeMessage;
0 21 3 buffer Ljava/nio/ByteBuffer;
1 21 4 shc Lsun/security/ssl/ServerHandshakeContext;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
context
message
buffer
}
SourceFile: "ExtendedMasterSecretExtension.java"
NestHost: sun.security.ssl.ExtendedMasterSecretExtension
InnerClasses:
private final CHExtendedMasterSecretConsumer = sun.security.ssl.ExtendedMasterSecretExtension$CHExtendedMasterSecretConsumer of sun.security.ssl.ExtendedMasterSecretExtension
final ExtendedMasterSecretSpec = sun.security.ssl.ExtendedMasterSecretExtension$ExtendedMasterSecretSpec of sun.security.ssl.ExtendedMasterSecretExtension
abstract ExtensionConsumer = sun.security.ssl.SSLExtension$ExtensionConsumer of sun.security.ssl.SSLExtension
abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake