RFC5649WrapEngine.smali
.class public Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;
.super Ljava/lang/Object;
.source "RFC5649WrapEngine.java"
# interfaces
.implements Lorg/spongycastle/crypto/Wrapper;
# instance fields
.field private engine:Lorg/spongycastle/crypto/BlockCipher;
.field private extractedAIV:[B
.field private forWrapping:Z
.field private highOrderIV:[B
.field private param:Lorg/spongycastle/crypto/params/KeyParameter;
.field private preIV:[B
# direct methods
.method public constructor <init>(Lorg/spongycastle/crypto/BlockCipher;)V
.registers 3
.prologue
.line 35
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 29
const/4 v0, 0x4
new-array v0, v0, [B
fill-array-data v0, :array_16
iput-object v0, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->highOrderIV:[B
.line 30
iget-object v0, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->highOrderIV:[B
iput-object v0, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->preIV:[B
.line 32
const/4 v0, 0x0
iput-object v0, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->extractedAIV:[B
.line 36
iput-object p1, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->engine:Lorg/spongycastle/crypto/BlockCipher;
.line 37
return-void
.line 29
nop
:array_16
.array-data 1
-0x5at
0x59t
0x59t
-0x5at
.end array-data
.end method
.method private padPlaintext([B)[B
.registers 7
.prologue
const/4 v4, 0x0
.line 77
array-length v0, p1
.line 78
rem-int/lit8 v1, v0, 0x8
rsub-int/lit8 v1, v1, 0x8
rem-int/lit8 v1, v1, 0x8
.line 79
add-int v2, v0, v1
new-array v2, v2, [B
.line 80
invoke-static {p1, v4, v2, v4, v0}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 81
if-eqz v1, :cond_16
.line 85
new-array v3, v1, [B
.line 86
invoke-static {v3, v4, v2, v0, v1}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 88
:cond_16
return-object v2
.end method
.method private rfc3394UnwrapNoIvCheck([BII)[B
.registers 15
.prologue
.line 259
add-int/lit8 v0, p3, -0x8
new-array v5, v0, [B
.line 260
const/16 v0, 0x8
new-array v6, v0, [B
.line 261
const/16 v0, 0x10
new-array v7, v0, [B
.line 263
const/4 v0, 0x0
const/16 v1, 0x8
invoke-static {p1, p2, v6, v0, v1}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 264
add-int/lit8 v0, p2, 0x8
const/4 v1, 0x0
add-int/lit8 v2, p3, -0x8
invoke-static {p1, v0, v5, v1, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 266
iget-object v0, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->engine:Lorg/spongycastle/crypto/BlockCipher;
const/4 v1, 0x0
iget-object v2, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->param:Lorg/spongycastle/crypto/params/KeyParameter;
invoke-interface {v0, v1, v2}, Lorg/spongycastle/crypto/BlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
.line 268
div-int/lit8 v0, p3, 0x8
.line 269
add-int/lit8 v3, v0, -0x1
.line 271
const/4 v0, 0x5
move v4, v0
:goto_28
if-ltz v4, :cond_75
move v2, v3
.line 273
:goto_2b
if-lez v2, :cond_71
.line 275
const/4 v0, 0x0
const/4 v1, 0x0
const/16 v8, 0x8
invoke-static {v6, v0, v7, v1, v8}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 276
add-int/lit8 v0, v2, -0x1
mul-int/lit8 v0, v0, 0x8
const/16 v1, 0x8
const/16 v8, 0x8
invoke-static {v5, v0, v7, v1, v8}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 278
mul-int v0, v3, v4
add-int v1, v0, v2
.line 279
const/4 v0, 0x1
:goto_44
if-eqz v1, :cond_54
.line 281
int-to-byte v8, v1
.line 283
rsub-int/lit8 v9, v0, 0x8
aget-byte v10, v7, v9
xor-int/2addr v8, v10
int-to-byte v8, v8
aput-byte v8, v7, v9
.line 285
ushr-int/lit8 v1, v1, 0x8
.line 279
add-int/lit8 v0, v0, 0x1
goto :goto_44
.line 288
:cond_54
iget-object v0, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->engine:Lorg/spongycastle/crypto/BlockCipher;
const/4 v1, 0x0
const/4 v8, 0x0
invoke-interface {v0, v7, v1, v7, v8}, Lorg/spongycastle/crypto/BlockCipher;->processBlock([BI[BI)I
.line 289
const/4 v0, 0x0
const/4 v1, 0x0
const/16 v8, 0x8
invoke-static {v7, v0, v6, v1, v8}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 290
const/16 v0, 0x8
add-int/lit8 v1, v2, -0x1
mul-int/lit8 v1, v1, 0x8
const/16 v8, 0x8
invoke-static {v7, v0, v5, v1, v8}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 273
add-int/lit8 v0, v2, -0x1
move v2, v0
goto :goto_2b
.line 271
:cond_71
add-int/lit8 v0, v4, -0x1
move v4, v0
goto :goto_28
.line 295
:cond_75
iput-object v6, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->extractedAIV:[B
.line 297
return-object v5
.end method
# virtual methods
.method public getAlgorithmName()Ljava/lang/String;
.registers 2
.prologue
.line 65
iget-object v0, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->engine:Lorg/spongycastle/crypto/BlockCipher;
invoke-interface {v0}, Lorg/spongycastle/crypto/BlockCipher;->getAlgorithmName()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public init(ZLorg/spongycastle/crypto/CipherParameters;)V
.registers 5
.prologue
.line 41
iput-boolean p1, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->forWrapping:Z
.line 43
instance-of v0, p2, Lorg/spongycastle/crypto/params/ParametersWithRandom;
if-eqz v0, :cond_3a
.line 45
check-cast p2, Lorg/spongycastle/crypto/params/ParametersWithRandom;
invoke-virtual {p2}, Lorg/spongycastle/crypto/params/ParametersWithRandom;->getParameters()Lorg/spongycastle/crypto/CipherParameters;
move-result-object v0
.line 48
:goto_c
instance-of v1, v0, Lorg/spongycastle/crypto/params/KeyParameter;
if-eqz v1, :cond_15
.line 50
check-cast v0, Lorg/spongycastle/crypto/params/KeyParameter;
iput-object v0, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->param:Lorg/spongycastle/crypto/params/KeyParameter;
.line 61
:cond_14
return-void
.line 52
:cond_15
instance-of v1, v0, Lorg/spongycastle/crypto/params/ParametersWithIV;
if-eqz v1, :cond_14
move-object v1, v0
.line 54
check-cast v1, Lorg/spongycastle/crypto/params/ParametersWithIV;
invoke-virtual {v1}, Lorg/spongycastle/crypto/params/ParametersWithIV;->getIV()[B
move-result-object v1
iput-object v1, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->preIV:[B
.line 55
check-cast v0, Lorg/spongycastle/crypto/params/ParametersWithIV;
invoke-virtual {v0}, Lorg/spongycastle/crypto/params/ParametersWithIV;->getParameters()Lorg/spongycastle/crypto/CipherParameters;
move-result-object v0
check-cast v0, Lorg/spongycastle/crypto/params/KeyParameter;
iput-object v0, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->param:Lorg/spongycastle/crypto/params/KeyParameter;
.line 56
iget-object v0, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->preIV:[B
array-length v0, v0
const/4 v1, 0x4
if-eq v0, v1, :cond_14
.line 58
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "IV length not equal to 4"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
:cond_3a
move-object v0, p2
goto :goto_c
.end method
.method public unwrap([BII)[B
.registers 12
.prologue
const/4 v1, 0x1
const/4 v6, 0x4
const/4 v2, 0x0
.line 144
iget-boolean v0, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->forWrapping:Z
if-eqz v0, :cond_f
.line 146
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "not set for unwrapping"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 149
:cond_f
div-int/lit8 v0, p3, 0x8
.line 151
shl-int/lit8 v3, v0, 0x3
if-eq v3, p3, :cond_1d
.line 153
new-instance v0, Lorg/spongycastle/crypto/InvalidCipherTextException;
const-string v1, "unwrap data must be a multiple of 8 bytes"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/InvalidCipherTextException;-><init>(Ljava/lang/String;)V
throw v0
.line 156
:cond_1d
if-ne v0, v1, :cond_27
.line 158
new-instance v0, Lorg/spongycastle/crypto/InvalidCipherTextException;
const-string v1, "unwrap data must be at least 16 bytes"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/InvalidCipherTextException;-><init>(Ljava/lang/String;)V
throw v0
.line 161
:cond_27
new-array v3, p3, [B
.line 162
invoke-static {p1, p2, v3, v2, p3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 163
new-array v4, p3, [B
.line 166
const/4 v5, 0x2
if-ne v0, v5, :cond_a9
.line 170
iget-object v0, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->engine:Lorg/spongycastle/crypto/BlockCipher;
iget-object v5, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->param:Lorg/spongycastle/crypto/params/KeyParameter;
invoke-interface {v0, v2, v5}, Lorg/spongycastle/crypto/BlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
move v0, v2
.line 171
:goto_39
if-ge v0, p3, :cond_48
.line 173
iget-object v5, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->engine:Lorg/spongycastle/crypto/BlockCipher;
invoke-interface {v5, v3, v0, v4, v0}, Lorg/spongycastle/crypto/BlockCipher;->processBlock([BI[BI)I
.line 171
iget-object v5, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->engine:Lorg/spongycastle/crypto/BlockCipher;
invoke-interface {v5}, Lorg/spongycastle/crypto/BlockCipher;->getBlockSize()I
move-result v5
add-int/2addr v0, v5
goto :goto_39
.line 177
:cond_48
const/16 v0, 0x8
new-array v0, v0, [B
iput-object v0, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->extractedAIV:[B
.line 178
iget-object v0, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->extractedAIV:[B
iget-object v3, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->extractedAIV:[B
array-length v3, v3
invoke-static {v4, v2, v0, v2, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 179
iget-object v0, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->extractedAIV:[B
array-length v0, v0
sub-int v0, p3, v0
new-array v0, v0, [B
.line 180
iget-object v3, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->extractedAIV:[B
array-length v3, v3
array-length v5, v0
invoke-static {v4, v3, v0, v2, v5}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 190
:goto_64
new-array v3, v6, [B
.line 191
new-array v4, v6, [B
.line 192
iget-object v5, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->extractedAIV:[B
invoke-static {v5, v2, v3, v2, v6}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 193
iget-object v5, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->extractedAIV:[B
invoke-static {v5, v6, v4, v2, v6}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 194
invoke-static {v4, v2}, Lorg/spongycastle/util/Pack;->bigEndianToInt([BI)I
move-result v4
.line 201
iget-object v5, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->preIV:[B
invoke-static {v3, v5}, Lorg/spongycastle/util/Arrays;->constantTimeAreEqual([B[B)Z
move-result v3
if-nez v3, :cond_7f
move v1, v2
.line 207
:cond_7f
array-length v3, v0
.line 208
add-int/lit8 v5, v3, -0x8
.line 209
if-gt v4, v5, :cond_85
move v1, v2
.line 213
:cond_85
if-le v4, v3, :cond_88
move v1, v2
.line 219
:cond_88
sub-int/2addr v3, v4
.line 220
array-length v5, v0
if-lt v3, v5, :cond_8f
.line 223
array-length v1, v0
move v3, v1
move v1, v2
.line 226
:cond_8f
new-array v5, v3, [B
.line 227
new-array v6, v3, [B
.line 228
array-length v7, v0
sub-int/2addr v7, v3
invoke-static {v0, v7, v6, v2, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 229
invoke-static {v6, v5}, Lorg/spongycastle/util/Arrays;->constantTimeAreEqual([B[B)Z
move-result v3
if-nez v3, :cond_9f
move v1, v2
.line 234
:cond_9f
if-nez v1, :cond_ae
.line 236
new-instance v0, Lorg/spongycastle/crypto/InvalidCipherTextException;
const-string v1, "checksum failed"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/InvalidCipherTextException;-><init>(Ljava/lang/String;)V
throw v0
.line 185
:cond_a9
invoke-direct {p0, p1, p2, p3}, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->rfc3394UnwrapNoIvCheck([BII)[B
move-result-object v0
goto :goto_64
.line 240
:cond_ae
new-array v1, v4, [B
.line 241
array-length v3, v1
invoke-static {v0, v2, v1, v2, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 243
return-object v1
.end method
.method public wrap([BII)[B
.registers 11
.prologue
const/4 v6, 0x1
const/16 v5, 0x8
const/4 v0, 0x0
.line 93
iget-boolean v1, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->forWrapping:Z
if-nez v1, :cond_10
.line 95
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "not set for wrapping"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 97
:cond_10
new-array v2, v5, [B
.line 100
invoke-static {p3}, Lorg/spongycastle/util/Pack;->intToBigEndian(I)[B
move-result-object v1
.line 102
iget-object v3, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->preIV:[B
iget-object v4, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->preIV:[B
array-length v4, v4
invoke-static {v3, v0, v2, v0, v4}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 104
iget-object v3, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->preIV:[B
array-length v3, v3
array-length v4, v1
invoke-static {v1, v0, v2, v3, v4}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 107
new-array v1, p3, [B
.line 108
invoke-static {p1, p2, v1, v0, p3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 109
invoke-direct {p0, v1}, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->padPlaintext([B)[B
move-result-object v3
.line 111
array-length v1, v3
if-ne v1, v5, :cond_56
.line 117
array-length v1, v3
add-int/lit8 v1, v1, 0x8
new-array v1, v1, [B
.line 118
invoke-static {v2, v0, v1, v0, v5}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 119
array-length v2, v3
invoke-static {v3, v0, v1, v5, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 121
iget-object v2, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->engine:Lorg/spongycastle/crypto/BlockCipher;
iget-object v3, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->param:Lorg/spongycastle/crypto/params/KeyParameter;
invoke-interface {v2, v6, v3}, Lorg/spongycastle/crypto/BlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
.line 122
:goto_44
array-length v2, v1
if-ge v0, v2, :cond_54
.line 124
iget-object v2, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->engine:Lorg/spongycastle/crypto/BlockCipher;
invoke-interface {v2, v1, v0, v1, v0}, Lorg/spongycastle/crypto/BlockCipher;->processBlock([BI[BI)I
.line 122
iget-object v2, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->engine:Lorg/spongycastle/crypto/BlockCipher;
invoke-interface {v2}, Lorg/spongycastle/crypto/BlockCipher;->getBlockSize()I
move-result v2
add-int/2addr v0, v2
goto :goto_44
:cond_54
move-object v0, v1
.line 136
:goto_55
return-object v0
.line 133
:cond_56
new-instance v1, Lorg/spongycastle/crypto/engines/RFC3394WrapEngine;
iget-object v4, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->engine:Lorg/spongycastle/crypto/BlockCipher;
invoke-direct {v1, v4}, Lorg/spongycastle/crypto/engines/RFC3394WrapEngine;-><init>(Lorg/spongycastle/crypto/BlockCipher;)V
.line 134
new-instance v4, Lorg/spongycastle/crypto/params/ParametersWithIV;
iget-object v5, p0, Lorg/spongycastle/crypto/engines/RFC5649WrapEngine;->param:Lorg/spongycastle/crypto/params/KeyParameter;
invoke-direct {v4, v5, v2}, Lorg/spongycastle/crypto/params/ParametersWithIV;-><init>(Lorg/spongycastle/crypto/CipherParameters;[B)V
.line 135
invoke-interface {v1, v6, v4}, Lorg/spongycastle/crypto/Wrapper;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
.line 136
array-length v2, v3
invoke-interface {v1, v3, v0, v2}, Lorg/spongycastle/crypto/Wrapper;->wrap([BII)[B
move-result-object v0
goto :goto_55
.end method