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