final class sun.security.ssl.CertStatusExtension$CertStatusRequestSpec 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$CertStatusRequestSpec
super_class: java.lang.Object
{
static final sun.security.ssl.CertStatusExtension$CertStatusRequestSpec DEFAULT;
descriptor: Lsun/security/ssl/CertStatusExtension$CertStatusRequestSpec;
flags: (0x0018) ACC_STATIC, ACC_FINAL
final sun.security.ssl.CertStatusExtension$CertStatusRequest statusRequest;
descriptor: Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
flags: (0x0010) ACC_FINAL
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=3, locals=0, args_size=0
0: new sun.security.ssl.CertStatusExtension$CertStatusRequestSpec
dup
getstatic sun.security.ssl.CertStatusExtension$OCSPStatusRequest.EMPTY_OCSP:Lsun/security/ssl/CertStatusExtension$OCSPStatusRequest;
invokespecial sun.security.ssl.CertStatusExtension$CertStatusRequestSpec.<init>:(Lsun/security/ssl/CertStatusExtension$CertStatusRequest;)V
1: putstatic sun.security.ssl.CertStatusExtension$CertStatusRequestSpec.DEFAULT:Lsun/security/ssl/CertStatusExtension$CertStatusRequestSpec;
2: 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$CertStatusRequestSpec.statusRequest: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$CertStatusRequestSpec;
0 3 1 statusRequest Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
MethodParameters:
Name Flags
statusRequest
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=5, locals=5, 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
aconst_null
putfield sun.security.ssl.CertStatusExtension$CertStatusRequestSpec.statusRequest:Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
3: return
4: StackMap locals: sun.security.ssl.CertStatusExtension$CertStatusRequestSpec sun.security.ssl.HandshakeContext java.nio.ByteBuffer
StackMap stack:
aload 2
invokevirtual java.nio.ByteBuffer.remaining:()I
iconst_1
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 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.getInt8:(Ljava/nio/ByteBuffer;)I
i2b
istore 3
start local 3 11: aload 2
invokevirtual java.nio.ByteBuffer.remaining:()I
newarray 8
astore 4
start local 4 12: aload 4
arraylength
ifeq 14
13: aload 2
aload 4
invokevirtual java.nio.ByteBuffer.get:([B)Ljava/nio/ByteBuffer;
pop
14: StackMap locals: int byte[]
StackMap stack:
iload 3
getstatic sun.security.ssl.CertStatusExtension$CertStatusRequestType.OCSP:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
getfield sun.security.ssl.CertStatusExtension$CertStatusRequestType.id:B
if_icmpne 17
15: aload 0
new sun.security.ssl.CertStatusExtension$OCSPStatusRequest
dup
iload 3
aload 4
invokespecial sun.security.ssl.CertStatusExtension$OCSPStatusRequest.<init>:(B[B)V
putfield sun.security.ssl.CertStatusExtension$CertStatusRequestSpec.statusRequest:Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
16: goto 23
17: StackMap locals:
StackMap stack:
getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 22
ldc "ssl,handshake"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 22
18: new java.lang.StringBuilder
dup
ldc "Unknown certificate status request (status type: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
19: iload 3
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
ldc ")"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
20: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
21: invokestatic sun.security.ssl.SSLLogger.info:(Ljava/lang/String;[Ljava/lang/Object;)V
22: StackMap locals:
StackMap stack:
aload 0
new sun.security.ssl.CertStatusExtension$CertStatusRequest
dup
iload 3
aload 4
invokespecial sun.security.ssl.CertStatusExtension$CertStatusRequest.<init>:(B[B)V
putfield sun.security.ssl.CertStatusExtension$CertStatusRequestSpec.statusRequest:Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
23: StackMap locals:
StackMap stack:
return
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 24 0 this Lsun/security/ssl/CertStatusExtension$CertStatusRequestSpec;
0 24 1 hc Lsun/security/ssl/HandshakeContext;
0 24 2 buffer Ljava/nio/ByteBuffer;
11 24 3 statusType B
12 24 4 encoded [B
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
hc
buffer
public java.lang.String toString();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.CertStatusExtension$CertStatusRequestSpec.statusRequest:Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
ifnonnull 2
1: ldc "<empty>"
goto 3
StackMap locals:
StackMap stack:
2: aload 0
getfield sun.security.ssl.CertStatusExtension$CertStatusRequestSpec.statusRequest:Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
invokevirtual sun.security.ssl.CertStatusExtension$CertStatusRequest.toString:()Ljava/lang/String;
3: StackMap locals:
StackMap stack: java.lang.String
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lsun/security/ssl/CertStatusExtension$CertStatusRequestSpec;
}
SourceFile: "CertStatusExtension.java"
NestHost: sun.security.ssl.CertStatusExtension
InnerClasses:
CertStatusRequest = sun.security.ssl.CertStatusExtension$CertStatusRequest of sun.security.ssl.CertStatusExtension
final CertStatusRequestSpec = sun.security.ssl.CertStatusExtension$CertStatusRequestSpec of sun.security.ssl.CertStatusExtension
final CertStatusRequestType = sun.security.ssl.CertStatusExtension$CertStatusRequestType 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