RSAPublicKey.smali
.class public Lorg/spongycastle/asn1/eac/RSAPublicKey;
.super Lorg/spongycastle/asn1/eac/PublicKeyDataObject;
.source "RSAPublicKey.java"
# static fields
.field private static exponentValid:I
.field private static modulusValid:I
# instance fields
.field private exponent:Ljava/math/BigInteger;
.field private modulus:Ljava/math/BigInteger;
.field private usage:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
.field private valid:I
# direct methods
.method static constructor <clinit>()V
.registers 1
.prologue
.line 31
const/4 v0, 0x1
sput v0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->modulusValid:I
.line 32
const/4 v0, 0x2
sput v0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->exponentValid:I
return-void
.end method
.method public constructor <init>(Lorg/spongycastle/asn1/ASN1ObjectIdentifier;Ljava/math/BigInteger;Ljava/math/BigInteger;)V
.registers 5
.prologue
.line 63
invoke-direct {p0}, Lorg/spongycastle/asn1/eac/PublicKeyDataObject;-><init>()V
.line 30
const/4 v0, 0x0
iput v0, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->valid:I
.line 64
iput-object p1, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->usage:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
.line 65
iput-object p2, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->modulus:Ljava/math/BigInteger;
.line 66
iput-object p3, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->exponent:Ljava/math/BigInteger;
.line 67
return-void
.end method
.method constructor <init>(Lorg/spongycastle/asn1/ASN1Sequence;)V
.registers 6
.prologue
.line 35
invoke-direct {p0}, Lorg/spongycastle/asn1/eac/PublicKeyDataObject;-><init>()V
.line 30
const/4 v0, 0x0
iput v0, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->valid:I
.line 36
invoke-virtual {p1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjects()Ljava/util/Enumeration;
move-result-object v0
.line 38
invoke-interface {v0}, Ljava/util/Enumeration;->nextElement()Ljava/lang/Object;
move-result-object v1
invoke-static {v1}, Lorg/spongycastle/asn1/ASN1ObjectIdentifier;->getInstance(Ljava/lang/Object;)Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
move-result-object v1
iput-object v1, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->usage:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
.line 40
:goto_14
invoke-interface {v0}, Ljava/util/Enumeration;->hasMoreElements()Z
move-result v1
if-eqz v1, :cond_50
.line 42
invoke-interface {v0}, Ljava/util/Enumeration;->nextElement()Ljava/lang/Object;
move-result-object v1
invoke-static {v1}, Lorg/spongycastle/asn1/eac/UnsignedInteger;->getInstance(Ljava/lang/Object;)Lorg/spongycastle/asn1/eac/UnsignedInteger;
move-result-object v1
.line 44
invoke-virtual {v1}, Lorg/spongycastle/asn1/eac/UnsignedInteger;->getTagNo()I
move-result v2
packed-switch v2, :pswitch_data_5e
.line 53
new-instance v0, Ljava/lang/IllegalArgumentException;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Unknown DERTaggedObject :"
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1}, Lorg/spongycastle/asn1/eac/UnsignedInteger;->getTagNo()I
move-result v1
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, "-> not an Iso7816RSAPublicKeyStructure"
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/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 47
:pswitch_48
invoke-direct {p0, v1}, Lorg/spongycastle/asn1/eac/RSAPublicKey;->setModulus(Lorg/spongycastle/asn1/eac/UnsignedInteger;)V
goto :goto_14
.line 50
:pswitch_4c
invoke-direct {p0, v1}, Lorg/spongycastle/asn1/eac/RSAPublicKey;->setExponent(Lorg/spongycastle/asn1/eac/UnsignedInteger;)V
goto :goto_14
.line 56
:cond_50
iget v0, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->valid:I
const/4 v1, 0x3
if-eq v0, v1, :cond_5d
.line 58
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "missing argument -> not an Iso7816RSAPublicKeyStructure"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 60
:cond_5d
return-void
.line 44
:pswitch_data_5e
.packed-switch 0x1
:pswitch_48
:pswitch_4c
.end packed-switch
.end method
.method private setExponent(Lorg/spongycastle/asn1/eac/UnsignedInteger;)V
.registers 4
.prologue
.line 99
iget v0, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->valid:I
sget v1, Lorg/spongycastle/asn1/eac/RSAPublicKey;->exponentValid:I
and-int/2addr v0, v1
if-nez v0, :cond_15
.line 101
iget v0, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->valid:I
sget v1, Lorg/spongycastle/asn1/eac/RSAPublicKey;->exponentValid:I
or-int/2addr v0, v1
iput v0, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->valid:I
.line 102
invoke-virtual {p1}, Lorg/spongycastle/asn1/eac/UnsignedInteger;->getValue()Ljava/math/BigInteger;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->exponent:Ljava/math/BigInteger;
return-void
.line 106
:cond_15
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "Exponent already set"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method private setModulus(Lorg/spongycastle/asn1/eac/UnsignedInteger;)V
.registers 4
.prologue
.line 86
iget v0, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->valid:I
sget v1, Lorg/spongycastle/asn1/eac/RSAPublicKey;->modulusValid:I
and-int/2addr v0, v1
if-nez v0, :cond_15
.line 88
iget v0, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->valid:I
sget v1, Lorg/spongycastle/asn1/eac/RSAPublicKey;->modulusValid:I
or-int/2addr v0, v1
iput v0, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->valid:I
.line 89
invoke-virtual {p1}, Lorg/spongycastle/asn1/eac/UnsignedInteger;->getValue()Ljava/math/BigInteger;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->modulus:Ljava/math/BigInteger;
return-void
.line 93
:cond_15
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "Modulus already set"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.end method
# virtual methods
.method public getModulus()Ljava/math/BigInteger;
.registers 2
.prologue
.line 76
iget-object v0, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->modulus:Ljava/math/BigInteger;
return-object v0
.end method
.method public getPublicExponent()Ljava/math/BigInteger;
.registers 2
.prologue
.line 81
iget-object v0, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->exponent:Ljava/math/BigInteger;
return-object v0
.end method
.method public getUsage()Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
.registers 2
.prologue
.line 71
iget-object v0, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->usage:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
return-object v0
.end method
.method public toASN1Primitive()Lorg/spongycastle/asn1/ASN1Primitive;
.registers 5
.prologue
.line 112
new-instance v0, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v0}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
.line 114
iget-object v1, p0, Lorg/spongycastle/asn1/eac/RSAPublicKey;->usage:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 115
new-instance v1, Lorg/spongycastle/asn1/eac/UnsignedInteger;
const/4 v2, 0x1
invoke-virtual {p0}, Lorg/spongycastle/asn1/eac/RSAPublicKey;->getModulus()Ljava/math/BigInteger;
move-result-object v3
invoke-direct {v1, v2, v3}, Lorg/spongycastle/asn1/eac/UnsignedInteger;-><init>(ILjava/math/BigInteger;)V
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 116
new-instance v1, Lorg/spongycastle/asn1/eac/UnsignedInteger;
const/4 v2, 0x2
invoke-virtual {p0}, Lorg/spongycastle/asn1/eac/RSAPublicKey;->getPublicExponent()Ljava/math/BigInteger;
move-result-object v3
invoke-direct {v1, v2, v3}, Lorg/spongycastle/asn1/eac/UnsignedInteger;-><init>(ILjava/math/BigInteger;)V
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 118
new-instance v1, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v1, v0}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
return-object v1
.end method