final class sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec implements sun.security.ssl.SSLExtension$SSLExtensionSpec
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec
super_class: java.lang.Object
{
static final sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec DEFAULT;
descriptor: Lsun/security/ssl/CertStatusExtension$CertStatusRequestV2Spec;
flags: (0x0018) ACC_STATIC, ACC_FINAL
final sun.security.ssl.CertStatusExtension$CertStatusRequest[] certStatusRequests;
descriptor: [Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
flags: (0x0010) ACC_FINAL
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=6, locals=0, args_size=0
0: new sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec
dup
iconst_1
anewarray sun.security.ssl.CertStatusExtension$CertStatusRequest
dup
iconst_0
1: getstatic sun.security.ssl.CertStatusExtension$OCSPStatusRequest.EMPTY_OCSP_MULTI:Lsun/security/ssl/CertStatusExtension$OCSPStatusRequest;
aastore
2: invokespecial sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.<init>:([Lsun/security/ssl/CertStatusExtension$CertStatusRequest;)V
3: putstatic sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.DEFAULT:Lsun/security/ssl/CertStatusExtension$CertStatusRequestV2Spec;
4: return
LocalVariableTable:
Start End Slot Name Signature
private void <init>(sun.security.ssl.CertStatusExtension$CertStatusRequest[]);
descriptor: ([Lsun/security/ssl/CertStatusExtension$CertStatusRequest;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
aload 1
putfield sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.certStatusRequests:[Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
2: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/CertStatusExtension$CertStatusRequestV2Spec;
0 3 1 certStatusRequests [Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
MethodParameters:
Name Flags
certStatusRequests
private void <init>(sun.security.ssl.HandshakeContext, java.nio.ByteBuffer);
descriptor: (Lsun/security/ssl/HandshakeContext;Ljava/nio/ByteBuffer;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=7, locals=9, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 2
invokevirtual java.nio.ByteBuffer.remaining:()I
ifne 4
2: aload 0
iconst_0
anewarray sun.security.ssl.CertStatusExtension$CertStatusRequest
putfield sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.certStatusRequests:[Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
3: return
4: StackMap locals: sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec sun.security.ssl.HandshakeContext java.nio.ByteBuffer
StackMap stack:
aload 2
invokevirtual java.nio.ByteBuffer.remaining:()I
iconst_5
if_icmpge 10
5: aload 1
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getstatic sun.security.ssl.Alert.DECODE_ERROR:Lsun/security/ssl/Alert;
6: new javax.net.ssl.SSLProtocolException
dup
7: ldc "Invalid status_request_v2 extension: insufficient data"
8: invokespecial javax.net.ssl.SSLProtocolException.<init>:(Ljava/lang/String;)V
9: invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
athrow
10: StackMap locals:
StackMap stack:
aload 2
invokestatic sun.security.ssl.Record.getInt16:(Ljava/nio/ByteBuffer;)I
istore 3
start local 3 11: iload 3
ifgt 19
12: aload 1
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getstatic sun.security.ssl.Alert.DECODE_ERROR:Lsun/security/ssl/Alert;
13: new javax.net.ssl.SSLProtocolException
dup
14: new java.lang.StringBuilder
dup
ldc "certificate_status_req_list length must be positive (received length: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
15: iload 3
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
ldc ")"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
16: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
17: invokespecial javax.net.ssl.SSLProtocolException.<init>:(Ljava/lang/String;)V
18: invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
athrow
19: StackMap locals: int
StackMap stack:
iload 3
istore 4
start local 4 20: new java.util.ArrayList
dup
invokespecial java.util.ArrayList.<init>:()V
astore 5
start local 5 21: goto 60
22: StackMap locals: int java.util.List
StackMap stack:
aload 2
invokestatic sun.security.ssl.Record.getInt8:(Ljava/nio/ByteBuffer;)I
i2b
istore 6
start local 6 23: aload 2
invokestatic sun.security.ssl.Record.getInt16:(Ljava/nio/ByteBuffer;)I
istore 7
start local 7 24: aload 2
invokevirtual java.nio.ByteBuffer.remaining:()I
iload 7
if_icmpge 34
25: aload 1
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
26: getstatic sun.security.ssl.Alert.DECODE_ERROR:Lsun/security/ssl/Alert;
27: new javax.net.ssl.SSLProtocolException
dup
28: new java.lang.StringBuilder
dup
ldc "Invalid status_request_v2 extension: insufficient data (request_length="
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
29: iload 7
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
30: ldc ", remining="
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 2
invokevirtual java.nio.ByteBuffer.remaining:()I
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
ldc ")"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
31: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
32: invokespecial javax.net.ssl.SSLProtocolException.<init>:(Ljava/lang/String;)V
33: invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
athrow
34: StackMap locals: int int
StackMap stack:
iload 7
newarray 8
astore 8
start local 8 35: aload 8
arraylength
ifeq 37
36: aload 2
aload 8
invokevirtual java.nio.ByteBuffer.get:([B)Ljava/nio/ByteBuffer;
pop
37: StackMap locals: byte[]
StackMap stack:
iinc 4 -3
38: iload 4
iload 7
isub
istore 4
39: iload 6
getstatic sun.security.ssl.CertStatusExtension$CertStatusRequestType.OCSP:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
getfield sun.security.ssl.CertStatusExtension$CertStatusRequestType.id:B
if_icmpeq 41
40: iload 6
getstatic sun.security.ssl.CertStatusExtension$CertStatusRequestType.OCSP_MULTI:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
getfield sun.security.ssl.CertStatusExtension$CertStatusRequestType.id:B
if_icmpne 52
41: StackMap locals:
StackMap stack:
aload 8
arraylength
iconst_4
if_icmpge 48
42: aload 1
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
43: getstatic sun.security.ssl.Alert.DECODE_ERROR:Lsun/security/ssl/Alert;
44: new javax.net.ssl.SSLProtocolException
dup
45: ldc "Invalid status_request_v2 extension: insufficient data"
46: invokespecial javax.net.ssl.SSLProtocolException.<init>:(Ljava/lang/String;)V
47: invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
athrow
48: StackMap locals:
StackMap stack:
aload 5
49: new sun.security.ssl.CertStatusExtension$OCSPStatusRequest
dup
iload 6
aload 8
invokespecial sun.security.ssl.CertStatusExtension$OCSPStatusRequest.<init>:(B[B)V
50: invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
51: goto 60
52: StackMap locals:
StackMap stack:
getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 57
ldc "ssl,handshake"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 57
53: new java.lang.StringBuilder
dup
ldc "Unknown certificate status request (status type: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
54: iload 6
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
ldc ")"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
55: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
56: invokestatic sun.security.ssl.SSLLogger.info:(Ljava/lang/String;[Ljava/lang/Object;)V
57: StackMap locals:
StackMap stack:
aload 5
58: new sun.security.ssl.CertStatusExtension$CertStatusRequest
dup
iload 6
aload 8
invokespecial sun.security.ssl.CertStatusExtension$CertStatusRequest.<init>:(B[B)V
59: invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
end local 8 end local 7 end local 6 60: StackMap locals:
StackMap stack:
iload 4
ifgt 22
61: aload 0
62: aload 5
iconst_0
anewarray sun.security.ssl.CertStatusExtension$CertStatusRequest
invokeinterface java.util.List.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
checkcast sun.security.ssl.CertStatusExtension$CertStatusRequest[]
63: putfield sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.certStatusRequests:[Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
64: return
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 65 0 this Lsun/security/ssl/CertStatusExtension$CertStatusRequestV2Spec;
0 65 1 hc Lsun/security/ssl/HandshakeContext;
0 65 2 message Ljava/nio/ByteBuffer;
11 65 3 listLen I
20 65 4 remaining I
21 65 5 statusRequests Ljava/util/List<Lsun/security/ssl/CertStatusExtension$CertStatusRequest;>;
23 60 6 statusType B
24 60 7 requestLen I
35 60 8 encoded [B
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
hc
message
public java.lang.String toString();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=9, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.certStatusRequests:[Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
ifnull 1
aload 0
getfield sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.certStatusRequests:[Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
arraylength
ifne 2
1: StackMap locals:
StackMap stack:
ldc "<empty>"
areturn
2: StackMap locals:
StackMap stack:
new java.text.MessageFormat
dup
3: ldc "\"cert status request\": '{'\n{0}\n'}'"
getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
4: invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
astore 1
start local 1 5: new java.lang.StringBuilder
dup
sipush 512
invokespecial java.lang.StringBuilder.<init>:(I)V
astore 2
start local 2 6: iconst_1
istore 3
start local 3 7: aload 0
getfield sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.certStatusRequests:[Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
dup
astore 7
arraylength
istore 6
iconst_0
istore 5
goto 18
StackMap locals: sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec java.text.MessageFormat java.lang.StringBuilder int top int int sun.security.ssl.CertStatusExtension$CertStatusRequest[]
StackMap stack:
8: aload 7
iload 5
aaload
astore 4
start local 4 9: iload 3
ifeq 12
10: iconst_0
istore 3
11: goto 13
12: StackMap locals: sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec java.text.MessageFormat java.lang.StringBuilder int sun.security.ssl.CertStatusExtension$CertStatusRequest int int sun.security.ssl.CertStatusExtension$CertStatusRequest[]
StackMap stack:
aload 2
ldc ", "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
13: StackMap locals:
StackMap stack:
iconst_1
anewarray java.lang.Object
dup
iconst_0
14: aload 4
invokevirtual sun.security.ssl.CertStatusExtension$CertStatusRequest.toString:()Ljava/lang/String;
invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;)Ljava/lang/String;
aastore
15: astore 8
start local 8 16: aload 2
aload 1
aload 8
invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
end local 8 end local 4 17: iinc 5 1
StackMap locals: sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec java.text.MessageFormat java.lang.StringBuilder int top int int sun.security.ssl.CertStatusExtension$CertStatusRequest[]
StackMap stack:
18: iload 5
iload 6
if_icmplt 8
19: aload 2
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 20 0 this Lsun/security/ssl/CertStatusExtension$CertStatusRequestV2Spec;
5 20 1 messageFormat Ljava/text/MessageFormat;
6 20 2 builder Ljava/lang/StringBuilder;
7 20 3 isFirst Z
9 17 4 csr Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
16 17 8 messageFields [Ljava/lang/Object;
}
SourceFile: "CertStatusExtension.java"
NestHost: sun.security.ssl.CertStatusExtension
InnerClasses:
CertStatusRequest = sun.security.ssl.CertStatusExtension$CertStatusRequest of sun.security.ssl.CertStatusExtension
final CertStatusRequestType = sun.security.ssl.CertStatusExtension$CertStatusRequestType of sun.security.ssl.CertStatusExtension
final CertStatusRequestV2Spec = sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec of sun.security.ssl.CertStatusExtension
final OCSPStatusRequest = sun.security.ssl.CertStatusExtension$OCSPStatusRequest of sun.security.ssl.CertStatusExtension
abstract SSLExtensionSpec = sun.security.ssl.SSLExtension$SSLExtensionSpec of sun.security.ssl.SSLExtension