McElieceCCA2KeyFactorySpi.smali
.class public Lorg/spongycastle/pqc/jcajce/provider/mceliece/McElieceCCA2KeyFactorySpi;
.super Ljava/security/KeyFactorySpi;
.source "McElieceCCA2KeyFactorySpi.java"
# static fields
.field public static final OID:Ljava/lang/String; = "1.3.6.1.4.1.8301.3.1.3.4.2"
# direct methods
.method public constructor <init>()V
.registers 1
.prologue
.line 36
invoke-direct {p0}, Ljava/security/KeyFactorySpi;-><init>()V
return-void
.end method
# virtual methods
.method protected engineGeneratePrivate(Ljava/security/spec/KeySpec;)Ljava/security/PrivateKey;
.registers 3
.prologue
.line 332
const/4 v0, 0x0
return-object v0
.end method
.method protected engineGeneratePublic(Ljava/security/spec/KeySpec;)Ljava/security/PublicKey;
.registers 3
.prologue
.line 326
const/4 v0, 0x0
return-object v0
.end method
.method protected engineGetKeySpec(Ljava/security/Key;Ljava/lang/Class;)Ljava/security/spec/KeySpec;
.registers 4
.prologue
.line 338
const/4 v0, 0x0
return-object v0
.end method
.method protected engineTranslateKey(Ljava/security/Key;)Ljava/security/Key;
.registers 3
.prologue
.line 344
const/4 v0, 0x0
return-object v0
.end method
.method public generatePrivate(Ljava/security/spec/KeySpec;)Ljava/security/PrivateKey;
.registers 12
.prologue
const/4 v9, 0x0
.line 129
instance-of v0, p1, Lorg/spongycastle/pqc/jcajce/spec/McElieceCCA2PrivateKeySpec;
if-eqz v0, :cond_d
.line 131
new-instance v0, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PrivateKey;
check-cast p1, Lorg/spongycastle/pqc/jcajce/spec/McElieceCCA2PrivateKeySpec;
invoke-direct {v0, p1}, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PrivateKey;-><init>(Lorg/spongycastle/pqc/jcajce/spec/McElieceCCA2PrivateKeySpec;)V
.line 190
:goto_c
return-object v0
.line 134
:cond_d
instance-of v0, p1, Ljava/security/spec/PKCS8EncodedKeySpec;
if-eqz v0, :cond_ce
.line 137
check-cast p1, Ljava/security/spec/PKCS8EncodedKeySpec;
invoke-virtual {p1}, Ljava/security/spec/PKCS8EncodedKeySpec;->getEncoded()[B
move-result-object v0
.line 144
:try_start_17
invoke-static {v0}, Lorg/spongycastle/asn1/ASN1Primitive;->fromByteArray([B)Lorg/spongycastle/asn1/ASN1Primitive;
move-result-object v0
invoke-static {v0}, Lorg/spongycastle/asn1/pkcs/PrivateKeyInfo;->getInstance(Ljava/lang/Object;)Lorg/spongycastle/asn1/pkcs/PrivateKeyInfo;
:try_end_1e
.catch Ljava/io/IOException; {:try_start_17 .. :try_end_1e} :catch_a0
move-result-object v0
.line 154
:try_start_1f
invoke-virtual {v0}, Lorg/spongycastle/asn1/pkcs/PrivateKeyInfo;->parsePrivateKey()Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v0
invoke-interface {v0}, Lorg/spongycastle/asn1/ASN1Encodable;->toASN1Primitive()Lorg/spongycastle/asn1/ASN1Primitive;
move-result-object v0
.line 157
check-cast v0, Lorg/spongycastle/asn1/ASN1Sequence;
.line 160
const/4 v1, 0x0
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v1
check-cast v1, Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
.line 161
invoke-virtual {v1}, Lorg/spongycastle/asn1/ASN1ObjectIdentifier;->toString()Ljava/lang/String;
.line 164
const/4 v1, 0x1
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v1
check-cast v1, Lorg/spongycastle/asn1/ASN1Integer;
invoke-virtual {v1}, Lorg/spongycastle/asn1/ASN1Integer;->getValue()Ljava/math/BigInteger;
move-result-object v1
.line 165
invoke-virtual {v1}, Ljava/math/BigInteger;->intValue()I
move-result v2
.line 168
const/4 v1, 0x2
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v1
check-cast v1, Lorg/spongycastle/asn1/ASN1Integer;
invoke-virtual {v1}, Lorg/spongycastle/asn1/ASN1Integer;->getValue()Ljava/math/BigInteger;
move-result-object v1
.line 169
invoke-virtual {v1}, Ljava/math/BigInteger;->intValue()I
move-result v3
.line 173
const/4 v1, 0x3
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v1
check-cast v1, Lorg/spongycastle/asn1/ASN1OctetString;
.line 174
invoke-virtual {v1}, Lorg/spongycastle/asn1/ASN1OctetString;->getOctets()[B
move-result-object v4
.line 176
const/4 v1, 0x4
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v1
check-cast v1, Lorg/spongycastle/asn1/ASN1OctetString;
.line 177
invoke-virtual {v1}, Lorg/spongycastle/asn1/ASN1OctetString;->getOctets()[B
move-result-object v5
.line 179
const/4 v1, 0x5
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v1
check-cast v1, Lorg/spongycastle/asn1/ASN1OctetString;
invoke-virtual {v1}, Lorg/spongycastle/asn1/ASN1OctetString;->getOctets()[B
move-result-object v6
.line 181
const/4 v1, 0x6
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v1
check-cast v1, Lorg/spongycastle/asn1/ASN1OctetString;
invoke-virtual {v1}, Lorg/spongycastle/asn1/ASN1OctetString;->getOctets()[B
move-result-object v7
.line 183
const/4 v1, 0x7
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v0
check-cast v0, Lorg/spongycastle/asn1/ASN1Sequence;
.line 184
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v1
new-array v8, v1, [[B
.line 185
:goto_8a
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v1
if-ge v9, v1, :cond_b6
.line 187
invoke-virtual {v0, v9}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v1
check-cast v1, Lorg/spongycastle/asn1/ASN1OctetString;
invoke-virtual {v1}, Lorg/spongycastle/asn1/ASN1OctetString;->getOctets()[B
move-result-object v1
aput-object v1, v8, v9
:try_end_9c
.catch Ljava/io/IOException; {:try_start_1f .. :try_end_9c} :catch_c5
.line 185
add-int/lit8 v1, v9, 0x1
move v9, v1
goto :goto_8a
.line 146
:catch_a0
move-exception v0
.line 148
new-instance v1, Ljava/security/spec/InvalidKeySpecException;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Unable to decode PKCS8EncodedKeySpec: "
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/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/String;)V
throw v1
.line 190
:cond_b6
:try_start_b6
new-instance v9, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PrivateKey;
new-instance v0, Lorg/spongycastle/pqc/jcajce/spec/McElieceCCA2PrivateKeySpec;
const-string v1, "1.3.6.1.4.1.8301.3.1.3.4.2"
invoke-direct/range {v0 .. v8}, Lorg/spongycastle/pqc/jcajce/spec/McElieceCCA2PrivateKeySpec;-><init>(Ljava/lang/String;II[B[B[B[B[[B)V
invoke-direct {v9, v0}, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PrivateKey;-><init>(Lorg/spongycastle/pqc/jcajce/spec/McElieceCCA2PrivateKeySpec;)V
:try_end_c2
.catch Ljava/io/IOException; {:try_start_b6 .. :try_end_c2} :catch_c5
move-object v0, v9
goto/16 :goto_c
.line 197
:catch_c5
move-exception v0
new-instance v0, Ljava/security/spec/InvalidKeySpecException;
const-string v1, "Unable to decode PKCS8EncodedKeySpec."
invoke-direct {v0, v1}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/String;)V
throw v0
.line 202
:cond_ce
new-instance v0, Ljava/security/spec/InvalidKeySpecException;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Unsupported key specification: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 203
invoke-virtual {p1}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, "."
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public generatePrivate(Lorg/spongycastle/asn1/pkcs/PrivateKeyInfo;)Ljava/security/PrivateKey;
.registers 11
.prologue
.line 313
:try_start_0
invoke-virtual {p1}, Lorg/spongycastle/asn1/pkcs/PrivateKeyInfo;->parsePrivateKey()Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v0
invoke-interface {v0}, Lorg/spongycastle/asn1/ASN1Encodable;->toASN1Primitive()Lorg/spongycastle/asn1/ASN1Primitive;
move-result-object v0
.line 314
invoke-static {v0}, Lorg/spongycastle/pqc/asn1/McElieceCCA2PrivateKey;->getInstance(Ljava/lang/Object;)Lorg/spongycastle/pqc/asn1/McElieceCCA2PrivateKey;
move-result-object v8
.line 315
new-instance v0, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PrivateKey;
invoke-virtual {v8}, Lorg/spongycastle/pqc/asn1/McElieceCCA2PrivateKey;->getOID()Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
move-result-object v1
invoke-virtual {v1}, Lorg/spongycastle/asn1/ASN1ObjectIdentifier;->getId()Ljava/lang/String;
move-result-object v1
invoke-virtual {v8}, Lorg/spongycastle/pqc/asn1/McElieceCCA2PrivateKey;->getN()I
move-result v2
invoke-virtual {v8}, Lorg/spongycastle/pqc/asn1/McElieceCCA2PrivateKey;->getK()I
move-result v3
invoke-virtual {v8}, Lorg/spongycastle/pqc/asn1/McElieceCCA2PrivateKey;->getField()Lorg/spongycastle/pqc/math/linearalgebra/GF2mField;
move-result-object v4
invoke-virtual {v8}, Lorg/spongycastle/pqc/asn1/McElieceCCA2PrivateKey;->getGoppaPoly()Lorg/spongycastle/pqc/math/linearalgebra/PolynomialGF2mSmallM;
move-result-object v5
invoke-virtual {v8}, Lorg/spongycastle/pqc/asn1/McElieceCCA2PrivateKey;->getP()Lorg/spongycastle/pqc/math/linearalgebra/Permutation;
move-result-object v6
invoke-virtual {v8}, Lorg/spongycastle/pqc/asn1/McElieceCCA2PrivateKey;->getH()Lorg/spongycastle/pqc/math/linearalgebra/GF2Matrix;
move-result-object v7
invoke-virtual {v8}, Lorg/spongycastle/pqc/asn1/McElieceCCA2PrivateKey;->getQInv()[Lorg/spongycastle/pqc/math/linearalgebra/PolynomialGF2mSmallM;
move-result-object v8
invoke-direct/range {v0 .. v8}, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PrivateKey;-><init>(Ljava/lang/String;IILorg/spongycastle/pqc/math/linearalgebra/GF2mField;Lorg/spongycastle/pqc/math/linearalgebra/PolynomialGF2mSmallM;Lorg/spongycastle/pqc/math/linearalgebra/Permutation;Lorg/spongycastle/pqc/math/linearalgebra/GF2Matrix;[Lorg/spongycastle/pqc/math/linearalgebra/PolynomialGF2mSmallM;)V
:try_end_35
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_35} :catch_36
return-object v0
.line 319
:catch_36
move-exception v0
new-instance v0, Ljava/security/spec/InvalidKeySpecException;
const-string v1, "Unable to decode PKCS8EncodedKeySpec"
invoke-direct {v0, v1}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public generatePublic(Ljava/security/spec/KeySpec;)Ljava/security/PublicKey;
.registers 8
.prologue
.line 58
instance-of v0, p1, Lorg/spongycastle/pqc/jcajce/spec/McElieceCCA2PublicKeySpec;
if-eqz v0, :cond_c
.line 60
new-instance v0, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PublicKey;
check-cast p1, Lorg/spongycastle/pqc/jcajce/spec/McElieceCCA2PublicKeySpec;
invoke-direct {v0, p1}, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PublicKey;-><init>(Lorg/spongycastle/pqc/jcajce/spec/McElieceCCA2PublicKeySpec;)V
.line 101
:goto_b
return-object v0
.line 63
:cond_c
instance-of v0, p1, Ljava/security/spec/X509EncodedKeySpec;
if-eqz v0, :cond_89
.line 66
check-cast p1, Ljava/security/spec/X509EncodedKeySpec;
invoke-virtual {p1}, Ljava/security/spec/X509EncodedKeySpec;->getEncoded()[B
move-result-object v0
.line 72
:try_start_16
invoke-static {v0}, Lorg/spongycastle/asn1/ASN1Primitive;->fromByteArray([B)Lorg/spongycastle/asn1/ASN1Primitive;
move-result-object v0
invoke-static {v0}, Lorg/spongycastle/asn1/x509/SubjectPublicKeyInfo;->getInstance(Ljava/lang/Object;)Lorg/spongycastle/asn1/x509/SubjectPublicKeyInfo;
:try_end_1d
.catch Ljava/io/IOException; {:try_start_16 .. :try_end_1d} :catch_7e
move-result-object v0
.line 83
:try_start_1e
invoke-virtual {v0}, Lorg/spongycastle/asn1/x509/SubjectPublicKeyInfo;->parsePublicKey()Lorg/spongycastle/asn1/ASN1Primitive;
move-result-object v0
.line 84
check-cast v0, Lorg/spongycastle/asn1/ASN1Sequence;
.line 87
const/4 v1, 0x0
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v1
check-cast v1, Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
.line 88
invoke-virtual {v1}, Lorg/spongycastle/asn1/ASN1ObjectIdentifier;->toString()Ljava/lang/String;
.line 91
const/4 v1, 0x1
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v1
check-cast v1, Lorg/spongycastle/asn1/ASN1Integer;
invoke-virtual {v1}, Lorg/spongycastle/asn1/ASN1Integer;->getValue()Ljava/math/BigInteger;
move-result-object v1
.line 92
invoke-virtual {v1}, Ljava/math/BigInteger;->intValue()I
move-result v2
.line 95
const/4 v1, 0x2
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v1
check-cast v1, Lorg/spongycastle/asn1/ASN1Integer;
invoke-virtual {v1}, Lorg/spongycastle/asn1/ASN1Integer;->getValue()Ljava/math/BigInteger;
move-result-object v1
.line 96
invoke-virtual {v1}, Ljava/math/BigInteger;->intValue()I
move-result v1
.line 99
const/4 v3, 0x3
invoke-virtual {v0, v3}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v0
check-cast v0, Lorg/spongycastle/asn1/ASN1OctetString;
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1OctetString;->getOctets()[B
move-result-object v3
.line 101
new-instance v0, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PublicKey;
new-instance v4, Lorg/spongycastle/pqc/jcajce/spec/McElieceCCA2PublicKeySpec;
const-string v5, "1.3.6.1.4.1.8301.3.1.3.4.2"
invoke-direct {v4, v5, v2, v1, v3}, Lorg/spongycastle/pqc/jcajce/spec/McElieceCCA2PublicKeySpec;-><init>(Ljava/lang/String;II[B)V
invoke-direct {v0, v4}, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PublicKey;-><init>(Lorg/spongycastle/pqc/jcajce/spec/McElieceCCA2PublicKeySpec;)V
:try_end_63
.catch Ljava/io/IOException; {:try_start_1e .. :try_end_63} :catch_64
goto :goto_b
.line 104
:catch_64
move-exception v0
.line 106
new-instance v1, Ljava/security/spec/InvalidKeySpecException;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Unable to decode X509EncodedKeySpec: "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 108
invoke-virtual {v0}, Ljava/io/IOException;->getMessage()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/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/String;)V
throw v1
.line 74
:catch_7e
move-exception v0
.line 76
new-instance v1, Ljava/security/spec/InvalidKeySpecException;
invoke-virtual {v0}, Ljava/io/IOException;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v0}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/String;)V
throw v1
.line 112
:cond_89
new-instance v0, Ljava/security/spec/InvalidKeySpecException;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Unsupported key specification: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 113
invoke-virtual {p1}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, "."
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public generatePublic(Lorg/spongycastle/asn1/x509/SubjectPublicKeyInfo;)Ljava/security/PublicKey;
.registers 7
.prologue
.line 296
:try_start_0
invoke-virtual {p1}, Lorg/spongycastle/asn1/x509/SubjectPublicKeyInfo;->parsePublicKey()Lorg/spongycastle/asn1/ASN1Primitive;
move-result-object v0
.line 297
check-cast v0, Lorg/spongycastle/asn1/ASN1Sequence;
invoke-static {v0}, Lorg/spongycastle/pqc/asn1/McElieceCCA2PublicKey;->getInstance(Ljava/lang/Object;)Lorg/spongycastle/pqc/asn1/McElieceCCA2PublicKey;
move-result-object v0
.line 298
new-instance v1, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PublicKey;
invoke-virtual {v0}, Lorg/spongycastle/pqc/asn1/McElieceCCA2PublicKey;->getOID()Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
move-result-object v2
invoke-virtual {v2}, Lorg/spongycastle/asn1/ASN1ObjectIdentifier;->getId()Ljava/lang/String;
move-result-object v2
invoke-virtual {v0}, Lorg/spongycastle/pqc/asn1/McElieceCCA2PublicKey;->getN()I
move-result v3
invoke-virtual {v0}, Lorg/spongycastle/pqc/asn1/McElieceCCA2PublicKey;->getT()I
move-result v4
invoke-virtual {v0}, Lorg/spongycastle/pqc/asn1/McElieceCCA2PublicKey;->getG()Lorg/spongycastle/pqc/math/linearalgebra/GF2Matrix;
move-result-object v0
invoke-direct {v1, v2, v3, v4, v0}, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PublicKey;-><init>(Ljava/lang/String;IILorg/spongycastle/pqc/math/linearalgebra/GF2Matrix;)V
:try_end_23
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_23} :catch_24
return-object v1
.line 302
:catch_24
move-exception v0
new-instance v0, Ljava/security/spec/InvalidKeySpecException;
const-string v1, "Unable to decode X509EncodedKeySpec"
invoke-direct {v0, v1}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public getKeySpec(Ljava/security/Key;Ljava/lang/Class;)Ljava/security/spec/KeySpec;
.registers 12
.prologue
.line 229
instance-of v0, p1, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PrivateKey;
if-eqz v0, :cond_44
.line 231
const-class v0, Ljava/security/spec/PKCS8EncodedKeySpec;
invoke-virtual {v0, p2}, Ljava/lang/Class;->isAssignableFrom(Ljava/lang/Class;)Z
move-result v0
if-eqz v0, :cond_16
.line 233
new-instance v0, Ljava/security/spec/PKCS8EncodedKeySpec;
invoke-interface {p1}, Ljava/security/Key;->getEncoded()[B
move-result-object v1
invoke-direct {v0, v1}, Ljava/security/spec/PKCS8EncodedKeySpec;-><init>([B)V
.line 255
:goto_15
return-object v0
.line 235
:cond_16
const-class v0, Lorg/spongycastle/pqc/jcajce/spec/McElieceCCA2PrivateKeySpec;
.line 236
invoke-virtual {v0, p2}, Ljava/lang/Class;->isAssignableFrom(Ljava/lang/Class;)Z
move-result v0
if-eqz v0, :cond_97
.line 238
check-cast p1, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PrivateKey;
.line 239
new-instance v0, Lorg/spongycastle/pqc/jcajce/spec/McElieceCCA2PrivateKeySpec;
const-string v1, "1.3.6.1.4.1.8301.3.1.3.4.2"
invoke-virtual {p1}, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PrivateKey;->getN()I
move-result v2
.line 240
invoke-virtual {p1}, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PrivateKey;->getK()I
move-result v3
invoke-virtual {p1}, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PrivateKey;->getField()Lorg/spongycastle/pqc/math/linearalgebra/GF2mField;
move-result-object v4
invoke-virtual {p1}, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PrivateKey;->getGoppaPoly()Lorg/spongycastle/pqc/math/linearalgebra/PolynomialGF2mSmallM;
move-result-object v5
.line 241
invoke-virtual {p1}, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PrivateKey;->getP()Lorg/spongycastle/pqc/math/linearalgebra/Permutation;
move-result-object v6
invoke-virtual {p1}, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PrivateKey;->getH()Lorg/spongycastle/pqc/math/linearalgebra/GF2Matrix;
move-result-object v7
invoke-virtual {p1}, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PrivateKey;->getQInv()[Lorg/spongycastle/pqc/math/linearalgebra/PolynomialGF2mSmallM;
move-result-object v8
invoke-direct/range {v0 .. v8}, Lorg/spongycastle/pqc/jcajce/spec/McElieceCCA2PrivateKeySpec;-><init>(Ljava/lang/String;IILorg/spongycastle/pqc/math/linearalgebra/GF2mField;Lorg/spongycastle/pqc/math/linearalgebra/PolynomialGF2mSmallM;Lorg/spongycastle/pqc/math/linearalgebra/Permutation;Lorg/spongycastle/pqc/math/linearalgebra/GF2Matrix;[Lorg/spongycastle/pqc/math/linearalgebra/PolynomialGF2mSmallM;)V
goto :goto_15
.line 244
:cond_44
instance-of v0, p1, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PublicKey;
if-eqz v0, :cond_78
.line 246
const-class v0, Ljava/security/spec/X509EncodedKeySpec;
invoke-virtual {v0, p2}, Ljava/lang/Class;->isAssignableFrom(Ljava/lang/Class;)Z
move-result v0
if-eqz v0, :cond_5a
.line 248
new-instance v0, Ljava/security/spec/X509EncodedKeySpec;
invoke-interface {p1}, Ljava/security/Key;->getEncoded()[B
move-result-object v1
invoke-direct {v0, v1}, Ljava/security/spec/X509EncodedKeySpec;-><init>([B)V
goto :goto_15
.line 250
:cond_5a
const-class v0, Lorg/spongycastle/pqc/jcajce/spec/McElieceCCA2PublicKeySpec;
.line 251
invoke-virtual {v0, p2}, Ljava/lang/Class;->isAssignableFrom(Ljava/lang/Class;)Z
move-result v0
if-eqz v0, :cond_97
.line 253
check-cast p1, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PublicKey;
.line 254
new-instance v0, Lorg/spongycastle/pqc/jcajce/spec/McElieceCCA2PublicKeySpec;
const-string v1, "1.3.6.1.4.1.8301.3.1.3.4.2"
invoke-virtual {p1}, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PublicKey;->getN()I
move-result v2
.line 255
invoke-virtual {p1}, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PublicKey;->getT()I
move-result v3
invoke-virtual {p1}, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PublicKey;->getG()Lorg/spongycastle/pqc/math/linearalgebra/GF2Matrix;
move-result-object v4
invoke-direct {v0, v1, v2, v3, v4}, Lorg/spongycastle/pqc/jcajce/spec/McElieceCCA2PublicKeySpec;-><init>(Ljava/lang/String;IILorg/spongycastle/pqc/math/linearalgebra/GF2Matrix;)V
goto :goto_15
.line 260
:cond_78
new-instance v0, Ljava/security/spec/InvalidKeySpecException;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Unsupported key type: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 261
invoke-virtual {p1}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, "."
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/String;)V
throw v0
.line 264
:cond_97
new-instance v0, Ljava/security/spec/InvalidKeySpecException;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Unknown key specification: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, "."
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/security/spec/InvalidKeySpecException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public translateKey(Ljava/security/Key;)Ljava/security/Key;
.registers 4
.prologue
.line 280
instance-of v0, p1, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PrivateKey;
if-nez v0, :cond_8
instance-of v0, p1, Lorg/spongycastle/pqc/jcajce/provider/mceliece/BCMcElieceCCA2PublicKey;
if-eqz v0, :cond_9
.line 283
:cond_8
return-object p1
.line 285
:cond_9
new-instance v0, Ljava/security/InvalidKeyException;
const-string v1, "Unsupported key type."
invoke-direct {v0, v1}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw v0
.end method