class org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1 implements org.bouncycastle.cert.crmf.jcajce.CRMFHelper$JCECallback
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1
  super_class: java.lang.Object
{
  final org.bouncycastle.cert.crmf.jcajce.CRMFHelper this$0;
    descriptor: Lorg/bouncycastle/cert/crmf/jcajce/CRMFHelper;
    flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC

  private final org.bouncycastle.asn1.x509.AlgorithmIdentifier val$encryptionAlgID;
    descriptor: Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;
    flags: (0x1012) ACC_PRIVATE, ACC_FINAL, ACC_SYNTHETIC

  private final java.security.Key val$sKey;
    descriptor: Ljava/security/Key;
    flags: (0x1012) ACC_PRIVATE, ACC_FINAL, ACC_SYNTHETIC

  void <init>(org.bouncycastle.cert.crmf.jcajce.CRMFHelper, org.bouncycastle.asn1.x509.AlgorithmIdentifier, java.security.Key);
    descriptor: (Lorg/bouncycastle/cert/crmf/jcajce/CRMFHelper;Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;Ljava/security/Key;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=4, args_size=4
        start local 0 // org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1 this
         0: .line 167
            aload 0 /* this */
            aload 1
            putfield org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1.this$0:Lorg/bouncycastle/cert/crmf/jcajce/CRMFHelper;
            aload 0 /* this */
            aload 2
            putfield org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1.val$encryptionAlgID:Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;
            aload 0 /* this */
            aload 3
            putfield org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1.val$sKey:Ljava/security/Key;
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1 this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/cert/crmf/jcajce/CRMFHelper$1;
    MethodParameters:
                     Name  Flags
      this$0               final
      val$encryptionAlgID  final
      val$sKey             final

  public java.lang.Object doInJCE();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=6, args_size=1
        start local 0 // org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1 this
         0: .line 174
            aload 0 /* this */
            getfield org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1.this$0:Lorg/bouncycastle/cert/crmf/jcajce/CRMFHelper;
            aload 0 /* this */
            getfield org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1.val$encryptionAlgID:Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;
            invokevirtual org.bouncycastle.asn1.x509.AlgorithmIdentifier.getAlgorithm:()Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;
            invokevirtual org.bouncycastle.cert.crmf.jcajce.CRMFHelper.createCipher:(Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;)Ljavax/crypto/Cipher;
            astore 1 /* cipher */
        start local 1 // javax.crypto.Cipher cipher
         1: .line 175
            aload 0 /* this */
            getfield org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1.val$encryptionAlgID:Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;
            invokevirtual org.bouncycastle.asn1.x509.AlgorithmIdentifier.getParameters:()Lorg/bouncycastle/asn1/ASN1Encodable;
            checkcast org.bouncycastle.asn1.ASN1Primitive
            astore 2 /* sParams */
        start local 2 // org.bouncycastle.asn1.ASN1Primitive sParams
         2: .line 176
            aload 0 /* this */
            getfield org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1.val$encryptionAlgID:Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;
            invokevirtual org.bouncycastle.asn1.x509.AlgorithmIdentifier.getAlgorithm:()Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;
            astore 3 /* encAlg */
        start local 3 // org.bouncycastle.asn1.ASN1ObjectIdentifier encAlg
         3: .line 178
            aload 2 /* sParams */
            ifnull 22
            aload 2 /* sParams */
            instanceof org.bouncycastle.asn1.ASN1Null
            ifne 22
         4: .line 182
            aload 0 /* this */
            getfield org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1.this$0:Lorg/bouncycastle/cert/crmf/jcajce/CRMFHelper;
            aload 0 /* this */
            getfield org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1.val$encryptionAlgID:Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;
            invokevirtual org.bouncycastle.asn1.x509.AlgorithmIdentifier.getAlgorithm:()Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;
            invokevirtual org.bouncycastle.cert.crmf.jcajce.CRMFHelper.createAlgorithmParameters:(Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;)Ljava/security/AlgorithmParameters;
            astore 4 /* params */
        start local 4 // java.security.AlgorithmParameters params
         5: .line 186
            aload 4 /* params */
            aload 2 /* sParams */
            invokestatic org.bouncycastle.jcajce.util.AlgorithmParametersUtils.loadParameters:(Ljava/security/AlgorithmParameters;Lorg/bouncycastle/asn1/ASN1Encodable;)V
         6: .line 187
            goto 9
         7: .line 188
      StackMap locals: org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1 javax.crypto.Cipher org.bouncycastle.asn1.ASN1Primitive org.bouncycastle.asn1.ASN1ObjectIdentifier java.security.AlgorithmParameters
      StackMap stack: java.io.IOException
            astore 5 /* e */
        start local 5 // java.io.IOException e
         8: .line 190
            new org.bouncycastle.cert.crmf.CRMFException
            dup
            ldc "error decoding algorithm parameters."
            aload 5 /* e */
            invokespecial org.bouncycastle.cert.crmf.CRMFException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 5 // java.io.IOException e
         9: .line 193
      StackMap locals:
      StackMap stack:
            aload 1 /* cipher */
            iconst_2
            aload 0 /* this */
            getfield org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1.val$sKey:Ljava/security/Key;
            aload 4 /* params */
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/AlgorithmParameters;)V
        end local 4 // java.security.AlgorithmParameters params
        10: .line 194
            goto 28
        11: .line 195
      StackMap locals: org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1 javax.crypto.Cipher org.bouncycastle.asn1.ASN1Primitive org.bouncycastle.asn1.ASN1ObjectIdentifier
      StackMap stack: java.security.NoSuchAlgorithmException
            astore 4 /* e */
        start local 4 // java.security.NoSuchAlgorithmException e
        12: .line 197
            aload 3 /* encAlg */
            getstatic org.bouncycastle.cms.CMSAlgorithm.DES_EDE3_CBC:Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;
            invokevirtual org.bouncycastle.asn1.ASN1ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifne 17
        13: .line 198
            aload 3 /* encAlg */
            getstatic org.bouncycastle.cms.CMSAlgorithm.IDEA_CBC:Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;
            invokevirtual org.bouncycastle.asn1.ASN1ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifne 17
        14: .line 199
            aload 3 /* encAlg */
            getstatic org.bouncycastle.cms.CMSAlgorithm.AES128_CBC:Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;
            invokevirtual org.bouncycastle.asn1.ASN1ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifne 17
        15: .line 200
            aload 3 /* encAlg */
            getstatic org.bouncycastle.cms.CMSAlgorithm.AES192_CBC:Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;
            invokevirtual org.bouncycastle.asn1.ASN1ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifne 17
        16: .line 201
            aload 3 /* encAlg */
            getstatic org.bouncycastle.cms.CMSAlgorithm.AES256_CBC:Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;
            invokevirtual org.bouncycastle.asn1.ASN1ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 21
        17: .line 203
      StackMap locals: java.security.NoSuchAlgorithmException
      StackMap stack:
            aload 1 /* cipher */
            iconst_2
            aload 0 /* this */
            getfield org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1.val$sKey:Ljava/security/Key;
            new javax.crypto.spec.IvParameterSpec
            dup
        18: .line 204
            aload 2 /* sParams */
            invokestatic org.bouncycastle.asn1.ASN1OctetString.getInstance:(Ljava/lang/Object;)Lorg/bouncycastle/asn1/ASN1OctetString;
            invokevirtual org.bouncycastle.asn1.ASN1OctetString.getOctets:()[B
            invokespecial javax.crypto.spec.IvParameterSpec.<init>:([B)V
        19: .line 203
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V
        20: .line 205
            goto 28
        21: .line 208
      StackMap locals:
      StackMap stack:
            aload 4 /* e */
            athrow
        end local 4 // java.security.NoSuchAlgorithmException e
        22: .line 214
      StackMap locals:
      StackMap stack:
            aload 3 /* encAlg */
            getstatic org.bouncycastle.cms.CMSAlgorithm.DES_EDE3_CBC:Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;
            invokevirtual org.bouncycastle.asn1.ASN1ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifne 25
        23: .line 215
            aload 3 /* encAlg */
            getstatic org.bouncycastle.cms.CMSAlgorithm.IDEA_CBC:Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;
            invokevirtual org.bouncycastle.asn1.ASN1ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifne 25
        24: .line 216
            aload 3 /* encAlg */
            getstatic org.bouncycastle.cms.CMSAlgorithm.CAST5_CBC:Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;
            invokevirtual org.bouncycastle.asn1.ASN1ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 27
        25: .line 218
      StackMap locals:
      StackMap stack:
            aload 1 /* cipher */
            iconst_2
            aload 0 /* this */
            getfield org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1.val$sKey:Ljava/security/Key;
            new javax.crypto.spec.IvParameterSpec
            dup
            bipush 8
            newarray 8
            invokespecial javax.crypto.spec.IvParameterSpec.<init>:([B)V
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V
        26: .line 219
            goto 28
        27: .line 222
      StackMap locals:
      StackMap stack:
            aload 1 /* cipher */
            iconst_2
            aload 0 /* this */
            getfield org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1.val$sKey:Ljava/security/Key;
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;)V
        28: .line 226
      StackMap locals:
      StackMap stack:
            aload 1 /* cipher */
            areturn
        end local 3 // org.bouncycastle.asn1.ASN1ObjectIdentifier encAlg
        end local 2 // org.bouncycastle.asn1.ASN1Primitive sParams
        end local 1 // javax.crypto.Cipher cipher
        end local 0 // org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1 this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   29     0     this  Lorg/bouncycastle/cert/crmf/jcajce/CRMFHelper$1;
            1   29     1   cipher  Ljavax/crypto/Cipher;
            2   29     2  sParams  Lorg/bouncycastle/asn1/ASN1Primitive;
            3   29     3   encAlg  Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;
            5   10     4   params  Ljava/security/AlgorithmParameters;
            8    9     5        e  Ljava/io/IOException;
           12   22     4        e  Ljava/security/NoSuchAlgorithmException;
      Exception table:
        from    to  target  type
           5     6       7  Class java.io.IOException
           4    10      11  Class java.security.NoSuchAlgorithmException
    Exceptions:
      throws org.bouncycastle.cert.crmf.CRMFException, java.security.InvalidAlgorithmParameterException, java.security.InvalidKeyException, java.security.spec.InvalidParameterSpecException, java.security.NoSuchAlgorithmException, javax.crypto.NoSuchPaddingException, java.security.NoSuchProviderException
}
SourceFile: "CRMFHelper.java"
EnclosingMethod: org.bouncycastle.cert.crmf.jcajce.CRMFHelper.createContentCipher:(Ljava/security/Key;Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;)Ljavax/crypto/Cipher;
NestHost: org.bouncycastle.cert.crmf.jcajce.CRMFHelper
InnerClasses:
  org.bouncycastle.cert.crmf.jcajce.CRMFHelper$1
  abstract JCECallback = org.bouncycastle.cert.crmf.jcajce.CRMFHelper$JCECallback of org.bouncycastle.cert.crmf.jcajce.CRMFHelper