IESCipher.smali
.class public Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;
.super Ljavax/crypto/CipherSpi;
.source "IESCipher.java"
# instance fields
.field private buffer:Ljava/io/ByteArrayOutputStream;
.field private dhaesMode:Z
.field private engine:Lorg/spongycastle/crypto/engines/IESEngine;
.field private engineParam:Ljava/security/AlgorithmParameters;
.field private engineSpec:Lorg/spongycastle/jce/spec/IESParameterSpec;
.field private final helper:Lorg/spongycastle/jcajce/util/JcaJceHelper;
.field private key:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
.field private otherKeyParameter:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
.field private random:Ljava/security/SecureRandom;
.field private state:I
# direct methods
.method public constructor <init>(Lorg/spongycastle/crypto/engines/IESEngine;)V
.registers 4
.prologue
const/4 v1, 0x0
.line 72
invoke-direct {p0}, Ljavax/crypto/CipherSpi;-><init>()V
.line 59
new-instance v0, Lorg/spongycastle/jcajce/util/BCJcaJceHelper;
invoke-direct {v0}, Lorg/spongycastle/jcajce/util/BCJcaJceHelper;-><init>()V
iput-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->helper:Lorg/spongycastle/jcajce/util/JcaJceHelper;
.line 62
const/4 v0, -0x1
iput v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->state:I
.line 63
new-instance v0, Ljava/io/ByteArrayOutputStream;
invoke-direct {v0}, Ljava/io/ByteArrayOutputStream;-><init>()V
iput-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->buffer:Ljava/io/ByteArrayOutputStream;
.line 64
iput-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineParam:Ljava/security/AlgorithmParameters;
.line 65
iput-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineSpec:Lorg/spongycastle/jce/spec/IESParameterSpec;
.line 68
const/4 v0, 0x0
iput-boolean v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->dhaesMode:Z
.line 69
iput-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->otherKeyParameter:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
.line 73
iput-object p1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engine:Lorg/spongycastle/crypto/engines/IESEngine;
.line 74
return-void
.end method
.method public constructor <init>(Lorg/spongycastle/crypto/engines/OldIESEngine;)V
.registers 4
.prologue
const/4 v1, 0x0
.line 77
invoke-direct {p0}, Ljavax/crypto/CipherSpi;-><init>()V
.line 59
new-instance v0, Lorg/spongycastle/jcajce/util/BCJcaJceHelper;
invoke-direct {v0}, Lorg/spongycastle/jcajce/util/BCJcaJceHelper;-><init>()V
iput-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->helper:Lorg/spongycastle/jcajce/util/JcaJceHelper;
.line 62
const/4 v0, -0x1
iput v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->state:I
.line 63
new-instance v0, Ljava/io/ByteArrayOutputStream;
invoke-direct {v0}, Ljava/io/ByteArrayOutputStream;-><init>()V
iput-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->buffer:Ljava/io/ByteArrayOutputStream;
.line 64
iput-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineParam:Ljava/security/AlgorithmParameters;
.line 65
iput-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineSpec:Lorg/spongycastle/jce/spec/IESParameterSpec;
.line 68
const/4 v0, 0x0
iput-boolean v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->dhaesMode:Z
.line 69
iput-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->otherKeyParameter:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
.line 78
iput-object p1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engine:Lorg/spongycastle/crypto/engines/IESEngine;
.line 79
return-void
.end method
# virtual methods
.method public engineDoFinal([BII[BI)I
.registers 9
.prologue
.line 476
invoke-virtual {p0, p1, p2, p3}, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineDoFinal([BII)[B
move-result-object v0
.line 477
const/4 v1, 0x0
array-length v2, v0
invoke-static {v0, v1, p4, p5, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 478
array-length v0, v0
return v0
.end method
.method public engineDoFinal([BII)[B
.registers 12
.prologue
const/4 v7, 0x3
const/4 v6, 0x1
.line 370
if-eqz p3, :cond_9
.line 372
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v0, p1, p2, p3}, Ljava/io/ByteArrayOutputStream;->write([BII)V
.line 375
:cond_9
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v0}, Ljava/io/ByteArrayOutputStream;->toByteArray()[B
move-result-object v1
.line 376
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v0}, Ljava/io/ByteArrayOutputStream;->reset()V
.line 379
new-instance v2, Lorg/spongycastle/crypto/params/IESWithCipherParameters;
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineSpec:Lorg/spongycastle/jce/spec/IESParameterSpec;
invoke-virtual {v0}, Lorg/spongycastle/jce/spec/IESParameterSpec;->getDerivationV()[B
move-result-object v0
iget-object v3, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineSpec:Lorg/spongycastle/jce/spec/IESParameterSpec;
.line 380
invoke-virtual {v3}, Lorg/spongycastle/jce/spec/IESParameterSpec;->getEncodingV()[B
move-result-object v3
iget-object v4, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineSpec:Lorg/spongycastle/jce/spec/IESParameterSpec;
.line 381
invoke-virtual {v4}, Lorg/spongycastle/jce/spec/IESParameterSpec;->getMacKeySize()I
move-result v4
iget-object v5, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineSpec:Lorg/spongycastle/jce/spec/IESParameterSpec;
.line 382
invoke-virtual {v5}, Lorg/spongycastle/jce/spec/IESParameterSpec;->getCipherKeySize()I
move-result v5
invoke-direct {v2, v0, v3, v4, v5}, Lorg/spongycastle/crypto/params/IESWithCipherParameters;-><init>([B[BII)V
.line 384
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->key:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
check-cast v0, Lorg/spongycastle/crypto/params/DHKeyParameters;
invoke-virtual {v0}, Lorg/spongycastle/crypto/params/DHKeyParameters;->getParameters()Lorg/spongycastle/crypto/params/DHParameters;
move-result-object v0
.line 387
iget-object v3, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->otherKeyParameter:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
if-eqz v3, :cond_6e
.line 391
:try_start_3d
iget v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->state:I
if-eq v0, v6, :cond_45
iget v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->state:I
if-ne v0, v7, :cond_58
.line 393
:cond_45
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engine:Lorg/spongycastle/crypto/engines/IESEngine;
const/4 v3, 0x1
iget-object v4, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->otherKeyParameter:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
iget-object v5, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->key:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
invoke-virtual {v0, v3, v4, v5, v2}, Lorg/spongycastle/crypto/engines/IESEngine;->init(ZLorg/spongycastle/crypto/CipherParameters;Lorg/spongycastle/crypto/CipherParameters;Lorg/spongycastle/crypto/CipherParameters;)V
.line 399
:goto_4f
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engine:Lorg/spongycastle/crypto/engines/IESEngine;
const/4 v2, 0x0
array-length v3, v1
invoke-virtual {v0, v1, v2, v3}, Lorg/spongycastle/crypto/engines/IESEngine;->processBlock([BII)[B
move-result-object v0
.line 452
:goto_57
return-object v0
.line 397
:cond_58
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engine:Lorg/spongycastle/crypto/engines/IESEngine;
const/4 v3, 0x0
iget-object v4, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->key:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
iget-object v5, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->otherKeyParameter:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
invoke-virtual {v0, v3, v4, v5, v2}, Lorg/spongycastle/crypto/engines/IESEngine;->init(ZLorg/spongycastle/crypto/CipherParameters;Lorg/spongycastle/crypto/CipherParameters;Lorg/spongycastle/crypto/CipherParameters;)V
:try_end_62
.catch Ljava/lang/Exception; {:try_start_3d .. :try_end_62} :catch_63
goto :goto_4f
.line 401
:catch_63
move-exception v0
.line 403
new-instance v1, Ljavax/crypto/BadPaddingException;
invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v0}, Ljavax/crypto/BadPaddingException;-><init>(Ljava/lang/String;)V
throw v1
.line 407
:cond_6e
iget v3, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->state:I
if-eq v3, v6, :cond_76
iget v3, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->state:I
if-ne v3, v7, :cond_aa
.line 410
:cond_76
new-instance v3, Lorg/spongycastle/crypto/generators/DHKeyPairGenerator;
invoke-direct {v3}, Lorg/spongycastle/crypto/generators/DHKeyPairGenerator;-><init>()V
.line 411
new-instance v4, Lorg/spongycastle/crypto/params/DHKeyGenerationParameters;
iget-object v5, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->random:Ljava/security/SecureRandom;
invoke-direct {v4, v5, v0}, Lorg/spongycastle/crypto/params/DHKeyGenerationParameters;-><init>(Ljava/security/SecureRandom;Lorg/spongycastle/crypto/params/DHParameters;)V
invoke-virtual {v3, v4}, Lorg/spongycastle/crypto/generators/DHKeyPairGenerator;->init(Lorg/spongycastle/crypto/KeyGenerationParameters;)V
.line 413
new-instance v0, Lorg/spongycastle/crypto/generators/EphemeralKeyPairGenerator;
new-instance v4, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher$1;
invoke-direct {v4, p0}, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher$1;-><init>(Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;)V
invoke-direct {v0, v3, v4}, Lorg/spongycastle/crypto/generators/EphemeralKeyPairGenerator;-><init>(Lorg/spongycastle/crypto/AsymmetricCipherKeyPairGenerator;Lorg/spongycastle/crypto/KeyEncoder;)V
.line 436
:try_start_8f
iget-object v3, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engine:Lorg/spongycastle/crypto/engines/IESEngine;
iget-object v4, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->key:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
invoke-virtual {v3, v4, v2, v0}, Lorg/spongycastle/crypto/engines/IESEngine;->init(Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;Lorg/spongycastle/crypto/CipherParameters;Lorg/spongycastle/crypto/generators/EphemeralKeyPairGenerator;)V
.line 438
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engine:Lorg/spongycastle/crypto/engines/IESEngine;
const/4 v2, 0x0
array-length v3, v1
invoke-virtual {v0, v1, v2, v3}, Lorg/spongycastle/crypto/engines/IESEngine;->processBlock([BII)[B
:try_end_9d
.catch Ljava/lang/Exception; {:try_start_8f .. :try_end_9d} :catch_9f
move-result-object v0
goto :goto_57
.line 440
:catch_9f
move-exception v0
.line 442
new-instance v1, Ljavax/crypto/BadPaddingException;
invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v0}, Ljavax/crypto/BadPaddingException;-><init>(Ljava/lang/String;)V
throw v1
.line 445
:cond_aa
iget v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->state:I
const/4 v3, 0x2
if-eq v0, v3, :cond_b4
iget v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->state:I
const/4 v3, 0x4
if-ne v0, v3, :cond_dc
.line 450
:cond_b4
:try_start_b4
iget-object v3, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engine:Lorg/spongycastle/crypto/engines/IESEngine;
iget-object v4, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->key:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
new-instance v5, Lorg/spongycastle/crypto/parsers/DHIESPublicKeyParser;
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->key:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
check-cast v0, Lorg/spongycastle/crypto/params/DHKeyParameters;
invoke-virtual {v0}, Lorg/spongycastle/crypto/params/DHKeyParameters;->getParameters()Lorg/spongycastle/crypto/params/DHParameters;
move-result-object v0
invoke-direct {v5, v0}, Lorg/spongycastle/crypto/parsers/DHIESPublicKeyParser;-><init>(Lorg/spongycastle/crypto/params/DHParameters;)V
invoke-virtual {v3, v4, v2, v5}, Lorg/spongycastle/crypto/engines/IESEngine;->init(Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;Lorg/spongycastle/crypto/CipherParameters;Lorg/spongycastle/crypto/KeyParser;)V
.line 452
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engine:Lorg/spongycastle/crypto/engines/IESEngine;
const/4 v2, 0x0
array-length v3, v1
invoke-virtual {v0, v1, v2, v3}, Lorg/spongycastle/crypto/engines/IESEngine;->processBlock([BII)[B
:try_end_cf
.catch Lorg/spongycastle/crypto/InvalidCipherTextException; {:try_start_b4 .. :try_end_cf} :catch_d1
move-result-object v0
goto :goto_57
.line 454
:catch_d1
move-exception v0
.line 456
new-instance v1, Ljavax/crypto/BadPaddingException;
invoke-virtual {v0}, Lorg/spongycastle/crypto/InvalidCipherTextException;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v0}, Ljavax/crypto/BadPaddingException;-><init>(Ljava/lang/String;)V
throw v1
.line 461
:cond_dc
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "IESCipher not initialised"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public engineGetBlockSize()I
.registers 2
.prologue
.line 83
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engine:Lorg/spongycastle/crypto/engines/IESEngine;
invoke-virtual {v0}, Lorg/spongycastle/crypto/engines/IESEngine;->getCipher()Lorg/spongycastle/crypto/BufferedBlockCipher;
move-result-object v0
if-eqz v0, :cond_13
.line 85
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engine:Lorg/spongycastle/crypto/engines/IESEngine;
invoke-virtual {v0}, Lorg/spongycastle/crypto/engines/IESEngine;->getCipher()Lorg/spongycastle/crypto/BufferedBlockCipher;
move-result-object v0
invoke-virtual {v0}, Lorg/spongycastle/crypto/BufferedBlockCipher;->getBlockSize()I
move-result v0
.line 89
:goto_12
return v0
:cond_13
const/4 v0, 0x0
goto :goto_12
.end method
.method public engineGetIV()[B
.registers 2
.prologue
.line 109
const/4 v0, 0x0
return-object v0
.end method
.method public engineGetKeySize(Ljava/security/Key;)I
.registers 4
.prologue
.line 96
instance-of v0, p1, Ljavax/crypto/interfaces/DHKey;
if-eqz v0, :cond_13
.line 98
check-cast p1, Ljavax/crypto/interfaces/DHKey;
invoke-interface {p1}, Ljavax/crypto/interfaces/DHKey;->getParams()Ljavax/crypto/spec/DHParameterSpec;
move-result-object v0
invoke-virtual {v0}, Ljavax/crypto/spec/DHParameterSpec;->getP()Ljava/math/BigInteger;
move-result-object v0
invoke-virtual {v0}, Ljava/math/BigInteger;->bitLength()I
move-result v0
return v0
.line 102
:cond_13
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "not a DH key"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public engineGetOutputSize(I)I
.registers 10
.prologue
const/4 v7, 0x4
const/4 v6, 0x3
const/4 v5, 0x2
const/4 v4, 0x1
.line 154
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->key:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
if-nez v0, :cond_10
.line 156
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "cipher not initialised"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 159
:cond_10
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engine:Lorg/spongycastle/crypto/engines/IESEngine;
invoke-virtual {v0}, Lorg/spongycastle/crypto/engines/IESEngine;->getMac()Lorg/spongycastle/crypto/Mac;
move-result-object v0
invoke-interface {v0}, Lorg/spongycastle/crypto/Mac;->getMacSize()I
move-result v1
.line 161
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->otherKeyParameter:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
if-nez v0, :cond_62
.line 163
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->key:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
check-cast v0, Lorg/spongycastle/crypto/params/DHKeyParameters;
invoke-virtual {v0}, Lorg/spongycastle/crypto/params/DHKeyParameters;->getParameters()Lorg/spongycastle/crypto/params/DHParameters;
move-result-object v0
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
mul-int/lit8 v0, v0, 0x2
div-int/lit8 v0, v0, 0x8
add-int/lit8 v0, v0, 0x1
.line 170
:goto_36
iget-object v2, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engine:Lorg/spongycastle/crypto/engines/IESEngine;
invoke-virtual {v2}, Lorg/spongycastle/crypto/engines/IESEngine;->getCipher()Lorg/spongycastle/crypto/BufferedBlockCipher;
move-result-object v2
if-eqz v2, :cond_50
.line 174
iget v2, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->state:I
if-eq v2, v4, :cond_46
iget v2, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->state:I
if-ne v2, v6, :cond_64
.line 176
:cond_46
iget-object v2, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engine:Lorg/spongycastle/crypto/engines/IESEngine;
invoke-virtual {v2}, Lorg/spongycastle/crypto/engines/IESEngine;->getCipher()Lorg/spongycastle/crypto/BufferedBlockCipher;
move-result-object v2
invoke-virtual {v2, p1}, Lorg/spongycastle/crypto/BufferedBlockCipher;->getOutputSize(I)I
move-result p1
.line 187
:cond_50
:goto_50
iget v2, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->state:I
if-eq v2, v4, :cond_58
iget v2, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->state:I
if-ne v2, v6, :cond_82
.line 189
:cond_58
iget-object v2, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v2}, Ljava/io/ByteArrayOutputStream;->size()I
move-result v2
add-int/2addr v1, v2
add-int/2addr v0, v1
add-int/2addr v0, p1
.line 193
:goto_61
return v0
.line 167
:cond_62
const/4 v0, 0x0
goto :goto_36
.line 178
:cond_64
iget v2, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->state:I
if-eq v2, v5, :cond_6c
iget v2, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->state:I
if-ne v2, v7, :cond_7a
.line 180
:cond_6c
iget-object v2, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engine:Lorg/spongycastle/crypto/engines/IESEngine;
invoke-virtual {v2}, Lorg/spongycastle/crypto/engines/IESEngine;->getCipher()Lorg/spongycastle/crypto/BufferedBlockCipher;
move-result-object v2
sub-int v3, p1, v1
sub-int/2addr v3, v0
invoke-virtual {v2, v3}, Lorg/spongycastle/crypto/BufferedBlockCipher;->getOutputSize(I)I
move-result p1
goto :goto_50
.line 184
:cond_7a
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "cipher not initialised"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 191
:cond_82
iget v2, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->state:I
if-eq v2, v5, :cond_8a
iget v2, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->state:I
if-ne v2, v7, :cond_96
.line 193
:cond_8a
iget-object v2, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v2}, Ljava/io/ByteArrayOutputStream;->size()I
move-result v2
sub-int v1, v2, v1
sub-int v0, v1, v0
add-int/2addr v0, p1
goto :goto_61
.line 197
:cond_96
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "IESCipher not initialised"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public engineGetParameters()Ljava/security/AlgorithmParameters;
.registers 3
.prologue
.line 114
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineParam:Ljava/security/AlgorithmParameters;
if-nez v0, :cond_19
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineSpec:Lorg/spongycastle/jce/spec/IESParameterSpec;
if-eqz v0, :cond_19
.line 118
:try_start_8
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->helper:Lorg/spongycastle/jcajce/util/JcaJceHelper;
const-string v1, "IES"
invoke-interface {v0, v1}, Lorg/spongycastle/jcajce/util/JcaJceHelper;->createAlgorithmParameters(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineParam:Ljava/security/AlgorithmParameters;
.line 119
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineParam:Ljava/security/AlgorithmParameters;
iget-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineSpec:Lorg/spongycastle/jce/spec/IESParameterSpec;
invoke-virtual {v0, v1}, Ljava/security/AlgorithmParameters;->init(Ljava/security/spec/AlgorithmParameterSpec;)V
:try_end_19
.catch Ljava/lang/Exception; {:try_start_8 .. :try_end_19} :catch_1c
.line 127
:cond_19
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineParam:Ljava/security/AlgorithmParameters;
return-object v0
.line 121
:catch_1c
move-exception v0
.line 123
new-instance v1, Ljava/lang/RuntimeException;
invoke-virtual {v0}, Ljava/lang/Exception;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw v1
.end method
.method public engineInit(ILjava/security/Key;Ljava/security/AlgorithmParameters;Ljava/security/SecureRandom;)V
.registers 9
.prologue
.line 231
const/4 v0, 0x0
.line 233
if-eqz p3, :cond_9
.line 237
:try_start_3
const-class v0, Lorg/spongycastle/jce/spec/IESParameterSpec;
invoke-virtual {p3, v0}, Ljava/security/AlgorithmParameters;->getParameterSpec(Ljava/lang/Class;)Ljava/security/spec/AlgorithmParameterSpec;
:try_end_8
.catch Ljava/lang/Exception; {:try_start_3 .. :try_end_8} :catch_f
move-result-object v0
.line 245
:cond_9
iput-object p3, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineParam:Ljava/security/AlgorithmParameters;
.line 246
invoke-virtual {p0, p1, p2, v0, p4}, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineInit(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
.line 247
return-void
.line 239
:catch_f
move-exception v0
.line 241
new-instance v1, Ljava/security/InvalidAlgorithmParameterException;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "cannot recognise parameters: "
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/security/InvalidAlgorithmParameterException;-><init>(Ljava/lang/String;)V
throw v1
.end method
.method public engineInit(ILjava/security/Key;Ljava/security/SecureRandom;)V
.registers 6
.prologue
.line 328
const/4 v0, 0x0
:try_start_1
invoke-virtual {p0, p1, p2, v0, p3}, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineInit(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
:try_end_4
.catch Ljava/security/InvalidAlgorithmParameterException; {:try_start_1 .. :try_end_4} :catch_5
.line 333
return-void
.line 332
:catch_5
move-exception v0
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "can\'t handle supplied parameter spec"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public engineInit(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
.registers 7
.prologue
.line 258
if-nez p3, :cond_2a
.line 260
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engine:Lorg/spongycastle/crypto/engines/IESEngine;
invoke-virtual {v0}, Lorg/spongycastle/crypto/engines/IESEngine;->getCipher()Lorg/spongycastle/crypto/BufferedBlockCipher;
move-result-object v0
invoke-static {v0}, Lorg/spongycastle/jcajce/provider/asymmetric/util/IESUtil;->guessParameterSpec(Lorg/spongycastle/crypto/BufferedBlockCipher;)Lorg/spongycastle/jce/spec/IESParameterSpec;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineSpec:Lorg/spongycastle/jce/spec/IESParameterSpec;
.line 272
:goto_e
const/4 v0, 0x1
if-eq p1, v0, :cond_14
const/4 v0, 0x3
if-ne p1, v0, :cond_5e
.line 274
:cond_14
instance-of v0, p2, Ljavax/crypto/interfaces/DHPublicKey;
if-eqz v0, :cond_3b
.line 276
check-cast p2, Ljava/security/PublicKey;
invoke-static {p2}, Lorg/spongycastle/jcajce/provider/asymmetric/util/DHUtil;->generatePublicKeyParameter(Ljava/security/PublicKey;)Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->key:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
.line 313
:goto_20
iput-object p4, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->random:Ljava/security/SecureRandom;
.line 314
iput p1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->state:I
.line 315
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v0}, Ljava/io/ByteArrayOutputStream;->reset()V
.line 317
return-void
.line 262
:cond_2a
instance-of v0, p3, Lorg/spongycastle/jce/spec/IESParameterSpec;
if-eqz v0, :cond_33
.line 264
check-cast p3, Lorg/spongycastle/jce/spec/IESParameterSpec;
iput-object p3, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->engineSpec:Lorg/spongycastle/jce/spec/IESParameterSpec;
goto :goto_e
.line 268
:cond_33
new-instance v0, Ljava/security/InvalidAlgorithmParameterException;
const-string v1, "must be passed IES parameters"
invoke-direct {v0, v1}, Ljava/security/InvalidAlgorithmParameterException;-><init>(Ljava/lang/String;)V
throw v0
.line 278
:cond_3b
instance-of v0, p2, Lorg/spongycastle/jce/interfaces/IESKey;
if-eqz v0, :cond_56
.line 280
check-cast p2, Lorg/spongycastle/jce/interfaces/IESKey;
.line 282
invoke-interface {p2}, Lorg/spongycastle/jce/interfaces/IESKey;->getPublic()Ljava/security/PublicKey;
move-result-object v0
invoke-static {v0}, Lorg/spongycastle/jcajce/provider/asymmetric/util/DHUtil;->generatePublicKeyParameter(Ljava/security/PublicKey;)Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->key:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
.line 283
invoke-interface {p2}, Lorg/spongycastle/jce/interfaces/IESKey;->getPrivate()Ljava/security/PrivateKey;
move-result-object v0
invoke-static {v0}, Lorg/spongycastle/jcajce/provider/asymmetric/util/DHUtil;->generatePrivateKeyParameter(Ljava/security/PrivateKey;)Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->otherKeyParameter:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
goto :goto_20
.line 287
:cond_56
new-instance v0, Ljava/security/InvalidKeyException;
const-string v1, "must be passed recipient\'s public DH key for encryption"
invoke-direct {v0, v1}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw v0
.line 290
:cond_5e
const/4 v0, 0x2
if-eq p1, v0, :cond_64
const/4 v0, 0x4
if-ne p1, v0, :cond_94
.line 292
:cond_64
instance-of v0, p2, Ljavax/crypto/interfaces/DHPrivateKey;
if-eqz v0, :cond_71
.line 294
check-cast p2, Ljava/security/PrivateKey;
invoke-static {p2}, Lorg/spongycastle/jcajce/provider/asymmetric/util/DHUtil;->generatePrivateKeyParameter(Ljava/security/PrivateKey;)Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->key:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
goto :goto_20
.line 296
:cond_71
instance-of v0, p2, Lorg/spongycastle/jce/interfaces/IESKey;
if-eqz v0, :cond_8c
.line 298
check-cast p2, Lorg/spongycastle/jce/interfaces/IESKey;
.line 300
invoke-interface {p2}, Lorg/spongycastle/jce/interfaces/IESKey;->getPublic()Ljava/security/PublicKey;
move-result-object v0
invoke-static {v0}, Lorg/spongycastle/jcajce/provider/asymmetric/util/DHUtil;->generatePublicKeyParameter(Ljava/security/PublicKey;)Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->otherKeyParameter:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
.line 301
invoke-interface {p2}, Lorg/spongycastle/jce/interfaces/IESKey;->getPrivate()Ljava/security/PrivateKey;
move-result-object v0
invoke-static {v0}, Lorg/spongycastle/jcajce/provider/asymmetric/util/DHUtil;->generatePrivateKeyParameter(Ljava/security/PrivateKey;)Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->key:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
goto :goto_20
.line 305
:cond_8c
new-instance v0, Ljava/security/InvalidKeyException;
const-string v1, "must be passed recipient\'s private DH key for decryption"
invoke-direct {v0, v1}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw v0
.line 310
:cond_94
new-instance v0, Ljava/security/InvalidKeyException;
const-string v1, "must be passed EC key"
invoke-direct {v0, v1}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public engineSetMode(Ljava/lang/String;)V
.registers 5
.prologue
.line 134
invoke-static {p1}, Lorg/spongycastle/util/Strings;->toUpperCase(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 136
const-string v1, "NONE"
invoke-virtual {v0, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v1
if-eqz v1, :cond_10
.line 138
const/4 v0, 0x0
iput-boolean v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->dhaesMode:Z
.line 142
:goto_f
return-void
.line 140
:cond_10
const-string v1, "DHAES"
invoke-virtual {v0, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_1c
.line 142
const/4 v0, 0x1
iput-boolean v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->dhaesMode:Z
goto :goto_f
.line 146
:cond_1c
new-instance v0, Ljava/lang/IllegalArgumentException;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "can\'t support mode "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1, p1}, 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
.end method
.method public engineSetPadding(Ljava/lang/String;)V
.registers 4
.prologue
.line 205
invoke-static {p1}, Lorg/spongycastle/util/Strings;->toUpperCase(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 208
const-string v1, "NOPADDING"
invoke-virtual {v0, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_24
.line 212
const-string v1, "PKCS5PADDING"
invoke-virtual {v0, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_24
const-string v1, "PKCS7PADDING"
invoke-virtual {v0, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_24
.line 218
new-instance v0, Ljavax/crypto/NoSuchPaddingException;
const-string v1, "padding not available with IESCipher"
invoke-direct {v0, v1}, Ljavax/crypto/NoSuchPaddingException;-><init>(Ljava/lang/String;)V
throw v0
.line 220
:cond_24
return-void
.end method
.method public engineUpdate([BII[BI)I
.registers 7
.prologue
.line 357
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v0, p1, p2, p3}, Ljava/io/ByteArrayOutputStream;->write([BII)V
.line 358
const/4 v0, 0x0
return v0
.end method
.method public engineUpdate([BII)[B
.registers 5
.prologue
.line 345
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/dh/IESCipher;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v0, p1, p2, p3}, Ljava/io/ByteArrayOutputStream;->write([BII)V
.line 346
const/4 v0, 0x0
return-object v0
.end method