DHIESPublicKeyParser.smali
.class public Lorg/spongycastle/crypto/parsers/DHIESPublicKeyParser;
.super Ljava/lang/Object;
.source "DHIESPublicKeyParser.java"
# interfaces
.implements Lorg/spongycastle/crypto/KeyParser;
# instance fields
.field private dhParams:Lorg/spongycastle/crypto/params/DHParameters;
# direct methods
.method public constructor <init>(Lorg/spongycastle/crypto/params/DHParameters;)V
.registers 2
.prologue
.line 19
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 20
iput-object p1, p0, Lorg/spongycastle/crypto/parsers/DHIESPublicKeyParser;->dhParams:Lorg/spongycastle/crypto/params/DHParameters;
.line 21
return-void
.end method
# virtual methods
.method public readKey(Ljava/io/InputStream;)Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
.registers 6
.prologue
.line 26
iget-object v0, p0, Lorg/spongycastle/crypto/parsers/DHIESPublicKeyParser;->dhParams:Lorg/spongycastle/crypto/params/DHParameters;
invoke-virtual {v0}, Lorg/spongycastle/crypto/params/DHParameters;->getP()Ljava/math/BigInteger;
move-result-object v0
invoke-virtual {v0}, Ljava/math/BigInteger;->bitLength()I
move-result v0
add-int/lit8 v0, v0, 0x7
div-int/lit8 v0, v0, 0x8
new-array v0, v0, [B
.line 28
const/4 v1, 0x0
array-length v2, v0
invoke-static {p1, v0, v1, v2}, Lorg/spongycastle/util/io/Streams;->readFully(Ljava/io/InputStream;[BII)I
.line 30
new-instance v1, Lorg/spongycastle/crypto/params/DHPublicKeyParameters;
new-instance v2, Ljava/math/BigInteger;
const/4 v3, 0x1
invoke-direct {v2, v3, v0}, Ljava/math/BigInteger;-><init>(I[B)V
iget-object v0, p0, Lorg/spongycastle/crypto/parsers/DHIESPublicKeyParser;->dhParams:Lorg/spongycastle/crypto/params/DHParameters;
invoke-direct {v1, v2, v0}, Lorg/spongycastle/crypto/params/DHPublicKeyParameters;-><init>(Ljava/math/BigInteger;Lorg/spongycastle/crypto/params/DHParameters;)V
return-object v1
.end method