DefaultTlsEncryptionCredentials.smali
.class public Lorg/spongycastle/crypto/tls/DefaultTlsEncryptionCredentials;
.super Lorg/spongycastle/crypto/tls/AbstractTlsEncryptionCredentials;
.source "DefaultTlsEncryptionCredentials.java"
# instance fields
.field protected certificate:Lorg/spongycastle/crypto/tls/Certificate;
.field protected context:Lorg/spongycastle/crypto/tls/TlsContext;
.field protected privateKey:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
# direct methods
.method public constructor <init>(Lorg/spongycastle/crypto/tls/TlsContext;Lorg/spongycastle/crypto/tls/Certificate;Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;)V
.registers 7
.prologue
.line 16
invoke-direct {p0}, Lorg/spongycastle/crypto/tls/AbstractTlsEncryptionCredentials;-><init>()V
.line 17
if-nez p2, :cond_d
.line 19
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 21
:cond_d
invoke-virtual {p2}, Lorg/spongycastle/crypto/tls/Certificate;->isEmpty()Z
move-result v0
if-eqz v0, :cond_1b
.line 23
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 25
:cond_1b
if-nez p3, :cond_25
.line 27
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 29
:cond_25
invoke-virtual {p3}, Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;->isPrivate()Z
move-result v0
if-nez v0, :cond_33
.line 31
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 34
:cond_33
instance-of v0, p3, Lorg/spongycastle/crypto/params/RSAKeyParameters;
if-nez v0, :cond_54
.line 39
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 40
invoke-virtual {p3}, 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
.line 43
:cond_54
iput-object p1, p0, Lorg/spongycastle/crypto/tls/DefaultTlsEncryptionCredentials;->context:Lorg/spongycastle/crypto/tls/TlsContext;
.line 44
iput-object p2, p0, Lorg/spongycastle/crypto/tls/DefaultTlsEncryptionCredentials;->certificate:Lorg/spongycastle/crypto/tls/Certificate;
.line 45
iput-object p3, p0, Lorg/spongycastle/crypto/tls/DefaultTlsEncryptionCredentials;->privateKey:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
.line 46
return-void
.end method
# virtual methods
.method public decryptPreMasterSecret([B)[B
.registers 4
.prologue
.line 56
iget-object v1, p0, Lorg/spongycastle/crypto/tls/DefaultTlsEncryptionCredentials;->context:Lorg/spongycastle/crypto/tls/TlsContext;
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DefaultTlsEncryptionCredentials;->privateKey:Lorg/spongycastle/crypto/params/AsymmetricKeyParameter;
check-cast v0, Lorg/spongycastle/crypto/params/RSAKeyParameters;
invoke-static {v1, v0, p1}, Lorg/spongycastle/crypto/tls/TlsRSAUtils;->safeDecryptPreMasterSecret(Lorg/spongycastle/crypto/tls/TlsContext;Lorg/spongycastle/crypto/params/RSAKeyParameters;[B)[B
move-result-object v0
return-object v0
.end method
.method public getCertificate()Lorg/spongycastle/crypto/tls/Certificate;
.registers 2
.prologue
.line 50
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DefaultTlsEncryptionCredentials;->certificate:Lorg/spongycastle/crypto/tls/Certificate;
return-object v0
.end method