final class sun.security.ssl.ServerHello$T13HelloRetryRequestReproducer implements sun.security.ssl.HandshakeProducer
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: sun.security.ssl.ServerHello$T13HelloRetryRequestReproducer
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.ServerHello$T13HelloRetryRequestReproducer this
0: .line 804
aload 0 /* this */
invokespecial java.lang.Object.<init>:()V
1: .line 806
return
end local 0 // sun.security.ssl.ServerHello$T13HelloRetryRequestReproducer this
LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/ServerHello$T13HelloRetryRequestReproducer;
public byte[] produce(sun.security.ssl.ConnectionContext, sun.security.ssl.SSLHandshake$HandshakeMessage);
descriptor: (Lsun/security/ssl/ConnectionContext;Lsun/security/ssl/SSLHandshake$HandshakeMessage;)[B
flags: (0x0001) ACC_PUBLIC
Code:
stack=8, locals=9, args_size=3
start local 0 // sun.security.ssl.ServerHello$T13HelloRetryRequestReproducer this
start local 1 // sun.security.ssl.ConnectionContext context
start local 2 // sun.security.ssl.SSLHandshake$HandshakeMessage message
0: .line 811
aload 1 /* context */
checkcast sun.security.ssl.ServerHandshakeContext
astore 3 /* shc */
start local 3 // sun.security.ssl.ServerHandshakeContext shc
1: .line 812
aload 2 /* message */
checkcast sun.security.ssl.ClientHello$ClientHelloMessage
astore 4 /* clientHello */
start local 4 // sun.security.ssl.ClientHello$ClientHelloMessage clientHello
2: .line 815
aload 3 /* shc */
getfield sun.security.ssl.ServerHandshakeContext.negotiatedCipherSuite:Lsun/security/ssl/CipherSuite;
astore 5 /* cipherSuite */
start local 5 // sun.security.ssl.CipherSuite cipherSuite
3: .line 816
new sun.security.ssl.ServerHello$ServerHelloMessage
dup
aload 3 /* shc */
4: .line 817
getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
5: .line 818
aload 4 /* clientHello */
getfield sun.security.ssl.ClientHello$ClientHelloMessage.sessionId:Lsun/security/ssl/SessionId;
6: .line 819
aload 5 /* cipherSuite */
7: .line 820
getstatic sun.security.ssl.RandomCookie.hrrRandom:Lsun/security/ssl/RandomCookie;
8: .line 821
aload 4 /* clientHello */
9: .line 816
invokespecial sun.security.ssl.ServerHello$ServerHelloMessage.<init>:(Lsun/security/ssl/HandshakeContext;Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/SessionId;Lsun/security/ssl/CipherSuite;Lsun/security/ssl/RandomCookie;Lsun/security/ssl/ClientHello$ClientHelloMessage;)V
astore 6 /* hhrm */
start local 6 // sun.security.ssl.ServerHello$ServerHelloMessage hhrm
10: .line 826
aload 3 /* shc */
getfield sun.security.ssl.ServerHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
11: .line 827
getstatic sun.security.ssl.SSLHandshake.MESSAGE_HASH:Lsun/security/ssl/SSLHandshake;
aload 3 /* shc */
getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
12: .line 826
invokevirtual sun.security.ssl.SSLConfiguration.getEnabledExtensions:(Lsun/security/ssl/SSLHandshake;Lsun/security/ssl/ProtocolVersion;)[Lsun/security/ssl/SSLExtension;
13: .line 825
astore 7 /* serverHelloExtensions */
start local 7 // sun.security.ssl.SSLExtension[] serverHelloExtensions
14: .line 828
aload 6 /* hhrm */
getfield sun.security.ssl.ServerHello$ServerHelloMessage.extensions:Lsun/security/ssl/SSLExtensions;
aload 3 /* shc */
aload 7 /* serverHelloExtensions */
invokevirtual sun.security.ssl.SSLExtensions.produce:(Lsun/security/ssl/HandshakeContext;[Lsun/security/ssl/SSLExtension;)V
15: .line 829
getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 18
ldc "ssl,handshake"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 18
16: .line 831
ldc "Reproduced HelloRetryRequest handshake message"
iconst_1
anewarray java.lang.Object
dup
iconst_0
aload 6 /* hhrm */
aastore
17: .line 830
invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
18: .line 834
StackMap locals: sun.security.ssl.ServerHello$T13HelloRetryRequestReproducer sun.security.ssl.ConnectionContext sun.security.ssl.SSLHandshake$HandshakeMessage sun.security.ssl.ServerHandshakeContext sun.security.ssl.ClientHello$ClientHelloMessage sun.security.ssl.CipherSuite sun.security.ssl.ServerHello$ServerHelloMessage sun.security.ssl.SSLExtension[]
StackMap stack:
new sun.security.ssl.HandshakeOutStream
dup
aconst_null
invokespecial sun.security.ssl.HandshakeOutStream.<init>:(Lsun/security/ssl/OutputRecord;)V
astore 8 /* hos */
start local 8 // sun.security.ssl.HandshakeOutStream hos
19: .line 835
aload 6 /* hhrm */
aload 8 /* hos */
invokevirtual sun.security.ssl.ServerHello$ServerHelloMessage.write:(Lsun/security/ssl/HandshakeOutStream;)V
20: .line 837
aload 8 /* hos */
invokevirtual sun.security.ssl.HandshakeOutStream.toByteArray:()[B
areturn
end local 8 // sun.security.ssl.HandshakeOutStream hos
end local 7 // sun.security.ssl.SSLExtension[] serverHelloExtensions
end local 6 // sun.security.ssl.ServerHello$ServerHelloMessage hhrm
end local 5 // sun.security.ssl.CipherSuite cipherSuite
end local 4 // sun.security.ssl.ClientHello$ClientHelloMessage clientHello
end local 3 // sun.security.ssl.ServerHandshakeContext shc
end local 2 // sun.security.ssl.SSLHandshake$HandshakeMessage message
end local 1 // sun.security.ssl.ConnectionContext context
end local 0 // sun.security.ssl.ServerHello$T13HelloRetryRequestReproducer this
LocalVariableTable:
Start End Slot Name Signature
0 21 0 this Lsun/security/ssl/ServerHello$T13HelloRetryRequestReproducer;
0 21 1 context Lsun/security/ssl/ConnectionContext;
0 21 2 message Lsun/security/ssl/SSLHandshake$HandshakeMessage;
1 21 3 shc Lsun/security/ssl/ServerHandshakeContext;
2 21 4 clientHello Lsun/security/ssl/ClientHello$ClientHelloMessage;
3 21 5 cipherSuite Lsun/security/ssl/CipherSuite;
10 21 6 hhrm Lsun/security/ssl/ServerHello$ServerHelloMessage;
14 21 7 serverHelloExtensions [Lsun/security/ssl/SSLExtension;
19 21 8 hos Lsun/security/ssl/HandshakeOutStream;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
context
message
}
SourceFile: "ServerHello.java"
NestHost: sun.security.ssl.ServerHello
InnerClasses:
final ClientHelloMessage = sun.security.ssl.ClientHello$ClientHelloMessage of sun.security.ssl.ClientHello
abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake
final ServerHelloMessage = sun.security.ssl.ServerHello$ServerHelloMessage of sun.security.ssl.ServerHello
private final T13HelloRetryRequestReproducer = sun.security.ssl.ServerHello$T13HelloRetryRequestReproducer of sun.security.ssl.ServerHello