.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 (Ljava/lang/String;Ljava/lang/String;J)V .locals 1 .line 32 invoke-direct {p0}, Ljava/lang/Object;->()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;->(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;->(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;->([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;->(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