ECIESPublicKeyParser.smali
.class public Lorg/spongycastle/crypto/parsers/ECIESPublicKeyParser;
.super Ljava/lang/Object;
.source "ECIESPublicKeyParser.java"
# interfaces
.implements Lorg/spongycastle/crypto/KeyParser;
# instance fields
.field private ecParams:Lorg/spongycastle/crypto/params/ECDomainParameters;
# direct methods
.method public constructor <init>(Lorg/spongycastle/crypto/params/ECDomainParameters;)V
.registers 2
.prologue
.line 18
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 19
iput-object p1, p0, Lorg/spongycastle/crypto/parsers/ECIESPublicKeyParser;->ecParams:Lorg/spongycastle/crypto/params/ECDomainParameters;
.line 20
return-void
.end method
# virtual methods
.method public readKey(Ljava/io/InputStream;)Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
.registers 6
.prologue
.line 26
invoke-virtual {p1}, Ljava/io/InputStream;->read()I
move-result v1
.line 29
packed-switch v1, :pswitch_data_6e
.line 46
:pswitch_7
new-instance v0, Ljava/io/IOException;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Sender\'s public key has invalid point encoding 0x"
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
const/16 v3, 0x10
invoke-static {v1, v3}, Ljava/lang/Integer;->toString(II)Ljava/lang/String;
move-result-object v1
invoke-virtual {v2, v1}, 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/io/IOException;-><init>(Ljava/lang/String;)V
throw v0
.line 32
:pswitch_22
new-instance v0, Ljava/io/IOException;
const-string v1, "Sender\'s public key invalid."
invoke-direct {v0, v1}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw v0
.line 36
:pswitch_2a
iget-object v0, p0, Lorg/spongycastle/crypto/parsers/ECIESPublicKeyParser;->ecParams:Lorg/spongycastle/crypto/params/ECDomainParameters;
invoke-virtual {v0}, Lorg/spongycastle/crypto/params/ECDomainParameters;->getCurve()Lorg/spongycastle/math/ec/ECCurve;
move-result-object v0
invoke-virtual {v0}, Lorg/spongycastle/math/ec/ECCurve;->getFieldSize()I
move-result v0
add-int/lit8 v0, v0, 0x7
div-int/lit8 v0, v0, 0x8
add-int/lit8 v0, v0, 0x1
new-array v0, v0, [B
.line 49
:goto_3c
const/4 v2, 0x0
int-to-byte v1, v1
aput-byte v1, v0, v2
.line 50
const/4 v1, 0x1
array-length v2, v0
add-int/lit8 v2, v2, -0x1
invoke-static {p1, v0, v1, v2}, Lorg/spongycastle/util/io/Streams;->readFully(Ljava/io/InputStream;[BII)I
.line 52
new-instance v1, Lorg/spongycastle/crypto/params/ECPublicKeyParameters;
iget-object v2, p0, Lorg/spongycastle/crypto/parsers/ECIESPublicKeyParser;->ecParams:Lorg/spongycastle/crypto/params/ECDomainParameters;
invoke-virtual {v2}, Lorg/spongycastle/crypto/params/ECDomainParameters;->getCurve()Lorg/spongycastle/math/ec/ECCurve;
move-result-object v2
invoke-virtual {v2, v0}, Lorg/spongycastle/math/ec/ECCurve;->decodePoint([B)Lorg/spongycastle/math/ec/ECPoint;
move-result-object v0
iget-object v2, p0, Lorg/spongycastle/crypto/parsers/ECIESPublicKeyParser;->ecParams:Lorg/spongycastle/crypto/params/ECDomainParameters;
invoke-direct {v1, v0, v2}, Lorg/spongycastle/crypto/params/ECPublicKeyParameters;-><init>(Lorg/spongycastle/math/ec/ECPoint;Lorg/spongycastle/crypto/params/ECDomainParameters;)V
return-object v1
.line 42
:pswitch_59
iget-object v0, p0, Lorg/spongycastle/crypto/parsers/ECIESPublicKeyParser;->ecParams:Lorg/spongycastle/crypto/params/ECDomainParameters;
invoke-virtual {v0}, Lorg/spongycastle/crypto/params/ECDomainParameters;->getCurve()Lorg/spongycastle/math/ec/ECCurve;
move-result-object v0
invoke-virtual {v0}, Lorg/spongycastle/math/ec/ECCurve;->getFieldSize()I
move-result v0
add-int/lit8 v0, v0, 0x7
div-int/lit8 v0, v0, 0x8
mul-int/lit8 v0, v0, 0x2
add-int/lit8 v0, v0, 0x1
new-array v0, v0, [B
goto :goto_3c
.line 29
:pswitch_data_6e
.packed-switch 0x0
:pswitch_22
:pswitch_7
:pswitch_2a
:pswitch_2a
:pswitch_59
:pswitch_7
:pswitch_59
:pswitch_59
.end packed-switch
.end method