CryptLib.smali
.class final Lcom/razorpay/CryptLib;
.super Ljava/lang/Object;
.source "CryptLib.java"
# instance fields
.field private a:Ljavax/crypto/Cipher;
.field private b:[B
.field private c:[B
# direct methods
.method constructor <init>()V
.registers 2
.line 58
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const-string v0, "AES/GCM/NoPadding"
.line 60
invoke-static {v0}, Ljavax/crypto/Cipher;->getInstance(Ljava/lang/String;)Ljavax/crypto/Cipher;
move-result-object v0
iput-object v0, p0, Lcom/razorpay/CryptLib;->a:Ljavax/crypto/Cipher;
const/16 v0, 0x20
new-array v0, v0, [B
.line 61
iput-object v0, p0, Lcom/razorpay/CryptLib;->b:[B
const/16 v0, 0x10
new-array v0, v0, [B
.line 62
iput-object v0, p0, Lcom/razorpay/CryptLib;->c:[B
return-void
.end method
.method private a(Ljava/lang/String;Ljava/lang/String;Lcom/razorpay/CryptLib$EncryptMode;Ljava/lang/String;)Ljava/lang/String;
.registers 11
const-string v0, "UTF-8"
.line 122
invoke-virtual {p2, v0}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
move-result-object v1
array-length v1, v1
.line 124
invoke-virtual {p2, v0}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
move-result-object v2
array-length v2, v2
iget-object v3, p0, Lcom/razorpay/CryptLib;->b:[B
array-length v4, v3
if-le v2, v4, :cond_12
.line 125
array-length v1, v3
.line 127
:cond_12
invoke-virtual {p4, v0}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
move-result-object v2
array-length v2, v2
.line 129
invoke-virtual {p4, v0}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
move-result-object v3
array-length v3, v3
iget-object v4, p0, Lcom/razorpay/CryptLib;->c:[B
array-length v5, v4
if-le v3, v5, :cond_22
.line 130
array-length v2, v4
.line 132
:cond_22
invoke-virtual {p2, v0}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
move-result-object p2
iget-object v3, p0, Lcom/razorpay/CryptLib;->b:[B
const/4 v4, 0x0
invoke-static {p2, v4, v3, v4, v1}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 133
invoke-virtual {p4, v0}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
move-result-object p2
iget-object p4, p0, Lcom/razorpay/CryptLib;->c:[B
invoke-static {p2, v4, p4, v4, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 137
new-instance p2, Ljavax/crypto/spec/SecretKeySpec;
iget-object p4, p0, Lcom/razorpay/CryptLib;->b:[B
const-string v1, "AES"
invoke-direct {p2, p4, v1}, Ljavax/crypto/spec/SecretKeySpec;-><init>([BLjava/lang/String;)V
.line 144
new-instance p4, Ljavax/crypto/spec/IvParameterSpec;
iget-object v1, p0, Lcom/razorpay/CryptLib;->c:[B
invoke-direct {p4, v1}, Ljavax/crypto/spec/IvParameterSpec;-><init>([B)V
.line 154
sget-object v1, Lcom/razorpay/CryptLib$EncryptMode;->ENCRYPT:Lcom/razorpay/CryptLib$EncryptMode;
invoke-virtual {p3, v1}, Lcom/razorpay/CryptLib$EncryptMode;->equals(Ljava/lang/Object;)Z
move-result v1
const/4 v2, 0x2
if-eqz v1, :cond_63
.line 159
iget-object v1, p0, Lcom/razorpay/CryptLib;->a:Ljavax/crypto/Cipher;
const/4 v3, 0x1
invoke-virtual {v1, v3, p2, p4}, Ljavax/crypto/Cipher;->init(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V
.line 160
iget-object v1, p0, Lcom/razorpay/CryptLib;->a:Ljavax/crypto/Cipher;
invoke-virtual {p1, v0}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
move-result-object v0
invoke-virtual {v1, v0}, Ljavax/crypto/Cipher;->doFinal([B)[B
move-result-object v0
.line 164
invoke-static {v0, v2}, Landroid/util/Base64;->encodeToString([BI)Ljava/lang/String;
move-result-object v0
goto :goto_65
:cond_63
const-string v0, ""
.line 170
:goto_65
sget-object v1, Lcom/razorpay/CryptLib$EncryptMode;->DECRYPT:Lcom/razorpay/CryptLib$EncryptMode;
invoke-virtual {p3, v1}, Lcom/razorpay/CryptLib$EncryptMode;->equals(Ljava/lang/Object;)Z
move-result p3
if-eqz p3, :cond_8a
:try_start_6d
const-string p3, "AES/CBC/NoPadding"
.line 172
invoke-static {p3}, Ljavax/crypto/Cipher;->getInstance(Ljava/lang/String;)Ljavax/crypto/Cipher;
move-result-object p3
iput-object p3, p0, Lcom/razorpay/CryptLib;->a:Ljavax/crypto/Cipher;
.line 173
invoke-virtual {p3, v2, p2, p4}, Ljavax/crypto/Cipher;->init(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V
.line 174
invoke-static {p1, v4}, Landroid/util/Base64;->decode(Ljava/lang/String;I)[B
move-result-object p1
.line 175
iget-object p2, p0, Lcom/razorpay/CryptLib;->a:Ljavax/crypto/Cipher;
invoke-virtual {p2, p1}, Ljavax/crypto/Cipher;->doFinal([B)[B
move-result-object p1
.line 176
new-instance p2, Ljava/lang/String;
sget-object p3, Ljava/nio/charset/StandardCharsets;->UTF_8:Ljava/nio/charset/Charset;
invoke-direct {p2, p1, p3}, Ljava/lang/String;-><init>([BLjava/nio/charset/Charset;)V
:try_end_89
.catch Ljava/lang/Exception; {:try_start_6d .. :try_end_89} :catch_8a
move-object v0, p2
:catch_8a
:cond_8a
return-object v0
.end method
# virtual methods
.method final a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
.registers 5
.line 242
sget-object v0, Lcom/razorpay/CryptLib$EncryptMode;->ENCRYPT:Lcom/razorpay/CryptLib$EncryptMode;
invoke-direct {p0, p1, p2, v0, p3}, Lcom/razorpay/CryptLib;->a(Ljava/lang/String;Ljava/lang/String;Lcom/razorpay/CryptLib$EncryptMode;Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
return-object p1
.end method
.method final b(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
.registers 5
.line 268
sget-object v0, Lcom/razorpay/CryptLib$EncryptMode;->DECRYPT:Lcom/razorpay/CryptLib$EncryptMode;
invoke-direct {p0, p1, p2, v0, p3}, Lcom/razorpay/CryptLib;->a(Ljava/lang/String;Ljava/lang/String;Lcom/razorpay/CryptLib$EncryptMode;Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
return-object p1
.end method