final class sun.security.ssl.CertStatusExtension$CTCertStatusResponseProducer implements sun.security.ssl.HandshakeProducer
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.CertStatusExtension$CTCertStatusResponseProducer
  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.CertStatusExtension$CTCertStatusResponseProducer this
         0: .line 1100
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 1102
            return
        end local 0 // sun.security.ssl.CertStatusExtension$CTCertStatusResponseProducer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/ssl/CertStatusExtension$CTCertStatusResponseProducer;

  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=4, locals=9, args_size=3
        start local 0 // sun.security.ssl.CertStatusExtension$CTCertStatusResponseProducer this
        start local 1 // sun.security.ssl.ConnectionContext context
        start local 2 // sun.security.ssl.SSLHandshake$HandshakeMessage message
         0: .line 1107
            aload 1 /* context */
            checkcast sun.security.ssl.ServerHandshakeContext
            astore 3 /* shc */
        start local 3 // sun.security.ssl.ServerHandshakeContext shc
         1: .line 1108
            aconst_null
            astore 4 /* producedData */
        start local 4 // byte[] producedData
         2: .line 1111
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.stapleParams:Lsun/security/ssl/StatusResponseManager$StaplingParameters;
            ifnonnull 7
         3: .line 1112
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 6
            ldc "ssl,handshake"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 6
         4: .line 1114
            ldc "Stapling is disabled for this connection"
            iconst_0
            anewarray java.lang.Object
         5: .line 1113
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
         6: .line 1116
      StackMap locals: sun.security.ssl.ServerHandshakeContext byte[]
      StackMap stack:
            aconst_null
            areturn
         7: .line 1120
      StackMap locals:
      StackMap stack:
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.currentCertEntry:Lsun/security/ssl/CertificateMessage$CertificateEntry;
            ifnonnull 11
         8: .line 1121
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 10
            ldc "ssl,handshake"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 10
         9: .line 1122
            ldc "Found null CertificateEntry in context"
            iconst_0
            anewarray java.lang.Object
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        10: .line 1124
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        11: .line 1131
      StackMap locals:
      StackMap stack:
            ldc "X.509"
            invokestatic java.security.cert.CertificateFactory.getInstance:(Ljava/lang/String;)Ljava/security/cert/CertificateFactory;
            astore 5 /* cf */
        start local 5 // java.security.cert.CertificateFactory cf
        12: .line 1133
            aload 5 /* cf */
        13: .line 1134
            new java.io.ByteArrayInputStream
            dup
        14: .line 1135
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.currentCertEntry:Lsun/security/ssl/CertificateMessage$CertificateEntry;
            getfield sun.security.ssl.CertificateMessage$CertificateEntry.encoded:[B
        15: .line 1134
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
        16: .line 1133
            invokevirtual java.security.cert.CertificateFactory.generateCertificate:(Ljava/io/InputStream;)Ljava/security/cert/Certificate;
            checkcast java.security.cert.X509Certificate
        17: .line 1132
            astore 6 /* x509Cert */
        start local 6 // java.security.cert.X509Certificate x509Cert
        18: .line 1136
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.stapleParams:Lsun/security/ssl/StatusResponseManager$StaplingParameters;
            getfield sun.security.ssl.StatusResponseManager$StaplingParameters.responseMap:Ljava/util/Map;
            aload 6 /* x509Cert */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast byte[]
            astore 7 /* respBytes */
        start local 7 // byte[] respBytes
        19: .line 1137
            aload 7 /* respBytes */
            ifnonnull 27
        20: .line 1139
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 25
        21: .line 1140
            ldc "ssl,handshake,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 25
        22: .line 1141
            new java.lang.StringBuilder
            dup
            ldc "No status response found for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        23: .line 1142
            aload 6 /* x509Cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        24: .line 1141
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        25: .line 1144
      StackMap locals: java.security.cert.CertificateFactory java.security.cert.X509Certificate byte[]
      StackMap stack:
            aload 3 /* shc */
            aconst_null
            putfield sun.security.ssl.ServerHandshakeContext.currentCertEntry:Lsun/security/ssl/CertificateMessage$CertificateEntry;
        26: .line 1145
            aconst_null
            areturn
        27: .line 1149
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 32
            ldc "ssl,handshake,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 32
        28: .line 1150
            new java.lang.StringBuilder
            dup
            ldc "Found status response for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        29: .line 1151
            aload 6 /* x509Cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        30: .line 1152
            ldc ", response length: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 7 /* respBytes */
            arraylength
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        31: .line 1150
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        32: .line 1154
      StackMap locals:
      StackMap stack:
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.stapleParams:Lsun/security/ssl/StatusResponseManager$StaplingParameters;
            getfield sun.security.ssl.StatusResponseManager$StaplingParameters.statReqType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
        33: .line 1155
            getstatic sun.security.ssl.CertStatusExtension$CertStatusRequestType.OCSP:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
        34: .line 1154
            if_acmpne 39
        35: .line 1156
            new sun.security.ssl.CertStatusExtension$OCSPStatusResponse
            dup
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.stapleParams:Lsun/security/ssl/StatusResponseManager$StaplingParameters;
            getfield sun.security.ssl.StatusResponseManager$StaplingParameters.statReqType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            getfield sun.security.ssl.CertStatusExtension$CertStatusRequestType.id:B
        36: .line 1157
            aload 7 /* respBytes */
        37: .line 1156
            invokespecial sun.security.ssl.CertStatusExtension$OCSPStatusResponse.<init>:(B[B)V
        38: .line 1157
            goto 42
        39: .line 1158
      StackMap locals:
      StackMap stack:
            new sun.security.ssl.CertStatusExtension$CertStatusResponse
            dup
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.stapleParams:Lsun/security/ssl/StatusResponseManager$StaplingParameters;
            getfield sun.security.ssl.StatusResponseManager$StaplingParameters.statReqType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            getfield sun.security.ssl.CertStatusExtension$CertStatusRequestType.id:B
        40: .line 1159
            aload 7 /* respBytes */
        41: .line 1158
            invokespecial sun.security.ssl.CertStatusExtension$CertStatusResponse.<init>:(B[B)V
        42: .line 1154
      StackMap locals:
      StackMap stack: sun.security.ssl.CertStatusExtension$CertStatusResponse
            astore 8 /* certResp */
        start local 8 // sun.security.ssl.CertStatusExtension$CertStatusResponse certResp
        43: .line 1160
            aload 8 /* certResp */
            invokevirtual sun.security.ssl.CertStatusExtension$CertStatusResponse.toByteArray:()[B
            astore 4 /* producedData */
        end local 8 // sun.security.ssl.CertStatusExtension$CertStatusResponse certResp
        end local 7 // byte[] respBytes
        end local 6 // java.security.cert.X509Certificate x509Cert
        end local 5 // java.security.cert.CertificateFactory cf
        44: .line 1161
            goto 53
      StackMap locals: sun.security.ssl.CertStatusExtension$CTCertStatusResponseProducer sun.security.ssl.ConnectionContext sun.security.ssl.SSLHandshake$HandshakeMessage sun.security.ssl.ServerHandshakeContext byte[]
      StackMap stack: java.security.cert.CertificateException
        45: astore 5 /* ce */
        start local 5 // java.security.cert.CertificateException ce
        46: .line 1162
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.BAD_CERTIFICATE:Lsun/security/ssl/Alert;
        47: .line 1163
            ldc "Failed to parse server certificates"
            aload 5 /* ce */
        48: .line 1162
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
            athrow
        end local 5 // java.security.cert.CertificateException ce
        49: .line 1164
      StackMap locals:
      StackMap stack: java.io.IOException
            astore 5 /* ioe */
        start local 5 // java.io.IOException ioe
        50: .line 1165
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.BAD_CERT_STATUS_RESPONSE:Lsun/security/ssl/Alert;
        51: .line 1166
            ldc "Failed to parse certificate status response"
            aload 5 /* ioe */
        52: .line 1165
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
            athrow
        end local 5 // java.io.IOException ioe
        53: .line 1170
      StackMap locals:
      StackMap stack:
            aload 3 /* shc */
            aconst_null
            putfield sun.security.ssl.ServerHandshakeContext.currentCertEntry:Lsun/security/ssl/CertificateMessage$CertificateEntry;
        54: .line 1171
            aload 4 /* producedData */
            areturn
        end local 4 // byte[] producedData
        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.CertStatusExtension$CTCertStatusResponseProducer this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   55     0          this  Lsun/security/ssl/CertStatusExtension$CTCertStatusResponseProducer;
            0   55     1       context  Lsun/security/ssl/ConnectionContext;
            0   55     2       message  Lsun/security/ssl/SSLHandshake$HandshakeMessage;
            1   55     3           shc  Lsun/security/ssl/ServerHandshakeContext;
            2   55     4  producedData  [B
           12   44     5            cf  Ljava/security/cert/CertificateFactory;
           18   44     6      x509Cert  Ljava/security/cert/X509Certificate;
           19   44     7     respBytes  [B
           43   44     8      certResp  Lsun/security/ssl/CertStatusExtension$CertStatusResponse;
           46   49     5            ce  Ljava/security/cert/CertificateException;
           50   53     5           ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
          11    26      45  Class java.security.cert.CertificateException
          27    44      45  Class java.security.cert.CertificateException
          11    26      49  Class java.io.IOException
          27    44      49  Class java.io.IOException
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      context  
      message  
}
SourceFile: "CertStatusExtension.java"
NestHost: sun.security.ssl.CertStatusExtension
InnerClasses:
  private final CTCertStatusResponseProducer = sun.security.ssl.CertStatusExtension$CTCertStatusResponseProducer of sun.security.ssl.CertStatusExtension
  final CertStatusRequestType = sun.security.ssl.CertStatusExtension$CertStatusRequestType of sun.security.ssl.CertStatusExtension
  CertStatusResponse = sun.security.ssl.CertStatusExtension$CertStatusResponse of sun.security.ssl.CertStatusExtension
  final OCSPStatusResponse = sun.security.ssl.CertStatusExtension$OCSPStatusResponse of sun.security.ssl.CertStatusExtension
  final CertificateEntry = sun.security.ssl.CertificateMessage$CertificateEntry of sun.security.ssl.CertificateMessage
  abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake
  final StaplingParameters = sun.security.ssl.StatusResponseManager$StaplingParameters of sun.security.ssl.StatusResponseManager