FFLV2ClientImpl.smali
.class public Lcom/avast/android/ffl/v2/FFLV2ClientImpl;
.super Lcom/avast/android/ffl/AbstractFFLClient;
# interfaces
.implements Lcom/avast/android/ffl/v2/FFLV2Client;
# instance fields
.field private final d:Lcom/avast/android/ffl/v2/AuthStorage;
.field private final e:Ljava/util/concurrent/atomic/AtomicReference;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/concurrent/atomic/AtomicReference<",
"Lcom/avast/android/ffl/v2/AuthClock;",
">;"
}
.end annotation
.end field
.field private final f:Lcom/avast/ffl/auth/proto/AuthProto$Identity;
.field private final g:Z
# direct methods
.method public constructor <init>(Lretrofit/client/Client;Lcom/avast/android/ffl/LoggingProvider;Lcom/avast/android/ffl/v2/AuthStorage;Lcom/avast/ffl/auth/proto/AuthProto$Identity;Ljava/lang/String;)V
.registers 13
const/4 v6, 0x0
move-object v0, p0
move-object v1, p1
move-object v2, p2
move-object v3, p3
move-object v4, p4
move-object v5, p5
invoke-direct/range {v0 .. v6}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;-><init>(Lretrofit/client/Client;Lcom/avast/android/ffl/LoggingProvider;Lcom/avast/android/ffl/v2/AuthStorage;Lcom/avast/ffl/auth/proto/AuthProto$Identity;Ljava/lang/String;Z)V
return-void
.end method
.method public constructor <init>(Lretrofit/client/Client;Lcom/avast/android/ffl/LoggingProvider;Lcom/avast/android/ffl/v2/AuthStorage;Lcom/avast/ffl/auth/proto/AuthProto$Identity;Ljava/lang/String;Z)V
.registers 7
invoke-direct {p0, p1, p2, p5}, Lcom/avast/android/ffl/AbstractFFLClient;-><init>(Lretrofit/client/Client;Lcom/avast/android/ffl/LoggingProvider;Ljava/lang/String;)V
new-instance p1, Ljava/util/concurrent/atomic/AtomicReference;
invoke-direct {p1}, Ljava/util/concurrent/atomic/AtomicReference;-><init>()V
iput-object p1, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->e:Ljava/util/concurrent/atomic/AtomicReference;
iput-object p3, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->d:Lcom/avast/android/ffl/v2/AuthStorage;
iput-object p4, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->f:Lcom/avast/ffl/auth/proto/AuthProto$Identity;
iput-boolean p6, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->g:Z
return-void
.end method
.method private g(Ljava/lang/String;)[B
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/UnsupportedEncodingException;
}
.end annotation
invoke-direct {p0, p1}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->h(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
const-string v0, "UTF-8"
invoke-virtual {p1, v0}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
move-result-object p1
invoke-static {p1}, Lorg/apache/commons/codec/binary/Base64;->decodeBase64([B)[B
move-result-object p1
return-object p1
.end method
.method private h(Ljava/lang/String;)Ljava/lang/String;
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/UnsupportedEncodingException;
}
.end annotation
const-string v0, "UTF-8"
invoke-static {p1, v0}, Ljava/net/URLDecoder;->decode(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
return-object p1
.end method
.method private i([B)Ljava/lang/String;
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/UnsupportedEncodingException;
}
.end annotation
new-instance v0, Ljava/lang/String;
invoke-static {p1}, Lorg/apache/commons/codec/binary/Base64;->encodeBase64([B)[B
move-result-object p1
const-string v1, "UTF-8"
invoke-direct {v0, p1, v1}, Ljava/lang/String;-><init>([BLjava/lang/String;)V
invoke-direct {p0, v0}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->j(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
return-object p1
.end method
.method private j(Ljava/lang/String;)Ljava/lang/String;
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/UnsupportedEncodingException;
}
.end annotation
const-string v0, "UTF-8"
invoke-static {p1, v0}, Ljava/net/URLEncoder;->encode(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
return-object p1
.end method
.method private k(Lretrofit/client/Request;Lcom/avast/android/ffl/v2/ClientKey;)Lretrofit/client/Response;
.registers 9
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
:try_start_0
invoke-direct {p0}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->s()J
move-result-wide v0
invoke-direct {p0, p1, p2, v0, v1}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->l(Lretrofit/client/Request;Lcom/avast/android/ffl/v2/ClientKey;J)Lretrofit/client/Response;
move-result-object p1
:try_end_8
.catch Lcom/avast/android/ffl/v2/InvalidRequestTimeException; {:try_start_0 .. :try_end_8} :catch_9
return-object p1
:catch_9
move-exception v0
iget-object v1, p0, Lcom/avast/android/ffl/AbstractFFLClient;->a:Lcom/avast/android/ffl/LoggingProvider;
const/4 v2, 0x1
new-array v2, v2, [Ljava/lang/Object;
const/4 v3, 0x0
invoke-virtual {v0}, Lcom/avast/android/ffl/v2/InvalidRequestTimeException;->a()J
move-result-wide v4
invoke-static {v4, v5}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v4
aput-object v4, v2, v3
const-string v3, "Server rejected request due to invalid time. Updating offset to server time ($s)"
invoke-interface {v1, v3, v2}, Lcom/avast/android/ffl/LoggingProvider;->c(Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v0}, Lcom/avast/android/ffl/v2/InvalidRequestTimeException;->a()J
move-result-wide v0
invoke-direct {p0, v0, v1}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->y(J)V
invoke-direct {p0}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->s()J
move-result-wide v0
invoke-direct {p0, p1, p2, v0, v1}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->l(Lretrofit/client/Request;Lcom/avast/android/ffl/v2/ClientKey;J)Lretrofit/client/Response;
move-result-object p1
return-object p1
.end method
.method private l(Lretrofit/client/Request;Lcom/avast/android/ffl/v2/ClientKey;J)Lretrofit/client/Response;
.registers 14
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
:try_start_0
invoke-virtual {p1}, Lretrofit/client/Request;->getBody()Lretrofit/mime/TypedOutput;
move-result-object v0
new-instance v1, Ljava/util/ArrayList;
invoke-virtual {p1}, Lretrofit/client/Request;->getHeaders()Ljava/util/List;
move-result-object v2
invoke-direct {v1, v2}, Ljava/util/ArrayList;-><init>(Ljava/util/Collection;)V
invoke-direct {p0}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->p()Lcom/avast/android/ffl/v2/ClientIdentity;
move-result-object v2
invoke-virtual {v2}, Lcom/avast/android/ffl/v2/ClientIdentity;->a()Ljava/lang/String;
move-result-object v2
invoke-static {}, Lcom/avast/crypto/SymKeyUtility;->d()[B
move-result-object v3
invoke-virtual {p2}, Lcom/avast/android/ffl/v2/ClientKey;->c()Lcom/google/protobuf/ByteString;
move-result-object v4
invoke-virtual {v4}, Lcom/google/protobuf/ByteString;->r()[B
move-result-object v4
sget-object v5, Lcom/avast/crypto/FFLSpec;->g:Lcom/avast/crypto/FFLSpec;
invoke-virtual {v5}, Lcom/avast/crypto/FFLSpec;->j()Ljavax/crypto/Mac;
move-result-object v5
invoke-static {v3, v4, p3, p4, v5}, Lcom/avast/crypto/SymKeyUtility;->c([B[BJLjavax/crypto/Mac;)[B
move-result-object v4
const/4 v5, 0x0
if-eqz v0, :cond_40
new-instance v6, Ljava/io/ByteArrayOutputStream;
invoke-interface {v0}, Lretrofit/mime/TypedOutput;->length()J
move-result-wide v7
long-to-int v8, v7
invoke-direct {v6, v8}, Ljava/io/ByteArrayOutputStream;-><init>(I)V
invoke-interface {v0, v6}, Lretrofit/mime/TypedOutput;->writeTo(Ljava/io/OutputStream;)V
invoke-virtual {v6}, Ljava/io/ByteArrayOutputStream;->toByteArray()[B
move-result-object v6
goto :goto_42
:cond_40
new-array v6, v5, [B
:goto_42
if-eqz v6, :cond_52
array-length v7, v6
if-lez v7, :cond_52
sget-object v7, Lcom/avast/crypto/FFLSpec;->g:Lcom/avast/crypto/FFLSpec;
invoke-virtual {v7}, Lcom/avast/crypto/FFLSpec;->f()Lcom/avast/crypto/CryptoHelper;
move-result-object v7
invoke-virtual {v7, v6, v3}, Lcom/avast/crypto/CryptoHelper;->c([B[B)[B
move-result-object v3
goto :goto_54
:cond_52
new-array v3, v5, [B
:goto_54
new-instance v6, Lretrofit/client/Header;
const-string v7, "Content-Encoding"
const-string v8, "x-ffl"
invoke-direct {v6, v7, v8}, Lretrofit/client/Header;-><init>(Ljava/lang/String;Ljava/lang/String;)V
invoke-interface {v1, v6}, Ljava/util/List;->add(Ljava/lang/Object;)Z
new-instance v6, Lretrofit/client/Header;
const-string v7, "X-AVAST-FFL-Version"
const-string v8, "2"
invoke-direct {v6, v7, v8}, Lretrofit/client/Header;-><init>(Ljava/lang/String;Ljava/lang/String;)V
invoke-interface {v1, v6}, Ljava/util/List;->add(Ljava/lang/Object;)Z
new-instance v6, Lretrofit/client/Header;
const-string v7, "X-AVAST-FFL-Mode"
const-string v8, "SFSR"
invoke-direct {v6, v7, v8}, Lretrofit/client/Header;-><init>(Ljava/lang/String;Ljava/lang/String;)V
invoke-interface {v1, v6}, Ljava/util/List;->add(Ljava/lang/Object;)Z
new-instance v6, Lretrofit/client/Header;
const-string v7, "X-AVAST-Request-Time"
invoke-static {p3, p4}, Ljava/lang/Long;->toString(J)Ljava/lang/String;
move-result-object v8
invoke-direct {v6, v7, v8}, Lretrofit/client/Header;-><init>(Ljava/lang/String;Ljava/lang/String;)V
invoke-interface {v1, v6}, Ljava/util/List;->add(Ljava/lang/Object;)Z
new-instance v6, Lretrofit/client/Header;
const-string v7, "X-AVAST-Client-Id-0"
invoke-direct {p0, v2}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->j(Ljava/lang/String;)Ljava/lang/String;
move-result-object v2
invoke-direct {v6, v7, v2}, Lretrofit/client/Header;-><init>(Ljava/lang/String;Ljava/lang/String;)V
invoke-interface {v1, v6}, Ljava/util/List;->add(Ljava/lang/Object;)Z
new-instance v2, Lretrofit/client/Header;
const-string v6, "X-AVAST-Key-Id-0"
invoke-virtual {p2}, Lcom/avast/android/ffl/v2/ClientKey;->b()Lcom/google/protobuf/ByteString;
move-result-object v7
invoke-virtual {v7}, Lcom/google/protobuf/ByteString;->r()[B
move-result-object v7
invoke-direct {p0, v7}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->i([B)Ljava/lang/String;
move-result-object v7
invoke-direct {v2, v6, v7}, Lretrofit/client/Header;-><init>(Ljava/lang/String;Ljava/lang/String;)V
invoke-interface {v1, v2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
new-instance v2, Lretrofit/client/Header;
const-string v6, "X-AVAST-ETEK-0"
invoke-direct {p0, v4}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->i([B)Ljava/lang/String;
move-result-object v4
invoke-direct {v2, v6, v4}, Lretrofit/client/Header;-><init>(Ljava/lang/String;Ljava/lang/String;)V
invoke-interface {v1, v2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
new-instance v2, Lretrofit/client/Request;
invoke-virtual {p1}, Lretrofit/client/Request;->getMethod()Ljava/lang/String;
move-result-object v4
invoke-virtual {p1}, Lretrofit/client/Request;->getUrl()Ljava/lang/String;
move-result-object p1
if-eqz v0, :cond_ca
new-instance v6, Lcom/avast/android/ffl/v2/FFLV2ClientImpl$2;
invoke-direct {v6, p0, v0, v3}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl$2;-><init>(Lcom/avast/android/ffl/v2/FFLV2ClientImpl;Lretrofit/mime/TypedOutput;[B)V
goto :goto_cb
:cond_ca
const/4 v6, 0x0
:goto_cb
invoke-direct {v2, v4, p1, v1, v6}, Lretrofit/client/Request;-><init>(Ljava/lang/String;Ljava/lang/String;Ljava/util/List;Lretrofit/mime/TypedOutput;)V
iget-object p1, p0, Lcom/avast/android/ffl/AbstractFFLClient;->b:Lretrofit/client/Client;
invoke-interface {p1, v2}, Lretrofit/client/Client;->execute(Lretrofit/client/Request;)Lretrofit/client/Response;
move-result-object p1
invoke-virtual {p1}, Lretrofit/client/Response;->getBody()Lretrofit/mime/TypedInput;
move-result-object v0
if-eqz v0, :cond_df
invoke-interface {v0}, Lretrofit/mime/TypedInput;->length()J
move-result-wide v1
goto :goto_e1
:cond_df
const-wide/16 v1, 0x0
:goto_e1
iget-object v3, p0, Lcom/avast/android/ffl/AbstractFFLClient;->a:Lcom/avast/android/ffl/LoggingProvider;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v6, "Received response with status "
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Lretrofit/client/Response;->getStatus()I
move-result v6
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v6, "("
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Lretrofit/client/Response;->getReason()Ljava/lang/String;
move-result-object v6
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v6, ") and payload size "
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v1, v2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
new-array v2, v5, [Ljava/lang/Object;
invoke-interface {v3, v1, v2}, Lcom/avast/android/ffl/LoggingProvider;->b(Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {p1}, Lretrofit/client/Response;->getStatus()I
move-result v1
const/16 v2, 0x1ba
if-eq v1, v2, :cond_174
invoke-direct {p0, p1}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->n(Lretrofit/client/Response;)[B
move-result-object v1
invoke-virtual {p2}, Lcom/avast/android/ffl/v2/ClientKey;->c()Lcom/google/protobuf/ByteString;
move-result-object p2
invoke-virtual {p2}, Lcom/google/protobuf/ByteString;->r()[B
move-result-object p2
sget-object v2, Lcom/avast/crypto/FFLSpec;->g:Lcom/avast/crypto/FFLSpec;
invoke-virtual {v2}, Lcom/avast/crypto/FFLSpec;->j()Ljavax/crypto/Mac;
move-result-object v2
invoke-static {v1, p2, p3, p4, v2}, Lcom/avast/crypto/SymKeyUtility;->a([B[BJLjavax/crypto/Mac;)[B
move-result-object p2
if-eqz v0, :cond_144
sget-object p3, Lcom/avast/crypto/FFLSpec;->g:Lcom/avast/crypto/FFLSpec;
invoke-virtual {p3}, Lcom/avast/crypto/FFLSpec;->f()Lcom/avast/crypto/CryptoHelper;
move-result-object p3
invoke-interface {v0}, Lretrofit/mime/TypedInput;->in()Ljava/io/InputStream;
move-result-object p4
invoke-static {p4}, Lcom/avast/android/ffl/AbstractFFLClient;->f(Ljava/io/InputStream;)[B
move-result-object p4
invoke-virtual {p3, p4, p2}, Lcom/avast/crypto/CryptoHelper;->b([B[B)[B
move-result-object p2
goto :goto_146
:cond_144
new-array p2, v5, [B
:goto_146
invoke-virtual {p1}, Lretrofit/client/Response;->getStatus()I
move-result p3
const/16 p4, 0x1bb
if-eq p3, p4, :cond_16a
new-instance p3, Lretrofit/client/Response;
invoke-virtual {p1}, Lretrofit/client/Response;->getUrl()Ljava/lang/String;
move-result-object v2
invoke-virtual {p1}, Lretrofit/client/Response;->getStatus()I
move-result v3
invoke-virtual {p1}, Lretrofit/client/Response;->getReason()Ljava/lang/String;
move-result-object v4
invoke-virtual {p1}, Lretrofit/client/Response;->getHeaders()Ljava/util/List;
move-result-object v5
new-instance v6, Lcom/avast/android/ffl/v2/FFLV2ClientImpl$3;
invoke-direct {v6, p0, v0, p2}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl$3;-><init>(Lcom/avast/android/ffl/v2/FFLV2ClientImpl;Lretrofit/mime/TypedInput;[B)V
move-object v1, p3
invoke-direct/range {v1 .. v6}, Lretrofit/client/Response;-><init>(Ljava/lang/String;ILjava/lang/String;Ljava/util/List;Lretrofit/mime/TypedInput;)V
return-object p3
:cond_16a
invoke-direct {p0, p2}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->o([B)J
move-result-wide p1
new-instance p3, Lcom/avast/android/ffl/v2/InvalidRequestTimeException;
invoke-direct {p3, p1, p2}, Lcom/avast/android/ffl/v2/InvalidRequestTimeException;-><init>(J)V
throw p3
:cond_174
new-instance p1, Lcom/avast/android/ffl/KeyExpiredException;
const-string p2, "Status code 442 from server"
invoke-direct {p1, p2}, Lcom/avast/android/ffl/KeyExpiredException;-><init>(Ljava/lang/String;)V
throw p1
:try_end_17c
.catch Lcom/avast/crypto/KeyUtilityException; {:try_start_0 .. :try_end_17c} :catch_182
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_0 .. :try_end_17c} :catch_180
.catch Ljava/security/InvalidKeyException; {:try_start_0 .. :try_end_17c} :catch_17e
.catch Lcom/avast/crypto/PayloadException; {:try_start_0 .. :try_end_17c} :catch_17c
:catch_17c
move-exception p1
goto :goto_183
:catch_17e
move-exception p1
goto :goto_183
:catch_180
move-exception p1
goto :goto_183
:catch_182
move-exception p1
:goto_183
new-instance p2, Lcom/avast/android/ffl/EncryptionException;
invoke-direct {p2, p1}, Lcom/avast/android/ffl/EncryptionException;-><init>(Ljava/lang/Throwable;)V
throw p2
.end method
.method private m()Lcom/google/protobuf/ByteString;
.registers 3
new-instance v0, Ljava/security/SecureRandom;
invoke-direct {v0}, Ljava/security/SecureRandom;-><init>()V
const/16 v1, 0x20
new-array v1, v1, [B
invoke-virtual {v0, v1}, Ljava/security/SecureRandom;->nextBytes([B)V
invoke-static {v1}, Lcom/google/protobuf/ByteString;->c([B)Lcom/google/protobuf/ByteString;
move-result-object v0
return-object v0
.end method
.method private n(Lretrofit/client/Response;)[B
.registers 9
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/avast/android/ffl/EncryptionException;,
Ljava/io/UnsupportedEncodingException;,
Lcom/avast/android/ffl/NonFFLResponseException;
}
.end annotation
invoke-virtual {p1}, Lretrofit/client/Response;->getHeaders()Ljava/util/List;
move-result-object v0
invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v0
const/4 v1, 0x0
move-object v2, v1
move-object v3, v2
:cond_b
:goto_b
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v4
if-eqz v4, :cond_4a
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v4
check-cast v4, Lretrofit/client/Header;
invoke-virtual {v4}, Lretrofit/client/Header;->getName()Ljava/lang/String;
move-result-object v5
const-string v6, "X-AVAST-FFL-Version"
invoke-virtual {v6, v5}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v5
if-eqz v5, :cond_28
invoke-virtual {v4}, Lretrofit/client/Header;->getValue()Ljava/lang/String;
move-result-object v1
goto :goto_b
:cond_28
invoke-virtual {v4}, Lretrofit/client/Header;->getName()Ljava/lang/String;
move-result-object v5
const-string v6, "X-AVAST-FFL-Mode"
invoke-virtual {v6, v5}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v5
if-eqz v5, :cond_39
invoke-virtual {v4}, Lretrofit/client/Header;->getValue()Ljava/lang/String;
move-result-object v2
goto :goto_b
:cond_39
invoke-virtual {v4}, Lretrofit/client/Header;->getName()Ljava/lang/String;
move-result-object v5
const-string v6, "X-AVAST-ETEK-0"
invoke-virtual {v6, v5}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v5
if-eqz v5, :cond_b
invoke-virtual {v4}, Lretrofit/client/Header;->getValue()Ljava/lang/String;
move-result-object v3
goto :goto_b
:cond_4a
const-string v0, "2"
invoke-virtual {v0, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_93
const-string p1, "SFSR"
invoke-virtual {p1, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result p1
if-nez p1, :cond_84
const-string p1, "SFMR"
invoke-virtual {p1, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result p1
if-eqz p1, :cond_6d
iget-object p1, p0, Lcom/avast/android/ffl/AbstractFFLClient;->a:Lcom/avast/android/ffl/LoggingProvider;
const/4 v0, 0x0
new-array v0, v0, [Ljava/lang/Object;
const-string v1, "Ignoring all but the first recipient in SFMR mode"
invoke-interface {p1, v1, v0}, Lcom/avast/android/ffl/LoggingProvider;->a(Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_84
:cond_6d
new-instance p1, Lcom/avast/android/ffl/EncryptionException;
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "Invalid FFL mode in server response: "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {p1, v0}, Lcom/avast/android/ffl/EncryptionException;-><init>(Ljava/lang/String;)V
throw p1
:cond_84
:goto_84
if-eqz v3, :cond_8b
invoke-direct {p0, v3}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->g(Ljava/lang/String;)[B
move-result-object p1
return-object p1
:cond_8b
new-instance p1, Lcom/avast/android/ffl/EncryptionException;
const-string v0, "Missing ETEK in server response"
invoke-direct {p1, v0}, Lcom/avast/android/ffl/EncryptionException;-><init>(Ljava/lang/String;)V
throw p1
:cond_93
new-instance v0, Lcom/avast/android/ffl/NonFFLResponseException;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Invalid FFL version in server response: "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1, p1}, Lcom/avast/android/ffl/NonFFLResponseException;-><init>(Ljava/lang/String;Lretrofit/client/Response;)V
throw v0
.end method
.method private o([B)J
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
new-instance v0, Ljava/lang/String;
const-string v1, "UTF-8"
invoke-direct {v0, p1, v1}, Ljava/lang/String;-><init>([BLjava/lang/String;)V
:try_start_7
invoke-static {v0}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide v0
:try_end_b
.catch Ljava/lang/NumberFormatException; {:try_start_7 .. :try_end_b} :catch_c
return-wide v0
:catch_c
move-exception p1
new-instance v0, Lcom/avast/android/ffl/EncryptionException;
const-string v1, "Cannot parse server time from respnse"
invoke-direct {v0, p1, v1}, Lcom/avast/android/ffl/EncryptionException;-><init>(Ljava/lang/Throwable;Ljava/lang/String;)V
throw v0
.end method
.method private p()Lcom/avast/android/ffl/v2/ClientIdentity;
.registers 2
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
iget-boolean v0, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->g:Z
if-eqz v0, :cond_b
iget-object v0, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->d:Lcom/avast/android/ffl/v2/AuthStorage;
invoke-interface {v0}, Lcom/avast/android/ffl/v2/AuthStorage;->h()Lcom/avast/android/ffl/v2/ClientIdentity;
move-result-object v0
goto :goto_11
:cond_b
iget-object v0, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->d:Lcom/avast/android/ffl/v2/AuthStorage;
invoke-interface {v0}, Lcom/avast/android/ffl/v2/AuthStorage;->m()Lcom/avast/android/ffl/v2/ClientIdentity;
move-result-object v0
:goto_11
return-object v0
.end method
.method private q()Lcom/avast/android/ffl/v2/ClientKey;
.registers 2
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
iget-boolean v0, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->g:Z
if-eqz v0, :cond_b
iget-object v0, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->d:Lcom/avast/android/ffl/v2/AuthStorage;
invoke-interface {v0}, Lcom/avast/android/ffl/v2/AuthStorage;->i()Lcom/avast/android/ffl/v2/ClientKey;
move-result-object v0
goto :goto_11
:cond_b
iget-object v0, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->d:Lcom/avast/android/ffl/v2/AuthStorage;
invoke-interface {v0}, Lcom/avast/android/ffl/v2/AuthStorage;->g()Lcom/avast/android/ffl/v2/ClientKey;
move-result-object v0
:goto_11
return-object v0
.end method
.method private s()J
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
iget-object v0, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->e:Ljava/util/concurrent/atomic/AtomicReference;
invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicReference;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/avast/android/ffl/v2/AuthClock;
if-nez v0, :cond_1a
new-instance v0, Lcom/avast/android/ffl/v2/DefaultClock;
iget-object v1, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->d:Lcom/avast/android/ffl/v2/AuthStorage;
invoke-interface {v1}, Lcom/avast/android/ffl/v2/AuthStorage;->o()J
move-result-wide v1
invoke-direct {v0, v1, v2}, Lcom/avast/android/ffl/v2/DefaultClock;-><init>(J)V
iget-object v1, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->e:Ljava/util/concurrent/atomic/AtomicReference;
invoke-virtual {v1, v0}, Ljava/util/concurrent/atomic/AtomicReference;->set(Ljava/lang/Object;)V
:cond_1a
invoke-interface {v0}, Lcom/avast/android/ffl/v2/AuthClock;->a()J
move-result-wide v0
return-wide v0
.end method
.method private t(Lcom/avast/android/ffl/v2/ClientIdentity;)V
.registers 13
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
invoke-direct {p0}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->m()Lcom/google/protobuf/ByteString;
move-result-object v0
invoke-static {}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationRequest;->t()Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationRequest$Builder;
move-result-object v1
invoke-virtual {v1, v0}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationRequest$Builder;->s(Lcom/google/protobuf/ByteString;)Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationRequest$Builder;
iget-object v2, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->f:Lcom/avast/ffl/auth/proto/AuthProto$Identity;
invoke-virtual {v1, v2}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationRequest$Builder;->t(Lcom/avast/ffl/auth/proto/AuthProto$Identity;)Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationRequest$Builder;
if-eqz p1, :cond_27
invoke-static {}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationRequest$Parent;->r()Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationRequest$Parent$Builder;
move-result-object v2
invoke-virtual {p1}, Lcom/avast/android/ffl/v2/ClientIdentity;->a()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationRequest$Parent$Builder;->o(Ljava/lang/String;)Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationRequest$Parent$Builder;
invoke-virtual {p1}, Lcom/avast/android/ffl/v2/ClientIdentity;->b()Lcom/google/protobuf/ByteString;
move-result-object v3
invoke-virtual {v2, v3}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationRequest$Parent$Builder;->q(Lcom/google/protobuf/ByteString;)Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationRequest$Parent$Builder;
invoke-virtual {v1, v2}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationRequest$Builder;->u(Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationRequest$Parent$Builder;)Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationRequest$Builder;
:cond_27
invoke-virtual {v1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationRequest$Builder;->h()Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationRequest;
move-result-object v1
invoke-virtual {v1}, Lcom/google/protobuf/AbstractMessageLite;->d()[B
move-result-object v1
iget-object v2, p0, Lcom/avast/android/ffl/AbstractFFLClient;->b:Lretrofit/client/Client;
new-instance v3, Lretrofit/client/Request;
invoke-virtual {p0}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->u()Ljava/lang/String;
move-result-object v4
const/4 v5, 0x0
new-instance v6, Lcom/avast/android/ffl/v2/FFLV2ClientImpl$1;
invoke-direct {v6, p0, v1}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl$1;-><init>(Lcom/avast/android/ffl/v2/FFLV2ClientImpl;[B)V
const-string v1, "POST"
invoke-direct {v3, v1, v4, v5, v6}, Lretrofit/client/Request;-><init>(Ljava/lang/String;Ljava/lang/String;Ljava/util/List;Lretrofit/mime/TypedOutput;)V
invoke-interface {v2, v3}, Lretrofit/client/Client;->execute(Lretrofit/client/Request;)Lretrofit/client/Response;
move-result-object v1
invoke-virtual {v1}, Lretrofit/client/Response;->getStatus()I
move-result v2
const/16 v3, 0xc8
if-ne v2, v3, :cond_f5
:try_start_4e
invoke-virtual {v1}, Lretrofit/client/Response;->getBody()Lretrofit/mime/TypedInput;
move-result-object v1
invoke-interface {v1}, Lretrofit/mime/TypedInput;->in()Ljava/io/InputStream;
move-result-object v1
invoke-static {v1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationResponse;->parseFrom(Ljava/io/InputStream;)Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationResponse;
move-result-object v1
:try_end_5a
.catch Lcom/google/protobuf/InvalidProtocolBufferException; {:try_start_4e .. :try_end_5a} :catch_ec
invoke-static {}, Ljava/util/Calendar;->getInstance()Ljava/util/Calendar;
move-result-object v2
invoke-virtual {v1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationResponse;->k()J
move-result-wide v3
invoke-virtual {v2, v3, v4}, Ljava/util/Calendar;->setTimeInMillis(J)V
if-eqz p1, :cond_6a
const-string v3, "app"
goto :goto_6c
:cond_6a
const-string v3, "root"
:goto_6c
iget-object v4, p0, Lcom/avast/android/ffl/AbstractFFLClient;->a:Lcom/avast/android/ffl/LoggingProvider;
const/4 v5, 0x3
new-array v6, v5, [Ljava/lang/Object;
const/4 v7, 0x0
aput-object v3, v6, v7
invoke-virtual {v1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationResponse;->h()Ljava/lang/String;
move-result-object v3
const/4 v8, 0x1
aput-object v3, v6, v8
invoke-virtual {v0}, Lcom/google/protobuf/ByteString;->r()[B
move-result-object v3
invoke-static {v3}, Lcom/avast/android/ffl/Hex;->a([B)Ljava/lang/String;
move-result-object v3
const/4 v9, 0x2
aput-object v3, v6, v9
const-string v3, "Registered as %s Client ID %s with CIGT %s"
invoke-interface {v4, v3, v6}, Lcom/avast/android/ffl/LoggingProvider;->c(Ljava/lang/String;[Ljava/lang/Object;)V
iget-object v3, p0, Lcom/avast/android/ffl/AbstractFFLClient;->a:Lcom/avast/android/ffl/LoggingProvider;
new-array v4, v5, [Ljava/lang/Object;
invoke-virtual {v1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationResponse;->l()Lcom/google/protobuf/ByteString;
move-result-object v5
invoke-virtual {v5}, Lcom/google/protobuf/ByteString;->r()[B
move-result-object v5
invoke-static {v5}, Lcom/avast/android/ffl/Hex;->a([B)Ljava/lang/String;
move-result-object v5
aput-object v5, v4, v7
invoke-virtual {v1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationResponse;->m()J
move-result-wide v5
invoke-static {v5, v6}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v5
aput-object v5, v4, v8
new-instance v5, Ljava/text/SimpleDateFormat;
sget-object v6, Ljava/util/Locale;->US:Ljava/util/Locale;
const-string v7, "yyyy-MM-dd HH:mm:ss"
invoke-direct {v5, v7, v6}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;Ljava/util/Locale;)V
invoke-virtual {v2}, Ljava/util/Calendar;->getTime()Ljava/util/Date;
move-result-object v2
invoke-virtual {v5, v2}, Ljava/text/SimpleDateFormat;->format(Ljava/util/Date;)Ljava/lang/String;
move-result-object v2
aput-object v2, v4, v9
const-string v2, "Received new AUTH key ID %s, version %s, expiration %s"
invoke-interface {v3, v2, v4}, Lcom/avast/android/ffl/LoggingProvider;->c(Ljava/lang/String;[Ljava/lang/Object;)V
new-instance v2, Lcom/avast/android/ffl/v2/ClientIdentity;
invoke-virtual {v1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationResponse;->h()Ljava/lang/String;
move-result-object v3
invoke-direct {v2, v0, v3}, Lcom/avast/android/ffl/v2/ClientIdentity;-><init>(Lcom/google/protobuf/ByteString;Ljava/lang/String;)V
new-instance v0, Lcom/avast/android/ffl/v2/ClientKey;
invoke-virtual {v1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationResponse;->l()Lcom/google/protobuf/ByteString;
move-result-object v5
invoke-virtual {v1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationResponse;->j()Lcom/google/protobuf/ByteString;
move-result-object v6
invoke-virtual {v1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationResponse;->m()J
move-result-wide v7
invoke-virtual {v1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthRegistrationResponse;->k()J
move-result-wide v9
move-object v4, v0
invoke-direct/range {v4 .. v10}, Lcom/avast/android/ffl/v2/ClientKey;-><init>(Lcom/google/protobuf/ByteString;Lcom/google/protobuf/ByteString;JJ)V
if-eqz p1, :cond_e6
iget-object p1, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->d:Lcom/avast/android/ffl/v2/AuthStorage;
invoke-interface {p1, v2, v0}, Lcom/avast/android/ffl/v2/AuthStorage;->c(Lcom/avast/android/ffl/v2/ClientIdentity;Lcom/avast/android/ffl/v2/ClientKey;)V
goto :goto_eb
:cond_e6
iget-object p1, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->d:Lcom/avast/android/ffl/v2/AuthStorage;
invoke-interface {p1, v2, v0}, Lcom/avast/android/ffl/v2/AuthStorage;->l(Lcom/avast/android/ffl/v2/ClientIdentity;Lcom/avast/android/ffl/v2/ClientKey;)V
:goto_eb
return-void
:catch_ec
move-exception p1
new-instance v0, Lcom/avast/android/ffl/RegistrationException;
const-string v1, "Could not parse registration GPB response"
invoke-direct {v0, p1, v1}, Lcom/avast/android/ffl/RegistrationException;-><init>(Ljava/lang/Throwable;Ljava/lang/String;)V
throw v0
:cond_f5
new-instance p1, Lcom/avast/android/ffl/RegistrationException;
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Return code of AUTH service should be 200, is "
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Lretrofit/client/Response;->getStatus()I
move-result v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {p1, v0}, Lcom/avast/android/ffl/RegistrationException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method private v(Lcom/avast/android/ffl/v2/ClientIdentity;Lcom/avast/android/ffl/v2/ClientKey;)Lcom/avast/android/ffl/v2/ClientKey;
.registers 12
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
invoke-static {}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyRequest;->x()Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyRequest$Builder;
move-result-object v0
invoke-virtual {p1}, Lcom/avast/android/ffl/v2/ClientIdentity;->b()Lcom/google/protobuf/ByteString;
move-result-object v1
invoke-virtual {v0, v1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyRequest$Builder;->s(Lcom/google/protobuf/ByteString;)Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyRequest$Builder;
invoke-virtual {p1}, Lcom/avast/android/ffl/v2/ClientIdentity;->a()Ljava/lang/String;
move-result-object p1
invoke-virtual {v0, p1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyRequest$Builder;->q(Ljava/lang/String;)Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyRequest$Builder;
invoke-virtual {p2}, Lcom/avast/android/ffl/v2/ClientKey;->d()J
move-result-wide v1
invoke-virtual {v0, v1, v2}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyRequest$Builder;->u(J)Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyRequest$Builder;
iget-object p1, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->f:Lcom/avast/ffl/auth/proto/AuthProto$Identity;
invoke-virtual {v0, p1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyRequest$Builder;->t(Lcom/avast/ffl/auth/proto/AuthProto$Identity;)Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyRequest$Builder;
invoke-virtual {v0}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyRequest$Builder;->h()Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyRequest;
move-result-object p1
invoke-virtual {p1}, Lcom/google/protobuf/AbstractMessageLite;->d()[B
move-result-object p1
iget-object v0, p0, Lcom/avast/android/ffl/AbstractFFLClient;->b:Lretrofit/client/Client;
new-instance v1, Lretrofit/client/Request;
invoke-virtual {p0}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->r()Ljava/lang/String;
move-result-object v2
new-instance v3, Lcom/avast/android/ffl/v2/FFLV2ClientImpl$4;
invoke-direct {v3, p0, p1}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl$4;-><init>(Lcom/avast/android/ffl/v2/FFLV2ClientImpl;[B)V
const-string p1, "POST"
const/4 v4, 0x0
invoke-direct {v1, p1, v2, v4, v3}, Lretrofit/client/Request;-><init>(Ljava/lang/String;Ljava/lang/String;Ljava/util/List;Lretrofit/mime/TypedOutput;)V
invoke-interface {v0, v1}, Lretrofit/client/Client;->execute(Lretrofit/client/Request;)Lretrofit/client/Response;
move-result-object p1
invoke-virtual {p1}, Lretrofit/client/Response;->getStatus()I
move-result v0
const/16 v1, 0x199
if-eq v0, v1, :cond_da
invoke-virtual {p1}, Lretrofit/client/Response;->getStatus()I
move-result p2
const/16 v0, 0xc8
if-ne p2, v0, :cond_bf
:try_start_4d
invoke-virtual {p1}, Lretrofit/client/Response;->getBody()Lretrofit/mime/TypedInput;
move-result-object p1
invoke-interface {p1}, Lretrofit/mime/TypedInput;->in()Ljava/io/InputStream;
move-result-object p1
invoke-static {p1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyResponse;->parseFrom(Ljava/io/InputStream;)Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyResponse;
move-result-object p1
:try_end_59
.catch Lcom/google/protobuf/InvalidProtocolBufferException; {:try_start_4d .. :try_end_59} :catch_b6
invoke-static {}, Ljava/util/Calendar;->getInstance()Ljava/util/Calendar;
move-result-object p2
invoke-virtual {p1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyResponse;->i()J
move-result-wide v0
invoke-virtual {p2, v0, v1}, Ljava/util/Calendar;->setTimeInMillis(J)V
iget-object v0, p0, Lcom/avast/android/ffl/AbstractFFLClient;->a:Lcom/avast/android/ffl/LoggingProvider;
const/4 v1, 0x3
new-array v1, v1, [Ljava/lang/Object;
const/4 v2, 0x0
invoke-virtual {p1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyResponse;->j()Lcom/google/protobuf/ByteString;
move-result-object v3
invoke-virtual {v3}, Lcom/google/protobuf/ByteString;->r()[B
move-result-object v3
invoke-static {v3}, Lcom/avast/android/ffl/Hex;->a([B)Ljava/lang/String;
move-result-object v3
aput-object v3, v1, v2
const/4 v2, 0x1
invoke-virtual {p1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyResponse;->k()J
move-result-wide v3
invoke-static {v3, v4}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v3
aput-object v3, v1, v2
const/4 v2, 0x2
new-instance v3, Ljava/text/SimpleDateFormat;
sget-object v4, Ljava/util/Locale;->US:Ljava/util/Locale;
const-string v5, "yyyy-MM-dd HH:mm:ss"
invoke-direct {v3, v5, v4}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;Ljava/util/Locale;)V
invoke-virtual {p2}, Ljava/util/Calendar;->getTime()Ljava/util/Date;
move-result-object p2
invoke-virtual {v3, p2}, Ljava/text/SimpleDateFormat;->format(Ljava/util/Date;)Ljava/lang/String;
move-result-object p2
aput-object p2, v1, v2
const-string p2, "Received new AUTH key ID %s, version %s, expiration %s"
invoke-interface {v0, p2, v1}, Lcom/avast/android/ffl/LoggingProvider;->c(Ljava/lang/String;[Ljava/lang/Object;)V
new-instance p2, Lcom/avast/android/ffl/v2/ClientKey;
invoke-virtual {p1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyResponse;->j()Lcom/google/protobuf/ByteString;
move-result-object v3
invoke-virtual {p1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyResponse;->h()Lcom/google/protobuf/ByteString;
move-result-object v4
invoke-virtual {p1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyResponse;->k()J
move-result-wide v5
invoke-virtual {p1}, Lcom/avast/ffl/auth/proto/AuthProto$FFLAuthGenerateKeyResponse;->i()J
move-result-wide v7
move-object v2, p2
invoke-direct/range {v2 .. v8}, Lcom/avast/android/ffl/v2/ClientKey;-><init>(Lcom/google/protobuf/ByteString;Lcom/google/protobuf/ByteString;JJ)V
invoke-direct {p0, p2}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->w(Lcom/avast/android/ffl/v2/ClientKey;)V
return-object p2
:catch_b6
move-exception p1
new-instance p2, Lcom/avast/android/ffl/v2/GenerateKeyException;
const-string v0, "Could not parse generate key GPB response"
invoke-direct {p2, v0, p1}, Lcom/avast/android/ffl/v2/GenerateKeyException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw p2
:cond_bf
new-instance p2, Lcom/avast/android/ffl/v2/GenerateKeyException;
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "Return code of AUTH service should be 200, is "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Lretrofit/client/Response;->getStatus()I
move-result p1
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {p2, p1}, Lcom/avast/android/ffl/v2/GenerateKeyException;-><init>(Ljava/lang/String;)V
throw p2
:cond_da
new-instance p1, Lcom/avast/android/ffl/v2/KeyVersionConflictException;
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "Conflict when requesting new key with previous version: "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Lcom/avast/android/ffl/v2/ClientKey;->d()J
move-result-wide v1
invoke-virtual {v0, v1, v2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-direct {p1, p2}, Lcom/avast/android/ffl/v2/KeyVersionConflictException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method private w(Lcom/avast/android/ffl/v2/ClientKey;)V
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
iget-boolean v0, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->g:Z
if-eqz v0, :cond_a
iget-object v0, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->d:Lcom/avast/android/ffl/v2/AuthStorage;
invoke-interface {v0, p1}, Lcom/avast/android/ffl/v2/AuthStorage;->b(Lcom/avast/android/ffl/v2/ClientKey;)V
goto :goto_f
:cond_a
iget-object v0, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->d:Lcom/avast/android/ffl/v2/AuthStorage;
invoke-interface {v0, p1}, Lcom/avast/android/ffl/v2/AuthStorage;->d(Lcom/avast/android/ffl/v2/ClientKey;)V
:goto_f
return-void
.end method
.method private y(J)V
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
invoke-static {p1, p2}, Lcom/avast/android/ffl/v2/DefaultClock;->b(J)J
move-result-wide p1
iget-object v0, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->d:Lcom/avast/android/ffl/v2/AuthStorage;
invoke-interface {v0, p1, p2}, Lcom/avast/android/ffl/v2/AuthStorage;->f(J)V
new-instance v0, Lcom/avast/android/ffl/v2/DefaultClock;
invoke-direct {v0, p1, p2}, Lcom/avast/android/ffl/v2/DefaultClock;-><init>(J)V
iget-object p1, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->e:Ljava/util/concurrent/atomic/AtomicReference;
invoke-virtual {p1, v0}, Ljava/util/concurrent/atomic/AtomicReference;->set(Ljava/lang/Object;)V
return-void
.end method
# virtual methods
.method public a()V
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
iget-object v0, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->d:Lcom/avast/android/ffl/v2/AuthStorage;
invoke-interface {v0}, Lcom/avast/android/ffl/v2/AuthStorage;->h()Lcom/avast/android/ffl/v2/ClientIdentity;
move-result-object v0
if-eqz v0, :cond_c
invoke-direct {p0, v0}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->t(Lcom/avast/android/ffl/v2/ClientIdentity;)V
return-void
:cond_c
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Root client id must be registered before registering app client id."
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public b()V
.registers 11
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
invoke-direct {p0}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->q()Lcom/avast/android/ffl/v2/ClientKey;
move-result-object v0
invoke-direct {p0}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->p()Lcom/avast/android/ffl/v2/ClientIdentity;
move-result-object v1
if-eqz v0, :cond_2c
if-eqz v1, :cond_2c
new-instance v9, Lcom/avast/android/ffl/v2/ClientKey;
invoke-virtual {v0}, Lcom/avast/android/ffl/v2/ClientKey;->b()Lcom/google/protobuf/ByteString;
move-result-object v3
invoke-virtual {v0}, Lcom/avast/android/ffl/v2/ClientKey;->c()Lcom/google/protobuf/ByteString;
move-result-object v4
invoke-virtual {v0}, Lcom/avast/android/ffl/v2/ClientKey;->d()J
move-result-wide v5
const-wide/16 v7, 0x1
add-long/2addr v5, v7
invoke-virtual {v0}, Lcom/avast/android/ffl/v2/ClientKey;->a()J
move-result-wide v7
move-object v2, v9
invoke-direct/range {v2 .. v8}, Lcom/avast/android/ffl/v2/ClientKey;-><init>(Lcom/google/protobuf/ByteString;Lcom/google/protobuf/ByteString;JJ)V
invoke-direct {p0, v9}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->w(Lcom/avast/android/ffl/v2/ClientKey;)V
invoke-direct {p0, v1, v0}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->v(Lcom/avast/android/ffl/v2/ClientIdentity;Lcom/avast/android/ffl/v2/ClientKey;)Lcom/avast/android/ffl/v2/ClientKey;
return-void
:cond_2c
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "App client is not registered with auth server"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public c()V
.registers 2
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
const/4 v0, 0x0
invoke-direct {p0, v0}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->t(Lcom/avast/android/ffl/v2/ClientIdentity;)V
return-void
.end method
.method public d()Z
.registers 2
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
iget-object v0, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->d:Lcom/avast/android/ffl/v2/AuthStorage;
invoke-interface {v0}, Lcom/avast/android/ffl/v2/AuthStorage;->m()Lcom/avast/android/ffl/v2/ClientIdentity;
move-result-object v0
if-eqz v0, :cond_12
iget-object v0, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->d:Lcom/avast/android/ffl/v2/AuthStorage;
invoke-interface {v0}, Lcom/avast/android/ffl/v2/AuthStorage;->g()Lcom/avast/android/ffl/v2/ClientKey;
move-result-object v0
if-eqz v0, :cond_12
const/4 v0, 0x1
goto :goto_13
:cond_12
const/4 v0, 0x0
:goto_13
return v0
.end method
.method public e()Z
.registers 2
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
iget-object v0, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->d:Lcom/avast/android/ffl/v2/AuthStorage;
invoke-interface {v0}, Lcom/avast/android/ffl/v2/AuthStorage;->h()Lcom/avast/android/ffl/v2/ClientIdentity;
move-result-object v0
if-eqz v0, :cond_a
const/4 v0, 0x1
goto :goto_b
:cond_a
const/4 v0, 0x0
:goto_b
return v0
.end method
.method public execute(Lretrofit/client/Request;)Lretrofit/client/Response;
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;,
Lcom/avast/android/ffl/KeyExpiredException;
}
.end annotation
iget-object v0, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->d:Lcom/avast/android/ffl/v2/AuthStorage;
invoke-interface {v0}, Lcom/avast/android/ffl/v2/AuthStorage;->h()Lcom/avast/android/ffl/v2/ClientIdentity;
move-result-object v0
if-eqz v0, :cond_2f
iget-object v1, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->d:Lcom/avast/android/ffl/v2/AuthStorage;
invoke-interface {v1}, Lcom/avast/android/ffl/v2/AuthStorage;->m()Lcom/avast/android/ffl/v2/ClientIdentity;
move-result-object v1
if-eqz v1, :cond_27
invoke-virtual {v1, v0}, Lcom/avast/android/ffl/v2/ClientIdentity;->c(Lcom/avast/android/ffl/v2/ClientIdentity;)Z
move-result v0
if-eqz v0, :cond_1f
invoke-direct {p0}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->q()Lcom/avast/android/ffl/v2/ClientKey;
move-result-object v0
invoke-direct {p0, p1, v0}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->k(Lretrofit/client/Request;Lcom/avast/android/ffl/v2/ClientKey;)Lretrofit/client/Response;
move-result-object p1
return-object p1
:cond_1f
new-instance p1, Lcom/avast/android/ffl/v2/AppClientIdMismatchException;
const-string v0, "App Client ID is not derived from root Client ID"
invoke-direct {p1, v0}, Lcom/avast/android/ffl/v2/AppClientIdMismatchException;-><init>(Ljava/lang/String;)V
throw p1
:cond_27
new-instance p1, Ljava/lang/IllegalStateException;
const-string v0, "App Client ID not registered"
invoke-direct {p1, v0}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw p1
:cond_2f
new-instance p1, Ljava/lang/IllegalStateException;
const-string v0, "Root Client ID not registered"
invoke-direct {p1, v0}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method protected r()Ljava/lang/String;
.registers 3
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "https://"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lcom/avast/android/ffl/AbstractFFLClient;->c:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, "/V2/KEY"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method protected u()Ljava/lang/String;
.registers 3
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "https://"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lcom/avast/android/ffl/AbstractFFLClient;->c:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, "/V2/REG"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public x()Lcom/avast/android/ffl/v2/FFLV2ClientImpl;
.registers 9
iget-boolean v0, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->g:Z
if-eqz v0, :cond_6
move-object v0, p0
goto :goto_17
:cond_6
new-instance v0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;
iget-object v2, p0, Lcom/avast/android/ffl/AbstractFFLClient;->b:Lretrofit/client/Client;
iget-object v3, p0, Lcom/avast/android/ffl/AbstractFFLClient;->a:Lcom/avast/android/ffl/LoggingProvider;
iget-object v4, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->d:Lcom/avast/android/ffl/v2/AuthStorage;
iget-object v5, p0, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;->f:Lcom/avast/ffl/auth/proto/AuthProto$Identity;
iget-object v6, p0, Lcom/avast/android/ffl/AbstractFFLClient;->c:Ljava/lang/String;
const/4 v7, 0x1
move-object v1, v0
invoke-direct/range {v1 .. v7}, Lcom/avast/android/ffl/v2/FFLV2ClientImpl;-><init>(Lretrofit/client/Client;Lcom/avast/android/ffl/LoggingProvider;Lcom/avast/android/ffl/v2/AuthStorage;Lcom/avast/ffl/auth/proto/AuthProto$Identity;Ljava/lang/String;Z)V
:goto_17
return-object v0
.end method