RFC3211WrapEngine.smali
.class public Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;
.super Ljava/lang/Object;
.source "RFC3211WrapEngine.java"
# interfaces
.implements Lorg/spongycastle/crypto/Wrapper;
# instance fields
.field private engine:Lorg/spongycastle/crypto/modes/CBCBlockCipher;
.field private forWrapping:Z
.field private param:Lorg/spongycastle/crypto/params/ParametersWithIV;
.field private rand:Ljava/security/SecureRandom;
# direct methods
.method public constructor <init>(Lorg/spongycastle/crypto/BlockCipher;)V
.registers 3
.prologue
.line 26
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 27
new-instance v0, Lorg/spongycastle/crypto/modes/CBCBlockCipher;
invoke-direct {v0, p1}, Lorg/spongycastle/crypto/modes/CBCBlockCipher;-><init>(Lorg/spongycastle/crypto/BlockCipher;)V
iput-object v0, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->engine:Lorg/spongycastle/crypto/modes/CBCBlockCipher;
.line 28
return-void
.end method
# virtual methods
.method public getAlgorithmName()Ljava/lang/String;
.registers 3
.prologue
.line 56
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
iget-object v1, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->engine:Lorg/spongycastle/crypto/modes/CBCBlockCipher;
invoke-virtual {v1}, Lorg/spongycastle/crypto/modes/CBCBlockCipher;->getUnderlyingCipher()Lorg/spongycastle/crypto/BlockCipher;
move-result-object v1
invoke-interface {v1}, Lorg/spongycastle/crypto/BlockCipher;->getAlgorithmName()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, "/RFC3211Wrap"
invoke-virtual {v0, v1}, 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
return-object v0
.end method
.method public init(ZLorg/spongycastle/crypto/CipherParameters;)V
.registers 4
.prologue
.line 34
iput-boolean p1, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->forWrapping:Z
.line 36
instance-of v0, p2, Lorg/spongycastle/crypto/params/ParametersWithRandom;
if-eqz v0, :cond_17
.line 38
check-cast p2, Lorg/spongycastle/crypto/params/ParametersWithRandom;
.line 40
invoke-virtual {p2}, Lorg/spongycastle/crypto/params/ParametersWithRandom;->getRandom()Ljava/security/SecureRandom;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->rand:Ljava/security/SecureRandom;
.line 41
invoke-virtual {p2}, Lorg/spongycastle/crypto/params/ParametersWithRandom;->getParameters()Lorg/spongycastle/crypto/CipherParameters;
move-result-object v0
check-cast v0, Lorg/spongycastle/crypto/params/ParametersWithIV;
iput-object v0, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->param:Lorg/spongycastle/crypto/params/ParametersWithIV;
.line 52
:goto_16
return-void
.line 45
:cond_17
if-eqz p1, :cond_20
.line 47
new-instance v0, Ljava/security/SecureRandom;
invoke-direct {v0}, Ljava/security/SecureRandom;-><init>()V
iput-object v0, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->rand:Ljava/security/SecureRandom;
.line 50
:cond_20
check-cast p2, Lorg/spongycastle/crypto/params/ParametersWithIV;
iput-object p2, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->param:Lorg/spongycastle/crypto/params/ParametersWithIV;
goto :goto_16
.end method
.method public unwrap([BII)[B
.registers 11
.prologue
const/4 v0, 0x0
.line 114
iget-boolean v1, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->forWrapping:Z
if-eqz v1, :cond_d
.line 116
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 119
:cond_d
iget-object v1, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->engine:Lorg/spongycastle/crypto/modes/CBCBlockCipher;
invoke-virtual {v1}, Lorg/spongycastle/crypto/modes/CBCBlockCipher;->getBlockSize()I
move-result v2
.line 121
mul-int/lit8 v1, v2, 0x2
if-ge p3, v1, :cond_1f
.line 123
new-instance v0, Lorg/spongycastle/crypto/InvalidCipherTextException;
const-string v1, "input too short"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/InvalidCipherTextException;-><init>(Ljava/lang/String;)V
throw v0
.line 126
:cond_1f
new-array v3, p3, [B
.line 127
new-array v4, v2, [B
.line 129
invoke-static {p1, p2, v3, v0, p3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 130
invoke-static {p1, p2, v4, v0, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 132
iget-object v1, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->engine:Lorg/spongycastle/crypto/modes/CBCBlockCipher;
new-instance v5, Lorg/spongycastle/crypto/params/ParametersWithIV;
iget-object v6, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->param:Lorg/spongycastle/crypto/params/ParametersWithIV;
invoke-virtual {v6}, Lorg/spongycastle/crypto/params/ParametersWithIV;->getParameters()Lorg/spongycastle/crypto/CipherParameters;
move-result-object v6
invoke-direct {v5, v6, v4}, Lorg/spongycastle/crypto/params/ParametersWithIV;-><init>(Lorg/spongycastle/crypto/CipherParameters;[B)V
invoke-virtual {v1, v0, v5}, Lorg/spongycastle/crypto/modes/CBCBlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
move v1, v2
.line 134
:goto_3a
if-ge v1, p3, :cond_43
.line 136
iget-object v5, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->engine:Lorg/spongycastle/crypto/modes/CBCBlockCipher;
invoke-virtual {v5, v3, v1, v3, v1}, Lorg/spongycastle/crypto/modes/CBCBlockCipher;->processBlock([BI[BI)I
.line 134
add-int/2addr v1, v2
goto :goto_3a
.line 139
:cond_43
sub-int v1, p3, v2
invoke-static {v3, v1, v4, v0, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 141
iget-object v1, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->engine:Lorg/spongycastle/crypto/modes/CBCBlockCipher;
new-instance v5, Lorg/spongycastle/crypto/params/ParametersWithIV;
iget-object v6, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->param:Lorg/spongycastle/crypto/params/ParametersWithIV;
invoke-virtual {v6}, Lorg/spongycastle/crypto/params/ParametersWithIV;->getParameters()Lorg/spongycastle/crypto/CipherParameters;
move-result-object v6
invoke-direct {v5, v6, v4}, Lorg/spongycastle/crypto/params/ParametersWithIV;-><init>(Lorg/spongycastle/crypto/CipherParameters;[B)V
invoke-virtual {v1, v0, v5}, Lorg/spongycastle/crypto/modes/CBCBlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
.line 143
iget-object v1, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->engine:Lorg/spongycastle/crypto/modes/CBCBlockCipher;
invoke-virtual {v1, v3, v0, v3, v0}, Lorg/spongycastle/crypto/modes/CBCBlockCipher;->processBlock([BI[BI)I
.line 145
iget-object v1, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->engine:Lorg/spongycastle/crypto/modes/CBCBlockCipher;
iget-object v4, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->param:Lorg/spongycastle/crypto/params/ParametersWithIV;
invoke-virtual {v1, v0, v4}, Lorg/spongycastle/crypto/modes/CBCBlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
move v1, v0
.line 147
:goto_65
if-ge v1, p3, :cond_6e
.line 149
iget-object v4, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->engine:Lorg/spongycastle/crypto/modes/CBCBlockCipher;
invoke-virtual {v4, v3, v1, v3, v1}, Lorg/spongycastle/crypto/modes/CBCBlockCipher;->processBlock([BI[BI)I
.line 147
add-int/2addr v1, v2
goto :goto_65
.line 152
:cond_6e
aget-byte v1, v3, v0
and-int/lit16 v1, v1, 0xff
add-int/lit8 v2, p3, -0x4
if-le v1, v2, :cond_7e
.line 154
new-instance v0, Lorg/spongycastle/crypto/InvalidCipherTextException;
const-string v1, "wrapped key corrupted"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/InvalidCipherTextException;-><init>(Ljava/lang/String;)V
throw v0
.line 157
:cond_7e
aget-byte v1, v3, v0
and-int/lit16 v1, v1, 0xff
new-array v2, v1, [B
.line 159
const/4 v1, 0x4
aget-byte v4, v3, v0
invoke-static {v3, v1, v2, v0, v4}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
move v1, v0
.line 163
:goto_8b
const/4 v4, 0x3
if-eq v0, v4, :cond_9c
.line 165
add-int/lit8 v4, v0, 0x1
aget-byte v4, v3, v4
xor-int/lit8 v4, v4, -0x1
int-to-byte v4, v4
.line 166
aget-byte v5, v2, v0
xor-int/2addr v4, v5
or-int/2addr v1, v4
.line 163
add-int/lit8 v0, v0, 0x1
goto :goto_8b
.line 168
:cond_9c
if-eqz v1, :cond_a6
.line 170
new-instance v0, Lorg/spongycastle/crypto/InvalidCipherTextException;
const-string v1, "wrapped key fails checksum"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/InvalidCipherTextException;-><init>(Ljava/lang/String;)V
throw v0
.line 173
:cond_a6
return-object v2
.end method
.method public wrap([BII)[B
.registers 10
.prologue
const/4 v4, 0x1
const/4 v1, 0x0
.line 64
iget-boolean v0, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->forWrapping:Z
if-nez v0, :cond_e
.line 66
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 69
:cond_e
iget-object v0, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->engine:Lorg/spongycastle/crypto/modes/CBCBlockCipher;
iget-object v2, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->param:Lorg/spongycastle/crypto/params/ParametersWithIV;
invoke-virtual {v0, v4, v2}, Lorg/spongycastle/crypto/modes/CBCBlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
.line 71
iget-object v0, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->engine:Lorg/spongycastle/crypto/modes/CBCBlockCipher;
invoke-virtual {v0}, Lorg/spongycastle/crypto/modes/CBCBlockCipher;->getBlockSize()I
move-result v2
.line 74
add-int/lit8 v0, p3, 0x4
shl-int/lit8 v3, v2, 0x1
if-ge v0, v3, :cond_63
.line 76
shl-int/lit8 v0, v2, 0x1
.line 80
:goto_23
new-array v3, v0, [B
.line 83
int-to-byte v0, p3
aput-byte v0, v3, v1
.line 84
aget-byte v0, p1, p2
xor-int/lit8 v0, v0, -0x1
int-to-byte v0, v0
aput-byte v0, v3, v4
.line 85
const/4 v0, 0x2
add-int/lit8 v4, p2, 0x1
aget-byte v4, p1, v4
xor-int/lit8 v4, v4, -0x1
int-to-byte v4, v4
aput-byte v4, v3, v0
.line 86
const/4 v0, 0x3
add-int/lit8 v4, p2, 0x2
aget-byte v4, p1, v4
xor-int/lit8 v4, v4, -0x1
int-to-byte v4, v4
aput-byte v4, v3, v0
.line 88
const/4 v0, 0x4
invoke-static {p1, p2, v3, v0, p3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 90
array-length v0, v3
add-int/lit8 v4, p3, 0x4
sub-int/2addr v0, v4
new-array v0, v0, [B
.line 92
iget-object v4, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->rand:Ljava/security/SecureRandom;
invoke-virtual {v4, v0}, Ljava/security/SecureRandom;->nextBytes([B)V
.line 93
add-int/lit8 v4, p3, 0x4
array-length v5, v0
invoke-static {v0, v1, v3, v4, v5}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
move v0, v1
.line 95
:goto_59
array-length v4, v3
if-ge v0, v4, :cond_72
.line 97
iget-object v4, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->engine:Lorg/spongycastle/crypto/modes/CBCBlockCipher;
invoke-virtual {v4, v3, v0, v3, v0}, Lorg/spongycastle/crypto/modes/CBCBlockCipher;->processBlock([BI[BI)I
.line 95
add-int/2addr v0, v2
goto :goto_59
.line 80
:cond_63
add-int/lit8 v0, p3, 0x4
rem-int/2addr v0, v2
if-nez v0, :cond_6b
add-int/lit8 v0, p3, 0x4
goto :goto_23
:cond_6b
add-int/lit8 v0, p3, 0x4
div-int/2addr v0, v2
add-int/lit8 v0, v0, 0x1
mul-int/2addr v0, v2
goto :goto_23
.line 100
:cond_72
:goto_72
array-length v0, v3
if-ge v1, v0, :cond_7c
.line 102
iget-object v0, p0, Lorg/spongycastle/crypto/engines/RFC3211WrapEngine;->engine:Lorg/spongycastle/crypto/modes/CBCBlockCipher;
invoke-virtual {v0, v3, v1, v3, v1}, Lorg/spongycastle/crypto/modes/CBCBlockCipher;->processBlock([BI[BI)I
.line 100
add-int/2addr v1, v2
goto :goto_72
.line 105
:cond_7c
return-object v3
.end method