public class org.bouncycastle.ocsp.OCSPReqGenerator
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.bouncycastle.ocsp.OCSPReqGenerator
  super_class: java.lang.Object
{
  private java.util.List list;
    descriptor: Ljava/util/List;
    flags: (0x0002) ACC_PRIVATE

  private org.bouncycastle.asn1.x509.GeneralName requestorName;
    descriptor: Lorg/bouncycastle/asn1/x509/GeneralName;
    flags: (0x0002) ACC_PRIVATE

  private org.bouncycastle.asn1.x509.X509Extensions requestExtensions;
    descriptor: Lorg/bouncycastle/asn1/x509/X509Extensions;
    flags: (0x0002) ACC_PRIVATE

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
         0: .line 35
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 37
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield org.bouncycastle.ocsp.OCSPReqGenerator.list:Ljava/util/List;
         2: .line 38
            aload 0 /* this */
            aconst_null
            putfield org.bouncycastle.ocsp.OCSPReqGenerator.requestorName:Lorg/bouncycastle/asn1/x509/GeneralName;
         3: .line 39
            aload 0 /* this */
            aconst_null
            putfield org.bouncycastle.ocsp.OCSPReqGenerator.requestExtensions:Lorg/bouncycastle/asn1/x509/X509Extensions;
         4: .line 35
            return
        end local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/bouncycastle/ocsp/OCSPReqGenerator;

  public void addRequest(org.bouncycastle.ocsp.CertificateID);
    descriptor: (Lorg/bouncycastle/ocsp/CertificateID;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=2, args_size=2
        start local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
        start local 1 // org.bouncycastle.ocsp.CertificateID certId
         0: .line 69
            aload 0 /* this */
            getfield org.bouncycastle.ocsp.OCSPReqGenerator.list:Ljava/util/List;
            new org.bouncycastle.ocsp.OCSPReqGenerator$RequestObject
            dup
            aload 0 /* this */
            aload 1 /* certId */
            aconst_null
            invokespecial org.bouncycastle.ocsp.OCSPReqGenerator$RequestObject.<init>:(Lorg/bouncycastle/ocsp/OCSPReqGenerator;Lorg/bouncycastle/ocsp/CertificateID;Lorg/bouncycastle/asn1/x509/X509Extensions;)V
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         1: .line 70
            return
        end local 1 // org.bouncycastle.ocsp.CertificateID certId
        end local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/bouncycastle/ocsp/OCSPReqGenerator;
            0    2     1  certId  Lorg/bouncycastle/ocsp/CertificateID;
    MethodParameters:
        Name  Flags
      certId  

  public void addRequest(org.bouncycastle.ocsp.CertificateID, org.bouncycastle.asn1.x509.X509Extensions);
    descriptor: (Lorg/bouncycastle/ocsp/CertificateID;Lorg/bouncycastle/asn1/x509/X509Extensions;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=3, args_size=3
        start local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
        start local 1 // org.bouncycastle.ocsp.CertificateID certId
        start local 2 // org.bouncycastle.asn1.x509.X509Extensions singleRequestExtensions
         0: .line 82
            aload 0 /* this */
            getfield org.bouncycastle.ocsp.OCSPReqGenerator.list:Ljava/util/List;
            new org.bouncycastle.ocsp.OCSPReqGenerator$RequestObject
            dup
            aload 0 /* this */
            aload 1 /* certId */
            aload 2 /* singleRequestExtensions */
            invokespecial org.bouncycastle.ocsp.OCSPReqGenerator$RequestObject.<init>:(Lorg/bouncycastle/ocsp/OCSPReqGenerator;Lorg/bouncycastle/ocsp/CertificateID;Lorg/bouncycastle/asn1/x509/X509Extensions;)V
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         1: .line 83
            return
        end local 2 // org.bouncycastle.asn1.x509.X509Extensions singleRequestExtensions
        end local 1 // org.bouncycastle.ocsp.CertificateID certId
        end local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
      LocalVariableTable:
        Start  End  Slot                     Name  Signature
            0    2     0                     this  Lorg/bouncycastle/ocsp/OCSPReqGenerator;
            0    2     1                   certId  Lorg/bouncycastle/ocsp/CertificateID;
            0    2     2  singleRequestExtensions  Lorg/bouncycastle/asn1/x509/X509Extensions;
    MethodParameters:
                         Name  Flags
      certId                   
      singleRequestExtensions  

  public void setRequestorName(javax.security.auth.x500.X500Principal);
    descriptor: (Ljavax/security/auth/x500/X500Principal;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=3, args_size=2
        start local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
        start local 1 // javax.security.auth.x500.X500Principal requestorName
         0: .line 95
            aload 0 /* this */
            new org.bouncycastle.asn1.x509.GeneralName
            dup
            iconst_4
            new org.bouncycastle.jce.X509Principal
            dup
            aload 1 /* requestorName */
            invokevirtual javax.security.auth.x500.X500Principal.getEncoded:()[B
            invokespecial org.bouncycastle.jce.X509Principal.<init>:([B)V
            invokespecial org.bouncycastle.asn1.x509.GeneralName.<init>:(ILorg/bouncycastle/asn1/ASN1Encodable;)V
            putfield org.bouncycastle.ocsp.OCSPReqGenerator.requestorName:Lorg/bouncycastle/asn1/x509/GeneralName;
         1: .line 96
            goto 4
         2: .line 97
      StackMap locals:
      StackMap stack: java.io.IOException
            astore 2 /* e */
        start local 2 // java.io.IOException e
         3: .line 99
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "cannot encode principal: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        end local 2 // java.io.IOException e
         4: .line 101
      StackMap locals:
      StackMap stack:
            return
        end local 1 // javax.security.auth.x500.X500Principal requestorName
        end local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    5     0           this  Lorg/bouncycastle/ocsp/OCSPReqGenerator;
            0    5     1  requestorName  Ljavax/security/auth/x500/X500Principal;
            3    4     2              e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           0     1       2  Class java.io.IOException
    MethodParameters:
               Name  Flags
      requestorName  

  public void setRequestorName(org.bouncycastle.asn1.x509.GeneralName);
    descriptor: (Lorg/bouncycastle/asn1/x509/GeneralName;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
        start local 1 // org.bouncycastle.asn1.x509.GeneralName requestorName
         0: .line 106
            aload 0 /* this */
            aload 1 /* requestorName */
            putfield org.bouncycastle.ocsp.OCSPReqGenerator.requestorName:Lorg/bouncycastle/asn1/x509/GeneralName;
         1: .line 107
            return
        end local 1 // org.bouncycastle.asn1.x509.GeneralName requestorName
        end local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    2     0           this  Lorg/bouncycastle/ocsp/OCSPReqGenerator;
            0    2     1  requestorName  Lorg/bouncycastle/asn1/x509/GeneralName;
    MethodParameters:
               Name  Flags
      requestorName  

  public void setRequestExtensions(org.bouncycastle.asn1.x509.X509Extensions);
    descriptor: (Lorg/bouncycastle/asn1/x509/X509Extensions;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
        start local 1 // org.bouncycastle.asn1.x509.X509Extensions requestExtensions
         0: .line 112
            aload 0 /* this */
            aload 1 /* requestExtensions */
            putfield org.bouncycastle.ocsp.OCSPReqGenerator.requestExtensions:Lorg/bouncycastle/asn1/x509/X509Extensions;
         1: .line 113
            return
        end local 1 // org.bouncycastle.asn1.x509.X509Extensions requestExtensions
        end local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    2     0               this  Lorg/bouncycastle/ocsp/OCSPReqGenerator;
            0    2     1  requestExtensions  Lorg/bouncycastle/asn1/x509/X509Extensions;
    MethodParameters:
                   Name  Flags
      requestExtensions  

  private org.bouncycastle.ocsp.OCSPReq generateRequest(org.bouncycastle.asn1.DERObjectIdentifier, java.security.PrivateKey, java.security.cert.X509Certificate[], java.lang.String, java.security.SecureRandom);
    descriptor: (Lorg/bouncycastle/asn1/DERObjectIdentifier;Ljava/security/PrivateKey;[Ljava/security/cert/X509Certificate;Ljava/lang/String;Ljava/security/SecureRandom;)Lorg/bouncycastle/ocsp/OCSPReq;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=15, args_size=6
        start local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
        start local 1 // org.bouncycastle.asn1.DERObjectIdentifier signingAlgorithm
        start local 2 // java.security.PrivateKey key
        start local 3 // java.security.cert.X509Certificate[] chain
        start local 4 // java.lang.String provider
        start local 5 // java.security.SecureRandom random
         0: .line 123
            aload 0 /* this */
            getfield org.bouncycastle.ocsp.OCSPReqGenerator.list:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 6 /* it */
        start local 6 // java.util.Iterator it
         1: .line 125
            new org.bouncycastle.asn1.ASN1EncodableVector
            dup
            invokespecial org.bouncycastle.asn1.ASN1EncodableVector.<init>:()V
            astore 7 /* requests */
        start local 7 // org.bouncycastle.asn1.ASN1EncodableVector requests
         2: .line 127
            goto 7
         3: .line 131
      StackMap locals: java.util.Iterator org.bouncycastle.asn1.ASN1EncodableVector
      StackMap stack:
            aload 7 /* requests */
            aload 6 /* it */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.bouncycastle.ocsp.OCSPReqGenerator$RequestObject
            invokevirtual org.bouncycastle.ocsp.OCSPReqGenerator$RequestObject.toRequest:()Lorg/bouncycastle/asn1/ocsp/Request;
            invokevirtual org.bouncycastle.asn1.ASN1EncodableVector.add:(Lorg/bouncycastle/asn1/DEREncodable;)V
         4: .line 132
            goto 7
         5: .line 133
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 8 /* e */
        start local 8 // java.lang.Exception e
         6: .line 135
            new org.bouncycastle.ocsp.OCSPException
            dup
            ldc "exception creating Request"
            aload 8 /* e */
            invokespecial org.bouncycastle.ocsp.OCSPException.<init>:(Ljava/lang/String;Ljava/lang/Exception;)V
            athrow
        end local 8 // java.lang.Exception e
         7: .line 127
      StackMap locals:
      StackMap stack:
            aload 6 /* it */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         8: .line 139
            new org.bouncycastle.asn1.ocsp.TBSRequest
            dup
            aload 0 /* this */
            getfield org.bouncycastle.ocsp.OCSPReqGenerator.requestorName:Lorg/bouncycastle/asn1/x509/GeneralName;
            new org.bouncycastle.asn1.DERSequence
            dup
            aload 7 /* requests */
            invokespecial org.bouncycastle.asn1.DERSequence.<init>:(Lorg/bouncycastle/asn1/ASN1EncodableVector;)V
            aload 0 /* this */
            getfield org.bouncycastle.ocsp.OCSPReqGenerator.requestExtensions:Lorg/bouncycastle/asn1/x509/X509Extensions;
            invokespecial org.bouncycastle.asn1.ocsp.TBSRequest.<init>:(Lorg/bouncycastle/asn1/x509/GeneralName;Lorg/bouncycastle/asn1/ASN1Sequence;Lorg/bouncycastle/asn1/x509/X509Extensions;)V
            astore 8 /* tbsReq */
        start local 8 // org.bouncycastle.asn1.ocsp.TBSRequest tbsReq
         9: .line 141
            aconst_null
            astore 9 /* sig */
        start local 9 // java.security.Signature sig
        10: .line 142
            aconst_null
            astore 10 /* signature */
        start local 10 // org.bouncycastle.asn1.ocsp.Signature signature
        11: .line 144
            aload 1 /* signingAlgorithm */
            ifnull 51
        12: .line 146
            aload 0 /* this */
            getfield org.bouncycastle.ocsp.OCSPReqGenerator.requestorName:Lorg/bouncycastle/asn1/x509/GeneralName;
            ifnonnull 14
        13: .line 148
            new org.bouncycastle.ocsp.OCSPException
            dup
            ldc "requestorName must be specified if request is signed."
            invokespecial org.bouncycastle.ocsp.OCSPException.<init>:(Ljava/lang/String;)V
            athrow
        14: .line 153
      StackMap locals: org.bouncycastle.asn1.ocsp.TBSRequest java.security.Signature org.bouncycastle.asn1.ocsp.Signature
      StackMap stack:
            aload 1 /* signingAlgorithm */
            invokevirtual org.bouncycastle.asn1.DERObjectIdentifier.getId:()Ljava/lang/String;
            aload 4 /* provider */
            invokestatic org.bouncycastle.ocsp.OCSPUtil.createSignatureInstance:(Ljava/lang/String;Ljava/lang/String;)Ljava/security/Signature;
            astore 9 /* sig */
        15: .line 154
            aload 5 /* random */
            ifnull 18
        16: .line 156
            aload 9 /* sig */
            aload 2 /* key */
            aload 5 /* random */
            invokevirtual java.security.Signature.initSign:(Ljava/security/PrivateKey;Ljava/security/SecureRandom;)V
        17: .line 157
            goto 24
        18: .line 160
      StackMap locals:
      StackMap stack:
            aload 9 /* sig */
            aload 2 /* key */
            invokevirtual java.security.Signature.initSign:(Ljava/security/PrivateKey;)V
        19: .line 162
            goto 24
        20: .line 163
      StackMap locals:
      StackMap stack: java.security.NoSuchProviderException
            astore 11 /* e */
        start local 11 // java.security.NoSuchProviderException e
        21: .line 166
            aload 11 /* e */
            athrow
        end local 11 // java.security.NoSuchProviderException e
        22: .line 168
      StackMap locals:
      StackMap stack: java.security.GeneralSecurityException
            astore 11 /* e */
        start local 11 // java.security.GeneralSecurityException e
        23: .line 170
            new org.bouncycastle.ocsp.OCSPException
            dup
            new java.lang.StringBuilder
            dup
            ldc "exception creating signature: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 11 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 11 /* e */
            invokespecial org.bouncycastle.ocsp.OCSPException.<init>:(Ljava/lang/String;Ljava/lang/Exception;)V
            athrow
        end local 11 // java.security.GeneralSecurityException e
        24: .line 173
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 11 /* bitSig */
        start local 11 // org.bouncycastle.asn1.DERBitString bitSig
        25: .line 177
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 12 /* bOut */
        start local 12 // java.io.ByteArrayOutputStream bOut
        26: .line 178
            new org.bouncycastle.asn1.ASN1OutputStream
            dup
            aload 12 /* bOut */
            invokespecial org.bouncycastle.asn1.ASN1OutputStream.<init>:(Ljava/io/OutputStream;)V
            astore 13 /* aOut */
        start local 13 // org.bouncycastle.asn1.ASN1OutputStream aOut
        27: .line 180
            aload 13 /* aOut */
            aload 8 /* tbsReq */
            invokevirtual org.bouncycastle.asn1.ASN1OutputStream.writeObject:(Ljava/lang/Object;)V
        28: .line 182
            aload 9 /* sig */
            aload 12 /* bOut */
            invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
            invokevirtual java.security.Signature.update:([B)V
        29: .line 184
            new org.bouncycastle.asn1.DERBitString
            dup
            aload 9 /* sig */
            invokevirtual java.security.Signature.sign:()[B
            invokespecial org.bouncycastle.asn1.DERBitString.<init>:([B)V
            astore 11 /* bitSig */
        end local 13 // org.bouncycastle.asn1.ASN1OutputStream aOut
        end local 12 // java.io.ByteArrayOutputStream bOut
        30: .line 185
            goto 33
        31: .line 186
      StackMap locals: org.bouncycastle.ocsp.OCSPReqGenerator org.bouncycastle.asn1.DERObjectIdentifier java.security.PrivateKey java.security.cert.X509Certificate[] java.lang.String java.security.SecureRandom java.util.Iterator org.bouncycastle.asn1.ASN1EncodableVector org.bouncycastle.asn1.ocsp.TBSRequest java.security.Signature org.bouncycastle.asn1.ocsp.Signature org.bouncycastle.asn1.DERBitString
      StackMap stack: java.lang.Exception
            astore 12 /* e */
        start local 12 // java.lang.Exception e
        32: .line 188
            new org.bouncycastle.ocsp.OCSPException
            dup
            new java.lang.StringBuilder
            dup
            ldc "exception processing TBSRequest: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 12 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 12 /* e */
            invokespecial org.bouncycastle.ocsp.OCSPException.<init>:(Ljava/lang/String;Ljava/lang/Exception;)V
            athrow
        end local 12 // java.lang.Exception e
        33: .line 191
      StackMap locals:
      StackMap stack:
            new org.bouncycastle.asn1.x509.AlgorithmIdentifier
            dup
            aload 1 /* signingAlgorithm */
            new org.bouncycastle.asn1.DERNull
            dup
            invokespecial org.bouncycastle.asn1.DERNull.<init>:()V
            invokespecial org.bouncycastle.asn1.x509.AlgorithmIdentifier.<init>:(Lorg/bouncycastle/asn1/DERObjectIdentifier;Lorg/bouncycastle/asn1/DEREncodable;)V
            astore 12 /* sigAlgId */
        start local 12 // org.bouncycastle.asn1.x509.AlgorithmIdentifier sigAlgId
        34: .line 193
            aload 3 /* chain */
            ifnull 50
            aload 3 /* chain */
            arraylength
            ifle 50
        35: .line 195
            new org.bouncycastle.asn1.ASN1EncodableVector
            dup
            invokespecial org.bouncycastle.asn1.ASN1EncodableVector.<init>:()V
            astore 13 /* v */
        start local 13 // org.bouncycastle.asn1.ASN1EncodableVector v
        36: .line 198
            iconst_0
            istore 14 /* i */
        start local 14 // int i
        37: goto 42
        38: .line 200
      StackMap locals: org.bouncycastle.asn1.x509.AlgorithmIdentifier org.bouncycastle.asn1.ASN1EncodableVector int
      StackMap stack:
            aload 13 /* v */
            new org.bouncycastle.asn1.x509.X509CertificateStructure
            dup
        39: .line 201
            aload 3 /* chain */
            iload 14 /* i */
            aaload
            invokevirtual java.security.cert.X509Certificate.getEncoded:()[B
            invokestatic org.bouncycastle.asn1.ASN1Object.fromByteArray:([B)Lorg/bouncycastle/asn1/ASN1Object;
            checkcast org.bouncycastle.asn1.ASN1Sequence
            invokespecial org.bouncycastle.asn1.x509.X509CertificateStructure.<init>:(Lorg/bouncycastle/asn1/ASN1Sequence;)V
        40: .line 200
            invokevirtual org.bouncycastle.asn1.ASN1EncodableVector.add:(Lorg/bouncycastle/asn1/DEREncodable;)V
        41: .line 198
            iinc 14 /* i */ 1
      StackMap locals:
      StackMap stack:
        42: iload 14 /* i */
            aload 3 /* chain */
            arraylength
            if_icmpne 38
        end local 14 // int i
        43: .line 203
            goto 48
        44: .line 204
      StackMap locals: org.bouncycastle.ocsp.OCSPReqGenerator org.bouncycastle.asn1.DERObjectIdentifier java.security.PrivateKey java.security.cert.X509Certificate[] java.lang.String java.security.SecureRandom java.util.Iterator org.bouncycastle.asn1.ASN1EncodableVector org.bouncycastle.asn1.ocsp.TBSRequest java.security.Signature org.bouncycastle.asn1.ocsp.Signature org.bouncycastle.asn1.DERBitString org.bouncycastle.asn1.x509.AlgorithmIdentifier org.bouncycastle.asn1.ASN1EncodableVector
      StackMap stack: java.io.IOException
            astore 14 /* e */
        start local 14 // java.io.IOException e
        45: .line 206
            new org.bouncycastle.ocsp.OCSPException
            dup
            ldc "error processing certs"
            aload 14 /* e */
            invokespecial org.bouncycastle.ocsp.OCSPException.<init>:(Ljava/lang/String;Ljava/lang/Exception;)V
            athrow
        end local 14 // java.io.IOException e
        46: .line 208
      StackMap locals:
      StackMap stack: java.security.cert.CertificateEncodingException
            astore 14 /* e */
        start local 14 // java.security.cert.CertificateEncodingException e
        47: .line 210
            new org.bouncycastle.ocsp.OCSPException
            dup
            ldc "error encoding certs"
            aload 14 /* e */
            invokespecial org.bouncycastle.ocsp.OCSPException.<init>:(Ljava/lang/String;Ljava/lang/Exception;)V
            athrow
        end local 14 // java.security.cert.CertificateEncodingException e
        48: .line 213
      StackMap locals:
      StackMap stack:
            new org.bouncycastle.asn1.ocsp.Signature
            dup
            aload 12 /* sigAlgId */
            aload 11 /* bitSig */
            new org.bouncycastle.asn1.DERSequence
            dup
            aload 13 /* v */
            invokespecial org.bouncycastle.asn1.DERSequence.<init>:(Lorg/bouncycastle/asn1/ASN1EncodableVector;)V
            invokespecial org.bouncycastle.asn1.ocsp.Signature.<init>:(Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;Lorg/bouncycastle/asn1/DERBitString;Lorg/bouncycastle/asn1/ASN1Sequence;)V
            astore 10 /* signature */
        end local 13 // org.bouncycastle.asn1.ASN1EncodableVector v
        49: .line 214
            goto 51
        50: .line 217
      StackMap locals:
      StackMap stack:
            new org.bouncycastle.asn1.ocsp.Signature
            dup
            aload 12 /* sigAlgId */
            aload 11 /* bitSig */
            invokespecial org.bouncycastle.asn1.ocsp.Signature.<init>:(Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;Lorg/bouncycastle/asn1/DERBitString;)V
            astore 10 /* signature */
        end local 12 // org.bouncycastle.asn1.x509.AlgorithmIdentifier sigAlgId
        end local 11 // org.bouncycastle.asn1.DERBitString bitSig
        51: .line 221
      StackMap locals:
      StackMap stack:
            new org.bouncycastle.ocsp.OCSPReq
            dup
            new org.bouncycastle.asn1.ocsp.OCSPRequest
            dup
            aload 8 /* tbsReq */
            aload 10 /* signature */
            invokespecial org.bouncycastle.asn1.ocsp.OCSPRequest.<init>:(Lorg/bouncycastle/asn1/ocsp/TBSRequest;Lorg/bouncycastle/asn1/ocsp/Signature;)V
            invokespecial org.bouncycastle.ocsp.OCSPReq.<init>:(Lorg/bouncycastle/asn1/ocsp/OCSPRequest;)V
            areturn
        end local 10 // org.bouncycastle.asn1.ocsp.Signature signature
        end local 9 // java.security.Signature sig
        end local 8 // org.bouncycastle.asn1.ocsp.TBSRequest tbsReq
        end local 7 // org.bouncycastle.asn1.ASN1EncodableVector requests
        end local 6 // java.util.Iterator it
        end local 5 // java.security.SecureRandom random
        end local 4 // java.lang.String provider
        end local 3 // java.security.cert.X509Certificate[] chain
        end local 2 // java.security.PrivateKey key
        end local 1 // org.bouncycastle.asn1.DERObjectIdentifier signingAlgorithm
        end local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   52     0              this  Lorg/bouncycastle/ocsp/OCSPReqGenerator;
            0   52     1  signingAlgorithm  Lorg/bouncycastle/asn1/DERObjectIdentifier;
            0   52     2               key  Ljava/security/PrivateKey;
            0   52     3             chain  [Ljava/security/cert/X509Certificate;
            0   52     4          provider  Ljava/lang/String;
            0   52     5            random  Ljava/security/SecureRandom;
            1   52     6                it  Ljava/util/Iterator;
            2   52     7          requests  Lorg/bouncycastle/asn1/ASN1EncodableVector;
            6    7     8                 e  Ljava/lang/Exception;
            9   52     8            tbsReq  Lorg/bouncycastle/asn1/ocsp/TBSRequest;
           10   52     9               sig  Ljava/security/Signature;
           11   52    10         signature  Lorg/bouncycastle/asn1/ocsp/Signature;
           21   22    11                 e  Ljava/security/NoSuchProviderException;
           23   24    11                 e  Ljava/security/GeneralSecurityException;
           25   51    11            bitSig  Lorg/bouncycastle/asn1/DERBitString;
           26   30    12              bOut  Ljava/io/ByteArrayOutputStream;
           27   30    13              aOut  Lorg/bouncycastle/asn1/ASN1OutputStream;
           32   33    12                 e  Ljava/lang/Exception;
           34   51    12          sigAlgId  Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;
           36   49    13                 v  Lorg/bouncycastle/asn1/ASN1EncodableVector;
           37   43    14                 i  I
           45   46    14                 e  Ljava/io/IOException;
           47   48    14                 e  Ljava/security/cert/CertificateEncodingException;
      Exception table:
        from    to  target  type
           3     4       5  Class java.lang.Exception
          14    19      20  Class java.security.NoSuchProviderException
          14    19      22  Class java.security.GeneralSecurityException
          25    30      31  Class java.lang.Exception
          36    43      44  Class java.io.IOException
          36    43      46  Class java.security.cert.CertificateEncodingException
    Exceptions:
      throws org.bouncycastle.ocsp.OCSPException, java.security.NoSuchProviderException
    MethodParameters:
                  Name  Flags
      signingAlgorithm  
      key               
      chain             
      provider          
      random            

  public org.bouncycastle.ocsp.OCSPReq generate();
    descriptor: ()Lorg/bouncycastle/ocsp/OCSPReq;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=2, args_size=1
        start local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
         0: .line 235
            aload 0 /* this */
            aconst_null
            aconst_null
            aconst_null
            aconst_null
            aconst_null
            invokevirtual org.bouncycastle.ocsp.OCSPReqGenerator.generateRequest:(Lorg/bouncycastle/asn1/DERObjectIdentifier;Ljava/security/PrivateKey;[Ljava/security/cert/X509Certificate;Ljava/lang/String;Ljava/security/SecureRandom;)Lorg/bouncycastle/ocsp/OCSPReq;
         1: areturn
         2: .line 237
      StackMap locals:
      StackMap stack: java.security.NoSuchProviderException
            astore 1 /* e */
        start local 1 // java.security.NoSuchProviderException e
         3: .line 242
            new org.bouncycastle.ocsp.OCSPException
            dup
            new java.lang.StringBuilder
            dup
            ldc "no provider! - "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 1 /* e */
            invokespecial org.bouncycastle.ocsp.OCSPException.<init>:(Ljava/lang/String;Ljava/lang/Exception;)V
            athrow
        end local 1 // java.security.NoSuchProviderException e
        end local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/bouncycastle/ocsp/OCSPReqGenerator;
            3    4     1     e  Ljava/security/NoSuchProviderException;
      Exception table:
        from    to  target  type
           0     1       2  Class java.security.NoSuchProviderException
    Exceptions:
      throws org.bouncycastle.ocsp.OCSPException

  public org.bouncycastle.ocsp.OCSPReq generate(java.lang.String, java.security.PrivateKey, java.security.cert.X509Certificate[], java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/security/PrivateKey;[Ljava/security/cert/X509Certificate;Ljava/lang/String;)Lorg/bouncycastle/ocsp/OCSPReq;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=5, args_size=5
        start local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
        start local 1 // java.lang.String signingAlgorithm
        start local 2 // java.security.PrivateKey key
        start local 3 // java.security.cert.X509Certificate[] chain
        start local 4 // java.lang.String provider
         0: .line 253
            aload 0 /* this */
            aload 1 /* signingAlgorithm */
            aload 2 /* key */
            aload 3 /* chain */
            aload 4 /* provider */
            aconst_null
            invokevirtual org.bouncycastle.ocsp.OCSPReqGenerator.generate:(Ljava/lang/String;Ljava/security/PrivateKey;[Ljava/security/cert/X509Certificate;Ljava/lang/String;Ljava/security/SecureRandom;)Lorg/bouncycastle/ocsp/OCSPReq;
            areturn
        end local 4 // java.lang.String provider
        end local 3 // java.security.cert.X509Certificate[] chain
        end local 2 // java.security.PrivateKey key
        end local 1 // java.lang.String signingAlgorithm
        end local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    1     0              this  Lorg/bouncycastle/ocsp/OCSPReqGenerator;
            0    1     1  signingAlgorithm  Ljava/lang/String;
            0    1     2               key  Ljava/security/PrivateKey;
            0    1     3             chain  [Ljava/security/cert/X509Certificate;
            0    1     4          provider  Ljava/lang/String;
    Exceptions:
      throws org.bouncycastle.ocsp.OCSPException, java.security.NoSuchProviderException, java.lang.IllegalArgumentException
    MethodParameters:
                  Name  Flags
      signingAlgorithm  
      key               
      chain             
      provider          

  public org.bouncycastle.ocsp.OCSPReq generate(java.lang.String, java.security.PrivateKey, java.security.cert.X509Certificate[], java.lang.String, java.security.SecureRandom);
    descriptor: (Ljava/lang/String;Ljava/security/PrivateKey;[Ljava/security/cert/X509Certificate;Ljava/lang/String;Ljava/security/SecureRandom;)Lorg/bouncycastle/ocsp/OCSPReq;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=7, args_size=6
        start local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
        start local 1 // java.lang.String signingAlgorithm
        start local 2 // java.security.PrivateKey key
        start local 3 // java.security.cert.X509Certificate[] chain
        start local 4 // java.lang.String provider
        start local 5 // java.security.SecureRandom random
         0: .line 264
            aload 1 /* signingAlgorithm */
            ifnonnull 2
         1: .line 266
            new java.lang.IllegalArgumentException
            dup
            ldc "no signing algorithm specified"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 271
      StackMap locals:
      StackMap stack:
            aload 1 /* signingAlgorithm */
            invokestatic org.bouncycastle.ocsp.OCSPUtil.getAlgorithmOID:(Ljava/lang/String;)Lorg/bouncycastle/asn1/DERObjectIdentifier;
            astore 6 /* oid */
        start local 6 // org.bouncycastle.asn1.DERObjectIdentifier oid
         3: .line 273
            aload 0 /* this */
            aload 6 /* oid */
            aload 2 /* key */
            aload 3 /* chain */
            aload 4 /* provider */
            aload 5 /* random */
            invokevirtual org.bouncycastle.ocsp.OCSPReqGenerator.generateRequest:(Lorg/bouncycastle/asn1/DERObjectIdentifier;Ljava/security/PrivateKey;[Ljava/security/cert/X509Certificate;Ljava/lang/String;Ljava/security/SecureRandom;)Lorg/bouncycastle/ocsp/OCSPReq;
         4: areturn
        end local 6 // org.bouncycastle.asn1.DERObjectIdentifier oid
         5: .line 275
      StackMap locals:
      StackMap stack: java.lang.IllegalArgumentException
            pop
         6: .line 277
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "unknown signing algorithm specified: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* signingAlgorithm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        end local 5 // java.security.SecureRandom random
        end local 4 // java.lang.String provider
        end local 3 // java.security.cert.X509Certificate[] chain
        end local 2 // java.security.PrivateKey key
        end local 1 // java.lang.String signingAlgorithm
        end local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    7     0              this  Lorg/bouncycastle/ocsp/OCSPReqGenerator;
            0    7     1  signingAlgorithm  Ljava/lang/String;
            0    7     2               key  Ljava/security/PrivateKey;
            0    7     3             chain  [Ljava/security/cert/X509Certificate;
            0    7     4          provider  Ljava/lang/String;
            0    7     5            random  Ljava/security/SecureRandom;
            3    5     6               oid  Lorg/bouncycastle/asn1/DERObjectIdentifier;
      Exception table:
        from    to  target  type
           2     4       5  Class java.lang.IllegalArgumentException
    Exceptions:
      throws org.bouncycastle.ocsp.OCSPException, java.security.NoSuchProviderException, java.lang.IllegalArgumentException
    MethodParameters:
                  Name  Flags
      signingAlgorithm  
      key               
      chain             
      provider          
      random            

  public java.util.Iterator getSignatureAlgNames();
    descriptor: ()Ljava/util/Iterator;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
         0: .line 288
            invokestatic org.bouncycastle.ocsp.OCSPUtil.getAlgNames:()Ljava/util/Iterator;
            areturn
        end local 0 // org.bouncycastle.ocsp.OCSPReqGenerator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/ocsp/OCSPReqGenerator;
}
SourceFile: "OCSPReqGenerator.java"
NestMembers:
  org.bouncycastle.ocsp.OCSPReqGenerator$RequestObject
InnerClasses:
  private RequestObject = org.bouncycastle.ocsp.OCSPReqGenerator$RequestObject of org.bouncycastle.ocsp.OCSPReqGenerator