AbstractTlsContext.smali
.class abstract Lorg/spongycastle/crypto/tls/AbstractTlsContext;
.super Ljava/lang/Object;
.source "AbstractTlsContext.java"
# interfaces
.implements Lorg/spongycastle/crypto/tls/TlsContext;
# static fields
.field private static counter:J
# instance fields
.field private clientVersion:Lorg/spongycastle/crypto/tls/ProtocolVersion;
.field private nonceRandom:Lorg/spongycastle/crypto/prng/RandomGenerator;
.field private secureRandom:Ljava/security/SecureRandom;
.field private securityParameters:Lorg/spongycastle/crypto/tls/SecurityParameters;
.field private serverVersion:Lorg/spongycastle/crypto/tls/ProtocolVersion;
.field private session:Lorg/spongycastle/crypto/tls/TlsSession;
.field private userObject:Ljava/lang/Object;
# direct methods
.method static constructor <clinit>()V
.registers 2
.prologue
.line 13
invoke-static {}, Lorg/spongycastle/util/Times;->nanoTime()J
move-result-wide v0
sput-wide v0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->counter:J
return-void
.end method
.method constructor <init>(Ljava/security/SecureRandom;Lorg/spongycastle/crypto/tls/SecurityParameters;)V
.registers 7
.prologue
const/4 v0, 0x0
.line 30
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 24
iput-object v0, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->clientVersion:Lorg/spongycastle/crypto/tls/ProtocolVersion;
.line 25
iput-object v0, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->serverVersion:Lorg/spongycastle/crypto/tls/ProtocolVersion;
.line 26
iput-object v0, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->session:Lorg/spongycastle/crypto/tls/TlsSession;
.line 27
iput-object v0, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->userObject:Ljava/lang/Object;
.line 31
const/4 v0, 0x4
invoke-static {v0}, Lorg/spongycastle/crypto/tls/TlsUtils;->createHash(S)Lorg/spongycastle/crypto/Digest;
move-result-object v0
.line 32
invoke-interface {v0}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v1
new-array v1, v1, [B
.line 33
invoke-virtual {p1, v1}, Ljava/security/SecureRandom;->nextBytes([B)V
.line 35
new-instance v2, Lorg/spongycastle/crypto/prng/DigestRandomGenerator;
invoke-direct {v2, v0}, Lorg/spongycastle/crypto/prng/DigestRandomGenerator;-><init>(Lorg/spongycastle/crypto/Digest;)V
iput-object v2, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->nonceRandom:Lorg/spongycastle/crypto/prng/RandomGenerator;
.line 36
iget-object v0, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->nonceRandom:Lorg/spongycastle/crypto/prng/RandomGenerator;
invoke-static {}, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->nextCounterValue()J
move-result-wide v2
invoke-interface {v0, v2, v3}, Lorg/spongycastle/crypto/prng/RandomGenerator;->addSeedMaterial(J)V
.line 37
iget-object v0, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->nonceRandom:Lorg/spongycastle/crypto/prng/RandomGenerator;
invoke-static {}, Lorg/spongycastle/util/Times;->nanoTime()J
move-result-wide v2
invoke-interface {v0, v2, v3}, Lorg/spongycastle/crypto/prng/RandomGenerator;->addSeedMaterial(J)V
.line 38
iget-object v0, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->nonceRandom:Lorg/spongycastle/crypto/prng/RandomGenerator;
invoke-interface {v0, v1}, Lorg/spongycastle/crypto/prng/RandomGenerator;->addSeedMaterial([B)V
.line 40
iput-object p1, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->secureRandom:Ljava/security/SecureRandom;
.line 41
iput-object p2, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->securityParameters:Lorg/spongycastle/crypto/tls/SecurityParameters;
.line 42
return-void
.end method
.method private static declared-synchronized nextCounterValue()J
.registers 6
.prologue
.line 17
const-class v1, Lorg/spongycastle/crypto/tls/AbstractTlsContext;
monitor-enter v1
:try_start_3
sget-wide v2, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->counter:J
const-wide/16 v4, 0x1
add-long/2addr v2, v4
sput-wide v2, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->counter:J
:try_end_a
.catchall {:try_start_3 .. :try_end_a} :catchall_c
monitor-exit v1
return-wide v2
:catchall_c
move-exception v0
monitor-exit v1
throw v0
.end method
# virtual methods
.method public exportKeyingMaterial(Ljava/lang/String;[BI)[B
.registers 11
.prologue
const/4 v6, 0x0
.line 110
if-eqz p2, :cond_12
array-length v0, p2
invoke-static {v0}, Lorg/spongycastle/crypto/tls/TlsUtils;->isValidUint16(I)Z
move-result v0
if-nez v0, :cond_12
.line 112
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "\'context_value\' must have length less than 2^16 (or be null)"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 115
:cond_12
invoke-virtual {p0}, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->getSecurityParameters()Lorg/spongycastle/crypto/tls/SecurityParameters;
move-result-object v2
.line 116
invoke-virtual {v2}, Lorg/spongycastle/crypto/tls/SecurityParameters;->getClientRandom()[B
move-result-object v1
invoke-virtual {v2}, Lorg/spongycastle/crypto/tls/SecurityParameters;->getServerRandom()[B
move-result-object v3
.line 118
array-length v0, v1
array-length v4, v3
add-int/2addr v0, v4
.line 119
if-eqz p2, :cond_27
.line 121
array-length v4, p2
add-int/lit8 v4, v4, 0x2
add-int/2addr v0, v4
.line 124
:cond_27
new-array v4, v0, [B
.line 127
array-length v5, v1
invoke-static {v1, v6, v4, v6, v5}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 128
array-length v1, v1
add-int/lit8 v1, v1, 0x0
.line 129
array-length v5, v3
invoke-static {v3, v6, v4, v1, v5}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 130
array-length v3, v3
add-int/2addr v1, v3
.line 131
if-eqz p2, :cond_44
.line 133
array-length v3, p2
invoke-static {v3, v4, v1}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeUint16(I[BI)V
.line 134
add-int/lit8 v1, v1, 0x2
.line 135
array-length v3, p2
invoke-static {p2, v6, v4, v1, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 136
array-length v3, p2
add-int/2addr v1, v3
.line 139
:cond_44
if-eq v1, v0, :cond_4e
.line 141
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "error in calculation of seed for export"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 144
:cond_4e
invoke-virtual {v2}, Lorg/spongycastle/crypto/tls/SecurityParameters;->getMasterSecret()[B
move-result-object v0
invoke-static {p0, v0, p1, v4, p3}, Lorg/spongycastle/crypto/tls/TlsUtils;->PRF(Lorg/spongycastle/crypto/tls/TlsContext;[BLjava/lang/String;[BI)[B
move-result-object v0
return-object v0
.end method
.method public getClientVersion()Lorg/spongycastle/crypto/tls/ProtocolVersion;
.registers 2
.prologue
.line 61
iget-object v0, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->clientVersion:Lorg/spongycastle/crypto/tls/ProtocolVersion;
return-object v0
.end method
.method public getNonceRandomGenerator()Lorg/spongycastle/crypto/prng/RandomGenerator;
.registers 2
.prologue
.line 46
iget-object v0, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->nonceRandom:Lorg/spongycastle/crypto/prng/RandomGenerator;
return-object v0
.end method
.method public getResumableSession()Lorg/spongycastle/crypto/tls/TlsSession;
.registers 2
.prologue
.line 81
iget-object v0, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->session:Lorg/spongycastle/crypto/tls/TlsSession;
return-object v0
.end method
.method public getSecureRandom()Ljava/security/SecureRandom;
.registers 2
.prologue
.line 51
iget-object v0, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->secureRandom:Ljava/security/SecureRandom;
return-object v0
.end method
.method public getSecurityParameters()Lorg/spongycastle/crypto/tls/SecurityParameters;
.registers 2
.prologue
.line 56
iget-object v0, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->securityParameters:Lorg/spongycastle/crypto/tls/SecurityParameters;
return-object v0
.end method
.method public getServerVersion()Lorg/spongycastle/crypto/tls/ProtocolVersion;
.registers 2
.prologue
.line 71
iget-object v0, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->serverVersion:Lorg/spongycastle/crypto/tls/ProtocolVersion;
return-object v0
.end method
.method public getUserObject()Ljava/lang/Object;
.registers 2
.prologue
.line 91
iget-object v0, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->userObject:Ljava/lang/Object;
return-object v0
.end method
.method setClientVersion(Lorg/spongycastle/crypto/tls/ProtocolVersion;)V
.registers 2
.prologue
.line 66
iput-object p1, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->clientVersion:Lorg/spongycastle/crypto/tls/ProtocolVersion;
.line 67
return-void
.end method
.method setResumableSession(Lorg/spongycastle/crypto/tls/TlsSession;)V
.registers 2
.prologue
.line 86
iput-object p1, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->session:Lorg/spongycastle/crypto/tls/TlsSession;
.line 87
return-void
.end method
.method setServerVersion(Lorg/spongycastle/crypto/tls/ProtocolVersion;)V
.registers 2
.prologue
.line 76
iput-object p1, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->serverVersion:Lorg/spongycastle/crypto/tls/ProtocolVersion;
.line 77
return-void
.end method
.method public setUserObject(Ljava/lang/Object;)V
.registers 2
.prologue
.line 96
iput-object p1, p0, Lorg/spongycastle/crypto/tls/AbstractTlsContext;->userObject:Ljava/lang/Object;
.line 97
return-void
.end method