DefaultTlsAgreementCredentials.smali
.class public Lorg/spongycastle/crypto/tls/DefaultTlsAgreementCredentials;
.super Lorg/spongycastle/crypto/tls/AbstractTlsAgreementCredentials;
.source "DefaultTlsAgreementCredentials.java"
# instance fields
.field protected basicAgreement:Lorg/spongycastle/crypto/BasicAgreement;
.field protected certificate:Lorg/spongycastle/crypto/tls/Certificate;
.field protected privateKey:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
.field protected truncateAgreement:Z
# direct methods
.method public constructor <init>(Lorg/spongycastle/crypto/tls/Certificate;Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;)V
.registers 6
.prologue
.line 23
invoke-direct {p0}, Lorg/spongycastle/crypto/tls/AbstractTlsAgreementCredentials;-><init>()V
.line 24
if-nez p1, :cond_d
.line 26
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "\'certificate\' cannot be null"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 28
:cond_d
invoke-virtual {p1}, Lorg/spongycastle/crypto/tls/Certificate;->isEmpty()Z
move-result v0
if-eqz v0, :cond_1b
.line 30
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "\'certificate\' cannot be empty"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 32
:cond_1b
if-nez p2, :cond_25
.line 34
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "\'privateKey\' cannot be null"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 36
:cond_25
invoke-virtual {p2}, Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;->isPrivate()Z
move-result v0
if-nez v0, :cond_33
.line 38
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "\'privateKey\' must be private"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 41
:cond_33
instance-of v0, p2, Lorg/spongycastle/crypto/params/DHPrivateKeyParameters;
if-eqz v0, :cond_46
.line 43
new-instance v0, Lorg/spongycastle/crypto/agreement/DHBasicAgreement;
invoke-direct {v0}, Lorg/spongycastle/crypto/agreement/DHBasicAgreement;-><init>()V
iput-object v0, p0, Lorg/spongycastle/crypto/tls/DefaultTlsAgreementCredentials;->basicAgreement:Lorg/spongycastle/crypto/BasicAgreement;
.line 44
const/4 v0, 0x1
iput-boolean v0, p0, Lorg/spongycastle/crypto/tls/DefaultTlsAgreementCredentials;->truncateAgreement:Z
.line 57
:goto_41
iput-object p1, p0, Lorg/spongycastle/crypto/tls/DefaultTlsAgreementCredentials;->certificate:Lorg/spongycastle/crypto/tls/Certificate;
.line 58
iput-object p2, p0, Lorg/spongycastle/crypto/tls/DefaultTlsAgreementCredentials;->privateKey:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
.line 59
return-void
.line 46
:cond_46
instance-of v0, p2, Lorg/spongycastle/crypto/params/ECPrivateKeyParameters;
if-eqz v0, :cond_55
.line 48
new-instance v0, Lorg/spongycastle/crypto/agreement/ECDHBasicAgreement;
invoke-direct {v0}, Lorg/spongycastle/crypto/agreement/ECDHBasicAgreement;-><init>()V
iput-object v0, p0, Lorg/spongycastle/crypto/tls/DefaultTlsAgreementCredentials;->basicAgreement:Lorg/spongycastle/crypto/BasicAgreement;
.line 49
const/4 v0, 0x0
iput-boolean v0, p0, Lorg/spongycastle/crypto/tls/DefaultTlsAgreementCredentials;->truncateAgreement:Z
goto :goto_41
.line 53
:cond_55
new-instance v0, Ljava/lang/IllegalArgumentException;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "\'privateKey\' type not supported: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 54
invoke-virtual {p2}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.end method
# virtual methods
.method public generateAgreement(Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;)[B
.registers 4
.prologue
.line 68
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DefaultTlsAgreementCredentials;->basicAgreement:Lorg/spongycastle/crypto/BasicAgreement;
iget-object v1, p0, Lorg/spongycastle/crypto/tls/DefaultTlsAgreementCredentials;->privateKey:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
invoke-interface {v0, v1}, Lorg/spongycastle/crypto/BasicAgreement;->init(Lorg/spongycastle/crypto/CipherParameters;)V
.line 69
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DefaultTlsAgreementCredentials;->basicAgreement:Lorg/spongycastle/crypto/BasicAgreement;
invoke-interface {v0, p1}, Lorg/spongycastle/crypto/BasicAgreement;->calculateAgreement(Lorg/spongycastle/crypto/CipherParameters;)Ljava/math/BigInteger;
move-result-object v0
.line 71
iget-boolean v1, p0, Lorg/spongycastle/crypto/tls/DefaultTlsAgreementCredentials;->truncateAgreement:Z
if-eqz v1, :cond_16
.line 73
invoke-static {v0}, Lorg/spongycastle/util/BigIntegers;->asUnsignedByteArray(Ljava/math/BigInteger;)[B
move-result-object v0
.line 76
:goto_15
return-object v0
:cond_16
iget-object v1, p0, Lorg/spongycastle/crypto/tls/DefaultTlsAgreementCredentials;->basicAgreement:Lorg/spongycastle/crypto/BasicAgreement;
invoke-interface {v1}, Lorg/spongycastle/crypto/BasicAgreement;->getFieldSize()I
move-result v1
invoke-static {v1, v0}, Lorg/spongycastle/util/BigIntegers;->asUnsignedByteArray(ILjava/math/BigInteger;)[B
move-result-object v0
goto :goto_15
.end method
.method public getCertificate()Lorg/spongycastle/crypto/tls/Certificate;
.registers 2
.prologue
.line 63
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DefaultTlsAgreementCredentials;->certificate:Lorg/spongycastle/crypto/tls/Certificate;
return-object v0
.end method