TlsAEADCipher.smali
.class public Lorg/spongycastle/crypto/tls/TlsAEADCipher;
.super Ljava/lang/Object;
.source "TlsAEADCipher.java"
# interfaces
.implements Lorg/spongycastle/crypto/tls/TlsCipher;
# instance fields
.field protected context:Lorg/spongycastle/crypto/tls/TlsContext;
.field protected decryptCipher:Lorg/spongycastle/crypto/modes/AEADBlockCipher;
.field protected decryptImplicitNonce:[B
.field protected encryptCipher:Lorg/spongycastle/crypto/modes/AEADBlockCipher;
.field protected encryptImplicitNonce:[B
.field protected macSize:I
.field protected nonce_explicit_length:I
# direct methods
.method public constructor <init>(Lorg/spongycastle/crypto/tls/TlsContext;Lorg/spongycastle/crypto/modes/AEADBlockCipher;Lorg/spongycastle/crypto/modes/AEADBlockCipher;II)V
.registers 16
.prologue
const/16 v8, 0x50
const/4 v7, 0x0
.line 24
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 25
invoke-static {p1}, Lorg/spongycastle/crypto/tls/TlsUtils;->isTLSv12(Lorg/spongycastle/crypto/tls/TlsContext;)Z
move-result v0
if-nez v0, :cond_12
.line 27
new-instance v0, Lorg/spongycastle/crypto/tls/TlsFatalAlert;
invoke-direct {v0, v8}, Lorg/spongycastle/crypto/tls/TlsFatalAlert;-><init>(S)V
throw v0
.line 30
:cond_12
iput-object p1, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->context:Lorg/spongycastle/crypto/tls/TlsContext;
.line 31
iput p5, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->macSize:I
.line 34
const/16 v0, 0x8
iput v0, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->nonce_explicit_length:I
.line 39
mul-int/lit8 v0, p4, 0x2
add-int/lit8 v2, v0, 0x8
.line 41
invoke-static {p1, v2}, Lorg/spongycastle/crypto/tls/TlsUtils;->calculateKeyBlock(Lorg/spongycastle/crypto/tls/TlsContext;I)[B
move-result-object v3
.line 45
new-instance v0, Lorg/spongycastle/crypto/params/KeyParameter;
invoke-direct {v0, v3, v7, p4}, Lorg/spongycastle/crypto/params/KeyParameter;-><init>([BII)V
.line 47
new-instance v1, Lorg/spongycastle/crypto/params/KeyParameter;
invoke-direct {v1, v3, p4, p4}, Lorg/spongycastle/crypto/params/KeyParameter;-><init>([BII)V
.line 48
add-int v4, p4, p4
.line 49
add-int/lit8 v5, v4, 0x4
invoke-static {v3, v4, v5}, Lorg/spongycastle/util/Arrays;->copyOfRange([BII)[B
move-result-object v5
.line 50
add-int/lit8 v4, v4, 0x4
.line 51
add-int/lit8 v6, v4, 0x4
invoke-static {v3, v4, v6}, Lorg/spongycastle/util/Arrays;->copyOfRange([BII)[B
move-result-object v3
.line 52
add-int/lit8 v4, v4, 0x4
.line 54
if-eq v4, v2, :cond_46
.line 56
new-instance v0, Lorg/spongycastle/crypto/tls/TlsFatalAlert;
invoke-direct {v0, v8}, Lorg/spongycastle/crypto/tls/TlsFatalAlert;-><init>(S)V
throw v0
.line 60
:cond_46
invoke-interface {p1}, Lorg/spongycastle/crypto/tls/TlsContext;->isServer()Z
move-result v2
if-eqz v2, :cond_74
.line 62
iput-object p3, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->encryptCipher:Lorg/spongycastle/crypto/modes/AEADBlockCipher;
.line 63
iput-object p2, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->decryptCipher:Lorg/spongycastle/crypto/modes/AEADBlockCipher;
.line 64
iput-object v3, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->encryptImplicitNonce:[B
.line 65
iput-object v5, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->decryptImplicitNonce:[B
.line 79
:goto_54
iget v2, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->nonce_explicit_length:I
add-int/lit8 v2, v2, 0x4
new-array v2, v2, [B
.line 81
iget-object v3, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->encryptCipher:Lorg/spongycastle/crypto/modes/AEADBlockCipher;
const/4 v4, 0x1
new-instance v5, Lorg/spongycastle/crypto/params/AEADParameters;
shl-int/lit8 v6, p5, 0x3
invoke-direct {v5, v1, v6, v2}, Lorg/spongycastle/crypto/params/AEADParameters;-><init>(Lorg/spongycastle/crypto/params/KeyParameter;I[B)V
invoke-interface {v3, v4, v5}, Lorg/spongycastle/crypto/modes/AEADBlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
.line 82
iget-object v1, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->decryptCipher:Lorg/spongycastle/crypto/modes/AEADBlockCipher;
new-instance v3, Lorg/spongycastle/crypto/params/AEADParameters;
shl-int/lit8 v4, p5, 0x3
invoke-direct {v3, v0, v4, v2}, Lorg/spongycastle/crypto/params/AEADParameters;-><init>(Lorg/spongycastle/crypto/params/KeyParameter;I[B)V
invoke-interface {v1, v7, v3}, Lorg/spongycastle/crypto/modes/AEADBlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
.line 83
return-void
.line 71
:cond_74
iput-object p2, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->encryptCipher:Lorg/spongycastle/crypto/modes/AEADBlockCipher;
.line 72
iput-object p3, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->decryptCipher:Lorg/spongycastle/crypto/modes/AEADBlockCipher;
.line 73
iput-object v5, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->encryptImplicitNonce:[B
.line 74
iput-object v3, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->decryptImplicitNonce:[B
move-object v9, v1
move-object v1, v0
move-object v0, v9
.line 76
goto :goto_54
.end method
# virtual methods
.method public decodeCiphertext(JS[BII)[B
.registers 16
.prologue
const/4 v3, 0x0
.line 138
invoke-virtual {p0, p6}, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->getPlaintextLimit(I)I
move-result v0
if-gez v0, :cond_f
.line 140
new-instance v0, Lorg/spongycastle/crypto/tls/TlsFatalAlert;
const/16 v1, 0x32
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/tls/TlsFatalAlert;-><init>(S)V
throw v0
.line 143
:cond_f
iget-object v0, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->decryptImplicitNonce:[B
array-length v0, v0
iget v1, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->nonce_explicit_length:I
add-int/2addr v0, v1
new-array v0, v0, [B
.line 144
iget-object v1, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->decryptImplicitNonce:[B
iget-object v2, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->decryptImplicitNonce:[B
array-length v2, v2
invoke-static {v1, v3, v0, v3, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 145
iget-object v1, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->decryptImplicitNonce:[B
array-length v1, v1
iget v2, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->nonce_explicit_length:I
invoke-static {p4, p5, v0, v1, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 147
iget v1, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->nonce_explicit_length:I
add-int v2, p5, v1
.line 148
iget v1, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->nonce_explicit_length:I
sub-int v3, p6, v1
.line 149
iget-object v1, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->decryptCipher:Lorg/spongycastle/crypto/modes/AEADBlockCipher;
invoke-interface {v1, v3}, Lorg/spongycastle/crypto/modes/AEADBlockCipher;->getOutputSize(I)I
move-result v6
.line 151
new-array v4, v6, [B
.line 154
invoke-virtual {p0, p1, p2, p3, v6}, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->getAdditionalData(JSI)[B
move-result-object v1
.line 155
new-instance v5, Lorg/spongycastle/crypto/params/AEADParameters;
const/4 v7, 0x0
iget v8, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->macSize:I
mul-int/lit8 v8, v8, 0x8
invoke-direct {v5, v7, v8, v0, v1}, Lorg/spongycastle/crypto/params/AEADParameters;-><init>(Lorg/spongycastle/crypto/params/KeyParameter;I[B[B)V
.line 159
:try_start_45
iget-object v0, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->decryptCipher:Lorg/spongycastle/crypto/modes/AEADBlockCipher;
const/4 v1, 0x0
invoke-interface {v0, v1, v5}, Lorg/spongycastle/crypto/modes/AEADBlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
.line 160
iget-object v0, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->decryptCipher:Lorg/spongycastle/crypto/modes/AEADBlockCipher;
const/4 v5, 0x0
move-object v1, p4
invoke-interface/range {v0 .. v5}, Lorg/spongycastle/crypto/modes/AEADBlockCipher;->processBytes([BII[BI)I
move-result v0
add-int/lit8 v0, v0, 0x0
.line 161
iget-object v1, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->decryptCipher:Lorg/spongycastle/crypto/modes/AEADBlockCipher;
invoke-interface {v1, v4, v0}, Lorg/spongycastle/crypto/modes/AEADBlockCipher;->doFinal([BI)I
:try_end_5a
.catch Ljava/lang/Exception; {:try_start_45 .. :try_end_5a} :catch_66
move-result v1
add-int/2addr v0, v1
.line 168
if-eq v0, v6, :cond_6f
.line 171
new-instance v0, Lorg/spongycastle/crypto/tls/TlsFatalAlert;
const/16 v1, 0x50
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/tls/TlsFatalAlert;-><init>(S)V
throw v0
.line 163
:catch_66
move-exception v0
.line 165
new-instance v1, Lorg/spongycastle/crypto/tls/TlsFatalAlert;
const/16 v2, 0x14
invoke-direct {v1, v2, v0}, Lorg/spongycastle/crypto/tls/TlsFatalAlert;-><init>(SLjava/lang/Throwable;)V
throw v1
.line 174
:cond_6f
return-object v4
.end method
.method public encodePlaintext(JS[BII)[B
.registers 16
.prologue
const/16 v7, 0x50
const/4 v3, 0x0
.line 94
iget-object v0, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->encryptImplicitNonce:[B
array-length v0, v0
iget v1, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->nonce_explicit_length:I
add-int/2addr v0, v1
new-array v0, v0, [B
.line 95
iget-object v1, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->encryptImplicitNonce:[B
iget-object v2, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->encryptImplicitNonce:[B
array-length v2, v2
invoke-static {v1, v3, v0, v3, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 102
iget-object v1, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->encryptImplicitNonce:[B
array-length v1, v1
invoke-static {p1, p2, v0, v1}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeUint64(J[BI)V
.line 106
iget-object v1, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->encryptCipher:Lorg/spongycastle/crypto/modes/AEADBlockCipher;
invoke-interface {v1, p6}, Lorg/spongycastle/crypto/modes/AEADBlockCipher;->getOutputSize(I)I
move-result v1
.line 108
iget v2, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->nonce_explicit_length:I
add-int/2addr v1, v2
new-array v4, v1, [B
.line 109
iget-object v1, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->encryptImplicitNonce:[B
array-length v1, v1
iget v2, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->nonce_explicit_length:I
invoke-static {v0, v1, v4, v3, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 110
iget v5, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->nonce_explicit_length:I
.line 112
invoke-virtual {p0, p1, p2, p3, p6}, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->getAdditionalData(JSI)[B
move-result-object v1
.line 113
new-instance v2, Lorg/spongycastle/crypto/params/AEADParameters;
const/4 v3, 0x0
iget v6, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->macSize:I
mul-int/lit8 v6, v6, 0x8
invoke-direct {v2, v3, v6, v0, v1}, Lorg/spongycastle/crypto/params/AEADParameters;-><init>(Lorg/spongycastle/crypto/params/KeyParameter;I[B[B)V
.line 117
:try_start_3c
iget-object v0, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->encryptCipher:Lorg/spongycastle/crypto/modes/AEADBlockCipher;
const/4 v1, 0x1
invoke-interface {v0, v1, v2}, Lorg/spongycastle/crypto/modes/AEADBlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
.line 118
iget-object v0, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->encryptCipher:Lorg/spongycastle/crypto/modes/AEADBlockCipher;
move-object v1, p4
move v2, p5
move v3, p6
invoke-interface/range {v0 .. v5}, Lorg/spongycastle/crypto/modes/AEADBlockCipher;->processBytes([BII[BI)I
move-result v0
add-int/2addr v0, v5
.line 119
iget-object v1, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->encryptCipher:Lorg/spongycastle/crypto/modes/AEADBlockCipher;
invoke-interface {v1, v4, v0}, Lorg/spongycastle/crypto/modes/AEADBlockCipher;->doFinal([BI)I
:try_end_51
.catch Ljava/lang/Exception; {:try_start_3c .. :try_end_51} :catch_5c
move-result v1
add-int/2addr v0, v1
.line 126
array-length v1, v4
if-eq v0, v1, :cond_63
.line 129
new-instance v0, Lorg/spongycastle/crypto/tls/TlsFatalAlert;
invoke-direct {v0, v7}, Lorg/spongycastle/crypto/tls/TlsFatalAlert;-><init>(S)V
throw v0
.line 121
:catch_5c
move-exception v0
.line 123
new-instance v1, Lorg/spongycastle/crypto/tls/TlsFatalAlert;
invoke-direct {v1, v7, v0}, Lorg/spongycastle/crypto/tls/TlsFatalAlert;-><init>(SLjava/lang/Throwable;)V
throw v1
.line 132
:cond_63
return-object v4
.end method
.method protected getAdditionalData(JSI)[B
.registers 8
.prologue
.line 185
const/16 v0, 0xd
new-array v0, v0, [B
.line 186
const/4 v1, 0x0
invoke-static {p1, p2, v0, v1}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeUint64(J[BI)V
.line 187
const/16 v1, 0x8
invoke-static {p3, v0, v1}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeUint8(S[BI)V
.line 188
iget-object v1, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->context:Lorg/spongycastle/crypto/tls/TlsContext;
invoke-interface {v1}, Lorg/spongycastle/crypto/tls/TlsContext;->getServerVersion()Lorg/spongycastle/crypto/tls/ProtocolVersion;
move-result-object v1
const/16 v2, 0x9
invoke-static {v1, v0, v2}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeVersion(Lorg/spongycastle/crypto/tls/ProtocolVersion;[BI)V
.line 189
const/16 v1, 0xb
invoke-static {p4, v0, v1}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeUint16(I[BI)V
.line 191
return-object v0
.end method
.method public getPlaintextLimit(I)I
.registers 4
.prologue
.line 88
iget v0, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->macSize:I
sub-int v0, p1, v0
iget v1, p0, Lorg/spongycastle/crypto/tls/TlsAEADCipher;->nonce_explicit_length:I
sub-int/2addr v0, v1
return v0
.end method