X509V1CertificateGenerator.smali
.class public Lorg/spongycastle/x509/X509V1CertificateGenerator;
.super Ljava/lang/Object;
.source "X509V1CertificateGenerator.java"
# instance fields
.field private sigAlgId:Lorg/spongycastle/asn1/x509/AlgorithmIdentifier;
.field private sigOID:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
.field private signatureAlgorithm:Ljava/lang/String;
.field private tbsGen:Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;
# direct methods
.method public constructor <init>()V
.registers 2
.prologue
.line 48
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 49
new-instance v0, Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;
invoke-direct {v0}, Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;-><init>()V
iput-object v0, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->tbsGen:Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;
.line 50
return-void
.end method
.method private generateJcaObject(Lorg/spongycastle/asn1/x509/TBSCertificate;[B)Ljava/security/cert/X509Certificate;
.registers 6
.prologue
.line 348
new-instance v0, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v0}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
.line 350
invoke-virtual {v0, p1}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 351
iget-object v1, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->sigAlgId:Lorg/spongycastle/asn1/x509/AlgorithmIdentifier;
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 352
new-instance v1, Lorg/spongycastle/asn1/DERBitString;
invoke-direct {v1, p2}, Lorg/spongycastle/asn1/DERBitString;-><init>([B)V
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 356
:try_start_15
new-instance v1, Lorg/spongycastle/jce/provider/X509CertificateObject;
new-instance v2, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v2, v0}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-static {v2}, Lorg/spongycastle/asn1/x509/Certificate;->getInstance(Ljava/lang/Object;)Lorg/spongycastle/asn1/x509/Certificate;
move-result-object v0
invoke-direct {v1, v0}, Lorg/spongycastle/jce/provider/X509CertificateObject;-><init>(Lorg/spongycastle/asn1/x509/Certificate;)V
:try_end_23
.catch Ljava/security/cert/CertificateParsingException; {:try_start_15 .. :try_end_23} :catch_24
return-object v1
.line 358
:catch_24
move-exception v0
.line 360
new-instance v1, Lorg/spongycastle/x509/ExtCertificateEncodingException;
const-string v2, "exception producing certificate object"
invoke-direct {v1, v2, v0}, Lorg/spongycastle/x509/ExtCertificateEncodingException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v1
.end method
# virtual methods
.method public generate(Ljava/security/PrivateKey;)Ljava/security/cert/X509Certificate;
.registers 3
.prologue
.line 275
const/4 v0, 0x0
invoke-virtual {p0, p1, v0}, Lorg/spongycastle/x509/X509V1CertificateGenerator;->generate(Ljava/security/PrivateKey;Ljava/security/SecureRandom;)Ljava/security/cert/X509Certificate;
move-result-object v0
return-object v0
.end method
.method public generate(Ljava/security/PrivateKey;Ljava/lang/String;)Ljava/security/cert/X509Certificate;
.registers 4
.prologue
.line 316
const/4 v0, 0x0
invoke-virtual {p0, p1, p2, v0}, Lorg/spongycastle/x509/X509V1CertificateGenerator;->generate(Ljava/security/PrivateKey;Ljava/lang/String;Ljava/security/SecureRandom;)Ljava/security/cert/X509Certificate;
move-result-object v0
return-object v0
.end method
.method public generate(Ljava/security/PrivateKey;Ljava/lang/String;Ljava/security/SecureRandom;)Ljava/security/cert/X509Certificate;
.registers 10
.prologue
.line 330
iget-object v0, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->tbsGen:Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;
invoke-virtual {v0}, Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;->generateTBSCertificate()Lorg/spongycastle/asn1/x509/TBSCertificate;
move-result-object v5
.line 335
:try_start_6
iget-object v0, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->sigOID:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
iget-object v1, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->signatureAlgorithm:Ljava/lang/String;
move-object v2, p2
move-object v3, p1
move-object v4, p3
invoke-static/range {v0 .. v5}, Lorg/spongycastle/x509/X509Util;->calculateSignature(Lorg/spongycastle/asn1/ASN1ObjectIdentifier;Ljava/lang/String;Ljava/lang/String;Ljava/security/PrivateKey;Ljava/security/SecureRandom;Lorg/spongycastle/asn1/ASN1Encodable;)[B
:try_end_10
.catch Ljava/io/IOException; {:try_start_6 .. :try_end_10} :catch_16
move-result-object v0
.line 342
invoke-direct {p0, v5, v0}, Lorg/spongycastle/x509/X509V1CertificateGenerator;->generateJcaObject(Lorg/spongycastle/asn1/x509/TBSCertificate;[B)Ljava/security/cert/X509Certificate;
move-result-object v0
return-object v0
.line 337
:catch_16
move-exception v0
.line 339
new-instance v1, Lorg/spongycastle/x509/ExtCertificateEncodingException;
const-string v2, "exception encoding TBS cert"
invoke-direct {v1, v2, v0}, Lorg/spongycastle/x509/ExtCertificateEncodingException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v1
.end method
.method public generate(Ljava/security/PrivateKey;Ljava/security/SecureRandom;)Ljava/security/cert/X509Certificate;
.registers 6
.prologue
.line 291
iget-object v0, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->tbsGen:Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;
invoke-virtual {v0}, Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;->generateTBSCertificate()Lorg/spongycastle/asn1/x509/TBSCertificate;
move-result-object v0
.line 296
:try_start_6
iget-object v1, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->sigOID:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
iget-object v2, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->signatureAlgorithm:Ljava/lang/String;
invoke-static {v1, v2, p1, p2, v0}, Lorg/spongycastle/x509/X509Util;->calculateSignature(Lorg/spongycastle/asn1/ASN1ObjectIdentifier;Ljava/lang/String;Ljava/security/PrivateKey;Ljava/security/SecureRandom;Lorg/spongycastle/asn1/ASN1Encodable;)[B
:try_end_d
.catch Ljava/io/IOException; {:try_start_6 .. :try_end_d} :catch_13
move-result-object v1
.line 303
invoke-direct {p0, v0, v1}, Lorg/spongycastle/x509/X509V1CertificateGenerator;->generateJcaObject(Lorg/spongycastle/asn1/x509/TBSCertificate;[B)Ljava/security/cert/X509Certificate;
move-result-object v0
return-object v0
.line 298
:catch_13
move-exception v0
.line 300
new-instance v1, Lorg/spongycastle/x509/ExtCertificateEncodingException;
const-string v2, "exception encoding TBS cert"
invoke-direct {v1, v2, v0}, Lorg/spongycastle/x509/ExtCertificateEncodingException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v1
.end method
.method public generateX509Certificate(Ljava/security/PrivateKey;)Ljava/security/cert/X509Certificate;
.registers 4
.prologue
.line 187
:try_start_0
const-string v0, "SC"
const/4 v1, 0x0
invoke-virtual {p0, p1, v0, v1}, Lorg/spongycastle/x509/X509V1CertificateGenerator;->generateX509Certificate(Ljava/security/PrivateKey;Ljava/lang/String;Ljava/security/SecureRandom;)Ljava/security/cert/X509Certificate;
:try_end_6
.catch Ljava/security/NoSuchProviderException; {:try_start_0 .. :try_end_6} :catch_8
move-result-object v0
return-object v0
.line 191
:catch_8
move-exception v0
new-instance v0, Ljava/lang/SecurityException;
const-string v1, "BC provider not installed!"
invoke-direct {v0, v1}, Ljava/lang/SecurityException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public generateX509Certificate(Ljava/security/PrivateKey;Ljava/lang/String;)Ljava/security/cert/X509Certificate;
.registers 4
.prologue
.line 226
const/4 v0, 0x0
invoke-virtual {p0, p1, p2, v0}, Lorg/spongycastle/x509/X509V1CertificateGenerator;->generateX509Certificate(Ljava/security/PrivateKey;Ljava/lang/String;Ljava/security/SecureRandom;)Ljava/security/cert/X509Certificate;
move-result-object v0
return-object v0
.end method
.method public generateX509Certificate(Ljava/security/PrivateKey;Ljava/lang/String;Ljava/security/SecureRandom;)Ljava/security/cert/X509Certificate;
.registers 8
.prologue
.line 243
:try_start_0
invoke-virtual {p0, p1, p2, p3}, Lorg/spongycastle/x509/X509V1CertificateGenerator;->generate(Ljava/security/PrivateKey;Ljava/lang/String;Ljava/security/SecureRandom;)Ljava/security/cert/X509Certificate;
:try_end_3
.catch Ljava/security/NoSuchProviderException; {:try_start_0 .. :try_end_3} :catch_5
.catch Ljava/security/SignatureException; {:try_start_0 .. :try_end_3} :catch_7
.catch Ljava/security/InvalidKeyException; {:try_start_0 .. :try_end_3} :catch_9
.catch Ljava/security/GeneralSecurityException; {:try_start_0 .. :try_end_3} :catch_b
move-result-object v0
return-object v0
.line 247
:catch_5
move-exception v0
throw v0
.line 251
:catch_7
move-exception v0
throw v0
.line 255
:catch_9
move-exception v0
throw v0
.line 257
:catch_b
move-exception v0
.line 259
new-instance v1, Ljava/lang/SecurityException;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "exception: "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v0}, Ljava/lang/SecurityException;-><init>(Ljava/lang/String;)V
throw v1
.end method
.method public generateX509Certificate(Ljava/security/PrivateKey;Ljava/security/SecureRandom;)Ljava/security/cert/X509Certificate;
.registers 5
.prologue
.line 207
:try_start_0
const-string v0, "SC"
invoke-virtual {p0, p1, v0, p2}, Lorg/spongycastle/x509/X509V1CertificateGenerator;->generateX509Certificate(Ljava/security/PrivateKey;Ljava/lang/String;Ljava/security/SecureRandom;)Ljava/security/cert/X509Certificate;
:try_end_5
.catch Ljava/security/NoSuchProviderException; {:try_start_0 .. :try_end_5} :catch_7
move-result-object v0
return-object v0
.line 211
:catch_7
move-exception v0
new-instance v0, Ljava/lang/SecurityException;
const-string v1, "BC provider not installed!"
invoke-direct {v0, v1}, Ljava/lang/SecurityException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public getSignatureAlgNames()Ljava/util/Iterator;
.registers 2
.prologue
.line 371
invoke-static {}, Lorg/spongycastle/x509/X509Util;->getAlgNames()Ljava/util/Iterator;
move-result-object v0
return-object v0
.end method
.method public reset()V
.registers 2
.prologue
.line 57
new-instance v0, Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;
invoke-direct {v0}, Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;-><init>()V
iput-object v0, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->tbsGen:Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;
.line 58
return-void
.end method
.method public setIssuerDN(Ljavax/security/auth/x500/X500Principal;)V
.registers 6
.prologue
.line 83
:try_start_0
iget-object v0, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->tbsGen:Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;
new-instance v1, Lorg/spongycastle/jce/X509Principal;
invoke-virtual {p1}, Ljavax/security/auth/x500/X500Principal;->getEncoded()[B
move-result-object v2
invoke-direct {v1, v2}, Lorg/spongycastle/jce/X509Principal;-><init>([B)V
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;->setIssuer(Lorg/spongycastle/asn1/x509/X509Name;)V
:try_end_e
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_e} :catch_f
.line 88
return-void
.line 85
:catch_f
move-exception v0
.line 87
new-instance v1, Ljava/lang/IllegalArgumentException;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "can\'t process principal: "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v0}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v1
.end method
.method public setIssuerDN(Lorg/spongycastle/asn1/x509/X509Name;)V
.registers 3
.prologue
.line 98
iget-object v0, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->tbsGen:Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;
invoke-virtual {v0, p1}, Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;->setIssuer(Lorg/spongycastle/asn1/x509/X509Name;)V
.line 99
return-void
.end method
.method public setNotAfter(Ljava/util/Date;)V
.registers 4
.prologue
.line 110
iget-object v0, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->tbsGen:Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;
new-instance v1, Lorg/spongycastle/asn1/x509/Time;
invoke-direct {v1, p1}, Lorg/spongycastle/asn1/x509/Time;-><init>(Ljava/util/Date;)V
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;->setEndDate(Lorg/spongycastle/asn1/x509/Time;)V
.line 111
return-void
.end method
.method public setNotBefore(Ljava/util/Date;)V
.registers 4
.prologue
.line 104
iget-object v0, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->tbsGen:Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;
new-instance v1, Lorg/spongycastle/asn1/x509/Time;
invoke-direct {v1, p1}, Lorg/spongycastle/asn1/x509/Time;-><init>(Ljava/util/Date;)V
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;->setStartDate(Lorg/spongycastle/asn1/x509/Time;)V
.line 105
return-void
.end method
.method public setPublicKey(Ljava/security/PublicKey;)V
.registers 6
.prologue
.line 143
:try_start_0
iget-object v0, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->tbsGen:Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;
invoke-interface {p1}, Ljava/security/PublicKey;->getEncoded()[B
move-result-object v1
invoke-static {v1}, Lorg/spongycastle/asn1/x509/SubjectPublicKeyInfo;->getInstance(Ljava/lang/Object;)Lorg/spongycastle/asn1/x509/SubjectPublicKeyInfo;
move-result-object v1
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;->setSubjectPublicKeyInfo(Lorg/spongycastle/asn1/x509/SubjectPublicKeyInfo;)V
:try_end_d
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_d} :catch_e
.line 148
return-void
.line 145
:catch_e
move-exception v0
.line 147
new-instance v1, Ljava/lang/IllegalArgumentException;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "unable to process key - "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0}, Ljava/lang/Exception;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v0}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v1
.end method
.method public setSerialNumber(Ljava/math/BigInteger;)V
.registers 4
.prologue
.line 66
sget-object v0, Ljava/math/BigInteger;->ZERO:Ljava/math/BigInteger;
invoke-virtual {p1, v0}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v0
if-gtz v0, :cond_10
.line 68
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "serial number must be a positive integer"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 71
:cond_10
iget-object v0, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->tbsGen:Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;
new-instance v1, Lorg/spongycastle/asn1/ASN1Integer;
invoke-direct {v1, p1}, Lorg/spongycastle/asn1/ASN1Integer;-><init>(Ljava/math/BigInteger;)V
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;->setSerialNumber(Lorg/spongycastle/asn1/ASN1Integer;)V
.line 72
return-void
.end method
.method public setSignatureAlgorithm(Ljava/lang/String;)V
.registers 4
.prologue
.line 160
iput-object p1, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->signatureAlgorithm:Ljava/lang/String;
.line 164
:try_start_2
invoke-static {p1}, Lorg/spongycastle/x509/X509Util;->getAlgorithmOID(Ljava/lang/String;)Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->sigOID:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
:try_end_8
.catch Ljava/lang/Exception; {:try_start_2 .. :try_end_8} :catch_18
.line 171
iget-object v0, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->sigOID:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
invoke-static {v0, p1}, Lorg/spongycastle/x509/X509Util;->getSigAlgID(Lorg/spongycastle/asn1/ASN1ObjectIdentifier;Ljava/lang/String;)Lorg/spongycastle/asn1/x509/AlgorithmIdentifier;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->sigAlgId:Lorg/spongycastle/asn1/x509/AlgorithmIdentifier;
.line 173
iget-object v0, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->tbsGen:Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;
iget-object v1, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->sigAlgId:Lorg/spongycastle/asn1/x509/AlgorithmIdentifier;
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;->setSignature(Lorg/spongycastle/asn1/x509/AlgorithmIdentifier;)V
.line 174
return-void
.line 168
:catch_18
move-exception v0
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "Unknown signature type requested"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public setSubjectDN(Ljavax/security/auth/x500/X500Principal;)V
.registers 6
.prologue
.line 121
:try_start_0
iget-object v0, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->tbsGen:Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;
new-instance v1, Lorg/spongycastle/jce/X509Principal;
invoke-virtual {p1}, Ljavax/security/auth/x500/X500Principal;->getEncoded()[B
move-result-object v2
invoke-direct {v1, v2}, Lorg/spongycastle/jce/X509Principal;-><init>([B)V
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;->setSubject(Lorg/spongycastle/asn1/x509/X509Name;)V
:try_end_e
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_e} :catch_f
.line 126
return-void
.line 123
:catch_f
move-exception v0
.line 125
new-instance v1, Ljava/lang/IllegalArgumentException;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "can\'t process principal: "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v0}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v1
.end method
.method public setSubjectDN(Lorg/spongycastle/asn1/x509/X509Name;)V
.registers 3
.prologue
.line 135
iget-object v0, p0, Lorg/spongycastle/x509/X509V1CertificateGenerator;->tbsGen:Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;
invoke-virtual {v0, p1}, Lorg/spongycastle/asn1/x509/V1TBSCertificateGenerator;->setSubject(Lorg/spongycastle/asn1/x509/X509Name;)V
.line 136
return-void
.end method