SSL3Mac.smali
.class public Lorg/spongycastle/crypto/tls/SSL3Mac;
.super Ljava/lang/Object;
.source "SSL3Mac.java"
# interfaces
.implements Lorg/spongycastle/crypto/Mac;
# static fields
.field static final IPAD:[B
.field private static final IPAD_BYTE:B = 0x36t
.field static final OPAD:[B
.field private static final OPAD_BYTE:B = 0x5ct
# instance fields
.field private digest:Lorg/spongycastle/crypto/Digest;
.field private padLength:I
.field private secret:[B
# direct methods
.method static constructor <clinit>()V
.registers 2
.prologue
const/16 v1, 0x30
.line 22
const/16 v0, 0x36
invoke-static {v0, v1}, Lorg/spongycastle/crypto/tls/SSL3Mac;->genPad(BI)[B
move-result-object v0
sput-object v0, Lorg/spongycastle/crypto/tls/SSL3Mac;->IPAD:[B
.line 23
const/16 v0, 0x5c
invoke-static {v0, v1}, Lorg/spongycastle/crypto/tls/SSL3Mac;->genPad(BI)[B
move-result-object v0
sput-object v0, Lorg/spongycastle/crypto/tls/SSL3Mac;->OPAD:[B
return-void
.end method
.method public constructor <init>(Lorg/spongycastle/crypto/Digest;)V
.registers 4
.prologue
.line 37
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 38
iput-object p1, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->digest:Lorg/spongycastle/crypto/Digest;
.line 40
invoke-interface {p1}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v0
const/16 v1, 0x14
if-ne v0, v1, :cond_12
.line 42
const/16 v0, 0x28
iput v0, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->padLength:I
.line 48
:goto_11
return-void
.line 46
:cond_12
const/16 v0, 0x30
iput v0, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->padLength:I
goto :goto_11
.end method
.method private static genPad(BI)[B
.registers 3
.prologue
.line 110
new-array v0, p1, [B
.line 111
invoke-static {v0, p0}, Lorg/spongycastle/util/Arrays;->fill([BB)V
.line 112
return-object v0
.end method
# virtual methods
.method public doFinal([BI)I
.registers 8
.prologue
const/4 v4, 0x0
.line 84
iget-object v0, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->digest:Lorg/spongycastle/crypto/Digest;
invoke-interface {v0}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v0
new-array v0, v0, [B
.line 85
iget-object v1, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->digest:Lorg/spongycastle/crypto/Digest;
invoke-interface {v1, v0, v4}, Lorg/spongycastle/crypto/Digest;->doFinal([BI)I
.line 87
iget-object v1, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->digest:Lorg/spongycastle/crypto/Digest;
iget-object v2, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->secret:[B
iget-object v3, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->secret:[B
array-length v3, v3
invoke-interface {v1, v2, v4, v3}, Lorg/spongycastle/crypto/Digest;->update([BII)V
.line 88
iget-object v1, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->digest:Lorg/spongycastle/crypto/Digest;
sget-object v2, Lorg/spongycastle/crypto/tls/SSL3Mac;->OPAD:[B
iget v3, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->padLength:I
invoke-interface {v1, v2, v4, v3}, Lorg/spongycastle/crypto/Digest;->update([BII)V
.line 89
iget-object v1, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->digest:Lorg/spongycastle/crypto/Digest;
array-length v2, v0
invoke-interface {v1, v0, v4, v2}, Lorg/spongycastle/crypto/Digest;->update([BII)V
.line 91
iget-object v0, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->digest:Lorg/spongycastle/crypto/Digest;
invoke-interface {v0, p1, p2}, Lorg/spongycastle/crypto/Digest;->doFinal([BI)I
move-result v0
.line 93
invoke-virtual {p0}, Lorg/spongycastle/crypto/tls/SSL3Mac;->reset()V
.line 95
return v0
.end method
.method public getAlgorithmName()Ljava/lang/String;
.registers 3
.prologue
.line 52
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
iget-object v1, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->digest:Lorg/spongycastle/crypto/Digest;
invoke-interface {v1}, Lorg/spongycastle/crypto/Digest;->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, "/SSL3MAC"
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 getMacSize()I
.registers 2
.prologue
.line 69
iget-object v0, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->digest:Lorg/spongycastle/crypto/Digest;
invoke-interface {v0}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v0
return v0
.end method
.method public getUnderlyingDigest()Lorg/spongycastle/crypto/Digest;
.registers 2
.prologue
.line 57
iget-object v0, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->digest:Lorg/spongycastle/crypto/Digest;
return-object v0
.end method
.method public init(Lorg/spongycastle/crypto/CipherParameters;)V
.registers 3
.prologue
.line 62
check-cast p1, Lorg/spongycastle/crypto/params/KeyParameter;
invoke-virtual {p1}, Lorg/spongycastle/crypto/params/KeyParameter;->getKey()[B
move-result-object v0
invoke-static {v0}, Lorg/spongycastle/util/Arrays;->clone([B)[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->secret:[B
.line 64
invoke-virtual {p0}, Lorg/spongycastle/crypto/tls/SSL3Mac;->reset()V
.line 65
return-void
.end method
.method public reset()V
.registers 5
.prologue
const/4 v3, 0x0
.line 103
iget-object v0, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->digest:Lorg/spongycastle/crypto/Digest;
invoke-interface {v0}, Lorg/spongycastle/crypto/Digest;->reset()V
.line 104
iget-object v0, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->digest:Lorg/spongycastle/crypto/Digest;
iget-object v1, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->secret:[B
iget-object v2, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->secret:[B
array-length v2, v2
invoke-interface {v0, v1, v3, v2}, Lorg/spongycastle/crypto/Digest;->update([BII)V
.line 105
iget-object v0, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->digest:Lorg/spongycastle/crypto/Digest;
sget-object v1, Lorg/spongycastle/crypto/tls/SSL3Mac;->IPAD:[B
iget v2, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->padLength:I
invoke-interface {v0, v1, v3, v2}, Lorg/spongycastle/crypto/Digest;->update([BII)V
.line 106
return-void
.end method
.method public update(B)V
.registers 3
.prologue
.line 74
iget-object v0, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->digest:Lorg/spongycastle/crypto/Digest;
invoke-interface {v0, p1}, Lorg/spongycastle/crypto/Digest;->update(B)V
.line 75
return-void
.end method
.method public update([BII)V
.registers 5
.prologue
.line 79
iget-object v0, p0, Lorg/spongycastle/crypto/tls/SSL3Mac;->digest:Lorg/spongycastle/crypto/Digest;
invoke-interface {v0, p1, p2, p3}, Lorg/spongycastle/crypto/Digest;->update([BII)V
.line 80
return-void
.end method