CipherSpi.smali
.class public Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;
.super Ljavax/crypto/CipherSpi;
.source "CipherSpi.java"
# instance fields
.field private availableSpecs:[Ljava/lang/Class;
.field private buffer:Ljava/io/ByteArrayOutputStream;
.field private cipher:Lorg/spongycastle/crypto/engines/IESEngine;
.field private engineParam:Ljava/security/AlgorithmParameters;
.field private engineParams:Lorg/spongycastle/jce/spec/IESParameterSpec;
.field private final helper:Lorg/spongycastle/jcajce/util/JcaJceHelper;
.field private state:I
# direct methods
.method public constructor <init>(Lorg/spongycastle/crypto/engines/IESEngine;)V
.registers 5
.prologue
const/4 v1, 0x0
.line 56
invoke-direct {p0}, Ljavax/crypto/CipherSpi;-><init>()V
.line 38
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/ies/CipherSpi;->helper:Lorg/spongycastle/jcajce/util/JcaJceHelper;
.line 41
const/4 v0, -0x1
iput v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->state:I
.line 42
new-instance v0, Ljava/io/ByteArrayOutputStream;
invoke-direct {v0}, Ljava/io/ByteArrayOutputStream;-><init>()V
iput-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->buffer:Ljava/io/ByteArrayOutputStream;
.line 43
iput-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->engineParam:Ljava/security/AlgorithmParameters;
.line 44
iput-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->engineParams:Lorg/spongycastle/jce/spec/IESParameterSpec;
.line 49
const/4 v0, 0x1
new-array v0, v0, [Ljava/lang/Class;
const/4 v1, 0x0
const-class v2, Lorg/spongycastle/jce/spec/IESParameterSpec;
aput-object v2, v0, v1
iput-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->availableSpecs:[Ljava/lang/Class;
.line 57
iput-object p1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->cipher:Lorg/spongycastle/crypto/engines/IESEngine;
.line 58
return-void
.end method
# virtual methods
.method protected engineDoFinal([BII[BI)I
.registers 10
.prologue
.line 334
if-eqz p3, :cond_7
.line 336
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v0, p1, p2, p3}, Ljava/io/ByteArrayOutputStream;->write([BII)V
.line 341
:cond_7
:try_start_7
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v0}, Ljava/io/ByteArrayOutputStream;->toByteArray()[B
move-result-object v0
.line 343
iget-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v1}, Ljava/io/ByteArrayOutputStream;->reset()V
.line 345
iget-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->cipher:Lorg/spongycastle/crypto/engines/IESEngine;
const/4 v2, 0x0
array-length v3, v0
invoke-virtual {v1, v0, v2, v3}, Lorg/spongycastle/crypto/engines/IESEngine;->processBlock([BII)[B
move-result-object v0
.line 347
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 349
array-length v0, v0
:try_end_20
.catch Lorg/spongycastle/crypto/InvalidCipherTextException; {:try_start_7 .. :try_end_20} :catch_21
return v0
.line 351
:catch_21
move-exception v0
.line 353
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
.end method
.method protected engineDoFinal([BII)[B
.registers 8
.prologue
.line 307
if-eqz p3, :cond_7
.line 309
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v0, p1, p2, p3}, Ljava/io/ByteArrayOutputStream;->write([BII)V
.line 314
:cond_7
:try_start_7
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v0}, Ljava/io/ByteArrayOutputStream;->toByteArray()[B
move-result-object v0
.line 316
iget-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v1}, Ljava/io/ByteArrayOutputStream;->reset()V
.line 318
iget-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->cipher:Lorg/spongycastle/crypto/engines/IESEngine;
const/4 v2, 0x0
array-length v3, v0
invoke-virtual {v1, v0, v2, v3}, Lorg/spongycastle/crypto/engines/IESEngine;->processBlock([BII)[B
:try_end_19
.catch Lorg/spongycastle/crypto/InvalidCipherTextException; {:try_start_7 .. :try_end_19} :catch_1b
move-result-object v0
return-object v0
.line 320
:catch_1b
move-exception v0
.line 322
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
.end method
.method protected engineGetBlockSize()I
.registers 2
.prologue
.line 62
const/4 v0, 0x0
return v0
.end method
.method protected engineGetIV()[B
.registers 2
.prologue
.line 67
const/4 v0, 0x0
return-object v0
.end method
.method protected engineGetKeySize(Ljava/security/Key;)I
.registers 4
.prologue
.line 73
instance-of v0, p1, Lorg/spongycastle/jce/interfaces/IESKey;
if-nez v0, :cond_c
.line 75
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "must be passed IE key"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 78
:cond_c
check-cast p1, Lorg/spongycastle/jce/interfaces/IESKey;
.line 80
invoke-interface {p1}, Lorg/spongycastle/jce/interfaces/IESKey;->getPrivate()Ljava/security/PrivateKey;
move-result-object v0
instance-of v0, v0, Ljavax/crypto/interfaces/DHPrivateKey;
if-eqz v0, :cond_25
.line 82
invoke-interface {p1}, Lorg/spongycastle/jce/interfaces/IESKey;->getPrivate()Ljava/security/PrivateKey;
move-result-object v0
check-cast v0, Ljavax/crypto/interfaces/DHPrivateKey;
.line 84
invoke-interface {v0}, Ljavax/crypto/interfaces/DHPrivateKey;->getX()Ljava/math/BigInteger;
move-result-object v0
invoke-virtual {v0}, Ljava/math/BigInteger;->bitLength()I
move-result v0
.line 90
:goto_24
return v0
.line 86
:cond_25
invoke-interface {p1}, Lorg/spongycastle/jce/interfaces/IESKey;->getPrivate()Ljava/security/PrivateKey;
move-result-object v0
instance-of v0, v0, Lorg/spongycastle/jce/interfaces/ECPrivateKey;
if-eqz v0, :cond_3c
.line 88
invoke-interface {p1}, Lorg/spongycastle/jce/interfaces/IESKey;->getPrivate()Ljava/security/PrivateKey;
move-result-object v0
check-cast v0, Lorg/spongycastle/jce/interfaces/ECPrivateKey;
.line 90
invoke-interface {v0}, Lorg/spongycastle/jce/interfaces/ECPrivateKey;->getD()Ljava/math/BigInteger;
move-result-object v0
invoke-virtual {v0}, Ljava/math/BigInteger;->bitLength()I
move-result v0
goto :goto_24
.line 93
:cond_3c
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "not an IE key!"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method protected engineGetOutputSize(I)I
.registers 4
.prologue
.line 99
iget v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->state:I
const/4 v1, 0x1
if-eq v0, v1, :cond_a
iget v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->state:I
const/4 v1, 0x3
if-ne v0, v1, :cond_14
.line 101
:cond_a
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v0}, Ljava/io/ByteArrayOutputStream;->size()I
move-result v0
add-int/2addr v0, p1
add-int/lit8 v0, v0, 0x14
.line 105
:goto_13
return v0
.line 103
:cond_14
iget v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->state:I
const/4 v1, 0x2
if-eq v0, v1, :cond_1e
iget v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->state:I
const/4 v1, 0x4
if-ne v0, v1, :cond_28
.line 105
:cond_1e
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v0}, Ljava/io/ByteArrayOutputStream;->size()I
move-result v0
add-int/2addr v0, p1
add-int/lit8 v0, v0, -0x14
goto :goto_13
.line 109
:cond_28
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
.end method
.method protected engineGetParameters()Ljava/security/AlgorithmParameters;
.registers 3
.prologue
.line 115
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->engineParam:Ljava/security/AlgorithmParameters;
if-nez v0, :cond_19
.line 117
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->engineParams:Lorg/spongycastle/jce/spec/IESParameterSpec;
if-eqz v0, :cond_19
.line 119
const-string v0, "IES"
.line 123
:try_start_a
iget-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->helper:Lorg/spongycastle/jcajce/util/JcaJceHelper;
invoke-interface {v1, v0}, 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/ies/CipherSpi;->engineParam:Ljava/security/AlgorithmParameters;
.line 124
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->engineParam:Ljava/security/AlgorithmParameters;
iget-object v1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->engineParams: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_a .. :try_end_19} :catch_1c
.line 133
:cond_19
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->engineParam:Ljava/security/AlgorithmParameters;
return-object v0
.line 126
:catch_1c
move-exception v0
.line 128
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 protected engineInit(ILjava/security/Key;Ljava/security/AlgorithmParameters;Ljava/security/SecureRandom;)V
.registers 8
.prologue
.line 232
const/4 v1, 0x0
.line 234
if-eqz p3, :cond_30
.line 236
const/4 v0, 0x0
:goto_4
iget-object v2, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->availableSpecs:[Ljava/lang/Class;
array-length v2, v2
if-eq v0, v2, :cond_37
.line 240
:try_start_9
iget-object v2, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->availableSpecs:[Ljava/lang/Class;
aget-object v2, v2, v0
invoke-virtual {p3, v2}, Ljava/security/AlgorithmParameters;->getParameterSpec(Ljava/lang/Class;)Ljava/security/spec/AlgorithmParameterSpec;
:try_end_10
.catch Ljava/lang/Exception; {:try_start_9 .. :try_end_10} :catch_2c
move-result-object v0
.line 249
:goto_11
if-nez v0, :cond_31
.line 251
new-instance v0, Ljava/security/InvalidAlgorithmParameterException;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "can\'t handle parameter "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p3}, Ljava/security/AlgorithmParameters;->toString()Ljava/lang/String;
move-result-object 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/InvalidAlgorithmParameterException;-><init>(Ljava/lang/String;)V
throw v0
.line 236
:catch_2c
move-exception v2
add-int/lit8 v0, v0, 0x1
goto :goto_4
:cond_30
move-object v0, v1
.line 255
:cond_31
iput-object p3, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->engineParam:Ljava/security/AlgorithmParameters;
.line 256
invoke-virtual {p0, p1, p2, v0, p4}, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->engineInit(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
.line 257
return-void
:cond_37
move-object v0, v1
goto :goto_11
.end method
.method protected engineInit(ILjava/security/Key;Ljava/security/SecureRandom;)V
.registers 6
.prologue
.line 265
const/4 v0, 0x1
if-eq p1, v0, :cond_6
const/4 v0, 0x3
if-ne p1, v0, :cond_c
.line 269
:cond_6
const/4 v0, 0x0
:try_start_7
invoke-virtual {p0, p1, p2, v0, p3}, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->engineInit(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
:try_end_a
.catch Ljava/security/InvalidAlgorithmParameterException; {:try_start_7 .. :try_end_a} :catch_b
.line 270
return-void
:catch_b
move-exception v0
.line 278
:cond_c
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "can\'t handle null parameter spec in IES"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method protected engineInit(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
.registers 12
.prologue
const/16 v2, 0x10
const/4 v6, 0x1
.line 156
instance-of v0, p2, Lorg/spongycastle/jce/interfaces/IESKey;
if-nez v0, :cond_f
.line 158
new-instance v0, Ljava/security/InvalidKeyException;
const-string v1, "must be passed IES key"
invoke-direct {v0, v1}, Ljava/security/InvalidKeyException;-><init>(Ljava/lang/String;)V
throw v0
.line 161
:cond_f
if-nez p3, :cond_75
if-eq p1, v6, :cond_16
const/4 v0, 0x3
if-ne p1, v0, :cond_75
.line 167
:cond_16
new-array v1, v2, [B
.line 168
new-array v2, v2, [B
.line 170
if-nez p4, :cond_21
.line 172
new-instance p4, Ljava/security/SecureRandom;
invoke-direct {p4}, Ljava/security/SecureRandom;-><init>()V
.line 175
:cond_21
invoke-virtual {p4, v1}, Ljava/security/SecureRandom;->nextBytes([B)V
.line 176
invoke-virtual {p4, v2}, Ljava/security/SecureRandom;->nextBytes([B)V
.line 178
new-instance v0, Lorg/spongycastle/jce/spec/IESParameterSpec;
const/16 v3, 0x80
invoke-direct {v0, v1, v2, v3}, Lorg/spongycastle/jce/spec/IESParameterSpec;-><init>([B[BI)V
.line 185
:goto_2e
check-cast p2, Lorg/spongycastle/jce/interfaces/IESKey;
.line 190
invoke-interface {p2}, Lorg/spongycastle/jce/interfaces/IESKey;->getPublic()Ljava/security/PublicKey;
move-result-object v1
instance-of v1, v1, Ljavax/crypto/interfaces/DHPublicKey;
if-eqz v1, :cond_81
.line 192
invoke-interface {p2}, Lorg/spongycastle/jce/interfaces/IESKey;->getPublic()Ljava/security/PublicKey;
move-result-object v1
invoke-static {v1}, Lorg/spongycastle/jcajce/provider/asymmetric/util/DHUtil;->generatePublicKeyParameter(Ljava/security/PublicKey;)Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
move-result-object v1
.line 193
invoke-interface {p2}, Lorg/spongycastle/jce/interfaces/IESKey;->getPrivate()Ljava/security/PrivateKey;
move-result-object v2
invoke-static {v2}, Lorg/spongycastle/jcajce/provider/asymmetric/util/DHUtil;->generatePrivateKeyParameter(Ljava/security/PrivateKey;)Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
move-result-object v2
.line 202
:goto_48
check-cast v0, Lorg/spongycastle/jce/spec/IESParameterSpec;
iput-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->engineParams:Lorg/spongycastle/jce/spec/IESParameterSpec;
.line 204
new-instance v0, Lorg/spongycastle/crypto/params/IESParameters;
iget-object v3, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->engineParams:Lorg/spongycastle/jce/spec/IESParameterSpec;
invoke-virtual {v3}, Lorg/spongycastle/jce/spec/IESParameterSpec;->getDerivationV()[B
move-result-object v3
iget-object v4, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->engineParams:Lorg/spongycastle/jce/spec/IESParameterSpec;
invoke-virtual {v4}, Lorg/spongycastle/jce/spec/IESParameterSpec;->getEncodingV()[B
move-result-object v4
iget-object v5, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->engineParams:Lorg/spongycastle/jce/spec/IESParameterSpec;
invoke-virtual {v5}, Lorg/spongycastle/jce/spec/IESParameterSpec;->getMacKeySize()I
move-result v5
invoke-direct {v0, v3, v4, v5}, Lorg/spongycastle/crypto/params/IESParameters;-><init>([B[BI)V
.line 206
iput p1, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->state:I
.line 208
iget-object v3, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v3}, Ljava/io/ByteArrayOutputStream;->reset()V
.line 210
packed-switch p1, :pswitch_data_a2
.line 221
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
const-string v1, "eeek!"
invoke-virtual {v0, v1}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 223
:goto_74
return-void
.line 180
:cond_75
instance-of v0, p3, Lorg/spongycastle/jce/spec/IESParameterSpec;
if-nez v0, :cond_9f
.line 182
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 198
:cond_81
invoke-interface {p2}, Lorg/spongycastle/jce/interfaces/IESKey;->getPublic()Ljava/security/PublicKey;
move-result-object v1
invoke-static {v1}, Lorg/spongycastle/jcajce/provider/asymmetric/util/ECUtil;->generatePublicKeyParameter(Ljava/security/PublicKey;)Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
move-result-object v1
.line 199
invoke-interface {p2}, Lorg/spongycastle/jce/interfaces/IESKey;->getPrivate()Ljava/security/PrivateKey;
move-result-object v2
invoke-static {v2}, Lorg/spongycastle/jcajce/provider/asymmetric/util/ECUtil;->generatePrivateKeyParameter(Ljava/security/PrivateKey;)Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
move-result-object v2
goto :goto_48
.line 214
:pswitch_92
iget-object v3, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->cipher:Lorg/spongycastle/crypto/engines/IESEngine;
invoke-virtual {v3, v6, v2, v1, v0}, Lorg/spongycastle/crypto/engines/IESEngine;->init(ZLorg/spongycastle/crypto/CipherParameters;Lorg/spongycastle/crypto/CipherParameters;Lorg/spongycastle/crypto/CipherParameters;)V
goto :goto_74
.line 218
:pswitch_98
iget-object v3, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->cipher:Lorg/spongycastle/crypto/engines/IESEngine;
const/4 v4, 0x0
invoke-virtual {v3, v4, v2, v1, v0}, Lorg/spongycastle/crypto/engines/IESEngine;->init(ZLorg/spongycastle/crypto/CipherParameters;Lorg/spongycastle/crypto/CipherParameters;Lorg/spongycastle/crypto/CipherParameters;)V
goto :goto_74
:cond_9f
move-object v0, p3
goto :goto_2e
.line 210
nop
:pswitch_data_a2
.packed-switch 0x1
:pswitch_92
:pswitch_98
:pswitch_92
:pswitch_98
.end packed-switch
.end method
.method protected engineSetMode(Ljava/lang/String;)V
.registers 5
.prologue
.line 139
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 protected engineSetPadding(Ljava/lang/String;)V
.registers 5
.prologue
.line 146
new-instance v0, Ljavax/crypto/NoSuchPaddingException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, " unavailable with RSA."
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}, Ljavax/crypto/NoSuchPaddingException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method protected engineUpdate([BII[BI)I
.registers 7
.prologue
.line 297
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v0, p1, p2, p3}, Ljava/io/ByteArrayOutputStream;->write([BII)V
.line 298
const/4 v0, 0x0
return v0
.end method
.method protected engineUpdate([BII)[B
.registers 5
.prologue
.line 286
iget-object v0, p0, Lorg/spongycastle/jcajce/provider/asymmetric/ies/CipherSpi;->buffer:Ljava/io/ByteArrayOutputStream;
invoke-virtual {v0, p1, p2, p3}, Ljava/io/ByteArrayOutputStream;->write([BII)V
.line 287
const/4 v0, 0x0
return-object v0
.end method