Files
rr3-apk/smali_classes2/com/glu/plugins/gluanalytics/CacheService.smali
Daniel Elliott f3960ee359 Add Discord APKTool decompilation (Smali source for modding)
- Imported from https://github.com/supermegamestre/Project-Real-Resurrection-3
- APKTool decompilation (Smali bytecode) for modding and rebuilding APK
- Supports both 32-bit (armeabi-v7a) and 64-bit (arm64-v8a) architectures
- Includes full Smali source, resources, and native libraries
- Ready to rebuild APK after modifications with apktool b command
- Added comprehensive README-apktool.md with modding guide

This branch complements the JADX branches:
- Use JADX (main/discord-community) to UNDERSTAND code (readable Java)
- Use APKTool (this branch) to MODIFY and REBUILD APK (editable Smali)

Total: 44,417 files, 538.51 MB Smali source code
2026-02-18 16:13:44 -08:00

602 lines
16 KiB
Smali

.class public Lcom/glu/plugins/gluanalytics/CacheService;
.super Ljava/lang/Object;
.source "SourceFile"
# instance fields
.field private mBundleId:Ljava/lang/String;
.field private mCacheServiceTimeout:J
.field private mExecutor:Ljava/util/concurrent/ScheduledExecutorService;
.field private mHeaders:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;"
}
.end annotation
.end field
.field private mLastGameName:Ljava/lang/String;
.field private mLastRevId:Ljava/lang/String;
.field private mLastS:Ljava/lang/String;
.field private mLastSentTime:J
.field private mLastSessId:Ljava/lang/String;
.field private mLastUid:Ljava/lang/String;
.field private final mLog:Lcom/glu/plugins/gluanalytics/util/YLogger;
.field private mUrl:Ljava/net/URL;
# direct methods
.method public constructor <init>(Ljava/lang/String;Ljava/lang/String;J)V
.locals 1
.line 32
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 18
invoke-virtual {p0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v0
invoke-static {v0}, Lcom/glu/plugins/gluanalytics/util/YLogger;->create(Ljava/lang/Class;)Lcom/glu/plugins/gluanalytics/util/YLogger;
move-result-object v0
iput-object v0, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLog:Lcom/glu/plugins/gluanalytics/util/YLogger;
.line 33
invoke-static {}, Ljava/util/concurrent/Executors;->newSingleThreadScheduledExecutor()Ljava/util/concurrent/ScheduledExecutorService;
move-result-object v0
iput-object v0, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mExecutor:Ljava/util/concurrent/ScheduledExecutorService;
iput-object p1, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mBundleId:Ljava/lang/String;
.line 38
:try_start_0
new-instance p1, Ljava/net/URL;
invoke-direct {p1, p2}, Ljava/net/URL;-><init>(Ljava/lang/String;)V
iput-object p1, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mUrl:Ljava/net/URL;
:try_end_0
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
goto :goto_0
:catch_0
move-exception p1
iget-object p2, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLog:Lcom/glu/plugins/gluanalytics/util/YLogger;
const-string v0, "URL"
.line 40
invoke-virtual {p1}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object p1
filled-new-array {v0, p1}, [Ljava/lang/Object;
move-result-object p1
const-string v0, "CacheService"
invoke-virtual {p2, v0, p1}, Lcom/glu/plugins/gluanalytics/util/YLogger;->i(Ljava/lang/String;[Ljava/lang/Object;)V
.line 43
:goto_0
invoke-static {}, Lcom/glu/plugins/gluanalytics/util/CollectionUtil;->createMap()Ljava/util/Map;
move-result-object p1
iput-object p1, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mHeaders:Ljava/util/Map;
const-string p2, "Content-Type"
const-string v0, "application/json"
.line 44
invoke-interface {p1, p2, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-wide/16 p1, -0x1
iput-wide p1, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastSentTime:J
iput-wide p3, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mCacheServiceTimeout:J
.line 49
invoke-direct {p0}, Lcom/glu/plugins/gluanalytics/CacheService;->scheduleUpdate()V
return-void
.end method
.method public static synthetic access$000(Lcom/glu/plugins/gluanalytics/CacheService;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.locals 0
.line 17
invoke-direct/range {p0 .. p5}, Lcom/glu/plugins/gluanalytics/CacheService;->doPutData(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
.method public static synthetic access$100(Lcom/glu/plugins/gluanalytics/CacheService;)Ljava/lang/String;
.locals 0
.line 17
iget-object p0, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastS:Ljava/lang/String;
return-object p0
.end method
.method public static synthetic access$200(Lcom/glu/plugins/gluanalytics/CacheService;)Ljava/lang/String;
.locals 0
.line 17
iget-object p0, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastGameName:Ljava/lang/String;
return-object p0
.end method
.method public static synthetic access$300(Lcom/glu/plugins/gluanalytics/CacheService;)Ljava/lang/String;
.locals 0
.line 17
iget-object p0, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastUid:Ljava/lang/String;
return-object p0
.end method
.method public static synthetic access$400(Lcom/glu/plugins/gluanalytics/CacheService;)Ljava/lang/String;
.locals 0
.line 17
iget-object p0, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastRevId:Ljava/lang/String;
return-object p0
.end method
.method public static synthetic access$500(Lcom/glu/plugins/gluanalytics/CacheService;)Ljava/lang/String;
.locals 0
.line 17
iget-object p0, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastSessId:Ljava/lang/String;
return-object p0
.end method
.method private doPutData(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.locals 7
.line 84
invoke-static {p1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-nez v0, :cond_3
invoke-static {p2}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-nez v0, :cond_3
invoke-static {p3}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-nez v0, :cond_3
invoke-static {p4}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-nez v0, :cond_3
invoke-static {p5}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-eqz v0, :cond_0
goto :goto_0
:cond_0
iget-object v0, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastS:Ljava/lang/String;
.line 89
invoke-virtual {p1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_1
iget-object v0, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastGameName:Ljava/lang/String;
invoke-virtual {p2, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_1
iget-object v0, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastUid:Ljava/lang/String;
invoke-virtual {p3, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_1
iget-object v0, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastRevId:Ljava/lang/String;
invoke-virtual {p4, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_1
iget-object v0, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastSessId:Ljava/lang/String;
invoke-virtual {p5, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_2
:cond_1
iput-object p1, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastS:Ljava/lang/String;
iput-object p2, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastGameName:Ljava/lang/String;
iput-object p3, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastUid:Ljava/lang/String;
iput-object p4, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastRevId:Ljava/lang/String;
iput-object p5, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastSessId:Ljava/lang/String;
const-wide/16 v0, -0x1
iput-wide v0, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastSentTime:J
.line 97
:cond_2
invoke-direct/range {p0 .. p5}, Lcom/glu/plugins/gluanalytics/CacheService;->sendPutRequset(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
return-void
:cond_3
:goto_0
iget-object v0, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLog:Lcom/glu/plugins/gluanalytics/util/YLogger;
iget-object v6, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mBundleId:Ljava/lang/String;
move-object v1, p1
move-object v2, p2
move-object v3, p3
move-object v4, p4
move-object v5, p5
filled-new-array/range {v1 .. v6}, [Ljava/lang/Object;
move-result-object p1
const-string p2, "s=%s, game_name=%s, uid=%s, rev_id=%s, sess_id=%s, bundle_id=%s"
.line 85
invoke-static {p2, p1}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
const-string p2, "Ignore"
filled-new-array {p2, p1}, [Ljava/lang/Object;
move-result-object p1
const-string p2, "CacheService"
invoke-virtual {v0, p2, p1}, Lcom/glu/plugins/gluanalytics/util/YLogger;->i(Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.end method
.method private scheduleUpdate()V
.locals 7
:try_start_0
iget-object v0, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mExecutor:Ljava/util/concurrent/ScheduledExecutorService;
.line 72
new-instance v1, Lcom/glu/plugins/gluanalytics/CacheService$2;
invoke-direct {v1, p0}, Lcom/glu/plugins/gluanalytics/CacheService$2;-><init>(Lcom/glu/plugins/gluanalytics/CacheService;)V
const-wide/16 v2, 0x1
const-wide/16 v4, 0x1
sget-object v6, Ljava/util/concurrent/TimeUnit;->MINUTES:Ljava/util/concurrent/TimeUnit;
invoke-interface/range {v0 .. v6}, Ljava/util/concurrent/ScheduledExecutorService;->scheduleAtFixedRate(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
:try_end_0
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
goto :goto_0
:catch_0
move-exception v0
iget-object v1, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLog:Lcom/glu/plugins/gluanalytics/util/YLogger;
const-string v2, "Exception"
.line 79
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v0
filled-new-array {v2, v0}, [Ljava/lang/Object;
move-result-object v0
const-string v2, "CacheService"
invoke-virtual {v1, v2, v0}, Lcom/glu/plugins/gluanalytics/util/YLogger;->i(Ljava/lang/String;[Ljava/lang/Object;)V
:goto_0
return-void
.end method
.method private sendPutRequset(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.locals 13
move-object v0, p0
.line 101
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v1
const-wide/16 v3, 0x3e8
div-long/2addr v1, v3
iget-wide v3, v0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastSentTime:J
const-wide/16 v5, 0x0
cmp-long v5, v3, v5
const-string v6, "CacheService"
if-ltz v5, :cond_1
sub-long v3, v1, v3
iget-wide v7, v0, Lcom/glu/plugins/gluanalytics/CacheService;->mCacheServiceTimeout:J
cmp-long v3, v3, v7
if-ltz v3, :cond_0
goto :goto_0
:cond_0
iget-object v1, v0, Lcom/glu/plugins/gluanalytics/CacheService;->mLog:Lcom/glu/plugins/gluanalytics/util/YLogger;
const-string v2, "Ignore"
const-string v3, "Not expired"
filled-new-array {v2, v3}, [Ljava/lang/Object;
move-result-object v2
.line 116
invoke-virtual {v1, v6, v2}, Lcom/glu/plugins/gluanalytics/util/YLogger;->i(Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_2
:cond_1
:goto_0
iget-object v12, v0, Lcom/glu/plugins/gluanalytics/CacheService;->mBundleId:Ljava/lang/String;
move-object v7, p1
move-object v8, p2
move-object/from16 v9, p3
move-object/from16 v10, p4
move-object/from16 v11, p5
filled-new-array/range {v7 .. v12}, [Ljava/lang/Object;
move-result-object v3
const-string v4, "{\"s\":\"%s\",\"game_name\":\"%s\",\"uid\":\"%s\",\"rev_id\":\"%s\",\"sess_id\":\"%s\",\"bundle_id\":\"%s\"}"
.line 104
invoke-static {v4, v3}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
iget-object v4, v0, Lcom/glu/plugins/gluanalytics/CacheService;->mLog:Lcom/glu/plugins/gluanalytics/util/YLogger;
const-string v5, "Data"
filled-new-array {v5, v3}, [Ljava/lang/Object;
move-result-object v5
.line 105
invoke-virtual {v4, v6, v5}, Lcom/glu/plugins/gluanalytics/util/YLogger;->i(Ljava/lang/String;[Ljava/lang/Object;)V
iget-object v4, v0, Lcom/glu/plugins/gluanalytics/CacheService;->mUrl:Ljava/net/URL;
iget-object v5, v0, Lcom/glu/plugins/gluanalytics/CacheService;->mHeaders:Ljava/util/Map;
const/4 v7, 0x0
const-string v8, "POST"
.line 107
invoke-static {v8, v4, v5, v3, v7}, Lcom/glu/plugins/gluanalytics/network/NetworkUtils;->sendRequest(Ljava/lang/String;Ljava/net/URL;Ljava/util/Map;Ljava/lang/String;I)Lcom/glu/plugins/gluanalytics/network/NetworkResponse;
move-result-object v3
.line 108
iget-object v4, v3, Lcom/glu/plugins/gluanalytics/network/NetworkResponse;->throwable:Ljava/lang/Throwable;
const-string v5, "SendRequest"
if-nez v4, :cond_3
.line 109
iget-object v4, v3, Lcom/glu/plugins/gluanalytics/network/NetworkResponse;->body:[B
if-eqz v4, :cond_2
new-instance v7, Ljava/lang/String;
invoke-direct {v7, v4}, Ljava/lang/String;-><init>([B)V
goto :goto_1
:cond_2
const-string v7, "null"
:goto_1
iget-object v4, v0, Lcom/glu/plugins/gluanalytics/CacheService;->mLog:Lcom/glu/plugins/gluanalytics/util/YLogger;
.line 110
iget v3, v3, Lcom/glu/plugins/gluanalytics/network/NetworkResponse;->code:I
invoke-static {v3}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v3
const-string v8, "\\s"
const-string v9, ""
invoke-virtual {v7, v8, v9}, Ljava/lang/String;->replaceAll(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object v7
const-string v8, "Body"
filled-new-array {v5, v3, v8, v7}, [Ljava/lang/Object;
move-result-object v3
invoke-virtual {v4, v6, v3}, Lcom/glu/plugins/gluanalytics/util/YLogger;->i(Ljava/lang/String;[Ljava/lang/Object;)V
iput-wide v1, v0, Lcom/glu/plugins/gluanalytics/CacheService;->mLastSentTime:J
goto :goto_2
:cond_3
iget-object v1, v0, Lcom/glu/plugins/gluanalytics/CacheService;->mLog:Lcom/glu/plugins/gluanalytics/util/YLogger;
.line 113
invoke-virtual {v4}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v2
filled-new-array {v5, v2}, [Ljava/lang/Object;
move-result-object v2
invoke-virtual {v1, v6, v2}, Lcom/glu/plugins/gluanalytics/util/YLogger;->i(Ljava/lang/String;[Ljava/lang/Object;)V
:goto_2
return-void
.end method
# virtual methods
.method public destroy()V
.locals 1
iget-object v0, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mExecutor:Ljava/util/concurrent/ScheduledExecutorService;
.line 54
invoke-interface {v0}, Ljava/util/concurrent/ExecutorService;->shutdownNow()Ljava/util/List;
return-void
.end method
.method public putData(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.locals 8
:try_start_0
iget-object p6, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mExecutor:Ljava/util/concurrent/ScheduledExecutorService;
.line 59
new-instance v7, Lcom/glu/plugins/gluanalytics/CacheService$1;
move-object v0, v7
move-object v1, p0
move-object v2, p1
move-object v3, p2
move-object v4, p3
move-object v5, p4
move-object v6, p5
invoke-direct/range {v0 .. v6}, Lcom/glu/plugins/gluanalytics/CacheService$1;-><init>(Lcom/glu/plugins/gluanalytics/CacheService;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
invoke-interface {p6, v7}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V
:try_end_0
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
goto :goto_0
:catch_0
move-exception p1
iget-object p2, p0, Lcom/glu/plugins/gluanalytics/CacheService;->mLog:Lcom/glu/plugins/gluanalytics/util/YLogger;
const-string p3, "Exception"
.line 66
invoke-virtual {p1}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object p1
filled-new-array {p3, p1}, [Ljava/lang/Object;
move-result-object p1
const-string p3, "CacheService"
invoke-virtual {p2, p3, p1}, Lcom/glu/plugins/gluanalytics/util/YLogger;->i(Ljava/lang/String;[Ljava/lang/Object;)V
:goto_0
return-void
.end method