PushSA.smali
.class public Lcn/jiguang/analytics/page/PushSA;
.super Ljava/lang/Object;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcn/jiguang/analytics/page/PushSA$a;
}
.end annotation
# static fields
.field public static final CACHE_PATH:Ljava/lang/String; = "push_stat_cache.json"
.field private static final KEY_SESSION_ID:Ljava/lang/String; = "session_id"
.field public static final REPORT_ACTIVE_LAUNCH:Ljava/lang/String; = "active_launch"
.field public static final REPORT_ACTIVE_TERMINATE:Ljava/lang/String; = "active_terminate"
.field private static final SESSION_END_MILLIS:Ljava/lang/String; = "cse"
.field private static final SESSION_START_MILLIS:Ljava/lang/String; = "css"
.field private static final TAG:Ljava/lang/String; = "PushSA"
.field private static volatile instance:Lcn/jiguang/analytics/page/PushSA;
.field public static isOnPauseInvoke:Z
.field public static isOnResumeInvoke:Z
# instance fields
.field private activitySwitch:Z
.field private cur_activity:Ljava/lang/String;
.field private final cur_session_file_lock:Ljava/lang/Object;
.field private cur_session_id:Ljava/lang/String;
.field private firstResume:Z
.field private flow_cache:Lorg/json/JSONObject;
.field private interval:J
.field private latestPauseTime:J
.field private latestResumeTime:J
.field private stat_enable:Z
.field private tempTimelong:J
# direct methods
.method static constructor <clinit>()V
.registers 2
const/4 v1, 0x0
const/4 v0, 0x0
sput-object v0, Lcn/jiguang/analytics/page/PushSA;->instance:Lcn/jiguang/analytics/page/PushSA;
sput-boolean v1, Lcn/jiguang/analytics/page/PushSA;->isOnResumeInvoke:Z
sput-boolean v1, Lcn/jiguang/analytics/page/PushSA;->isOnPauseInvoke:Z
return-void
.end method
.method private constructor <init>()V
.registers 7
const/4 v3, 0x1
const-wide/16 v4, 0x0
const/4 v2, 0x0
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
iput-object v2, p0, Lcn/jiguang/analytics/page/PushSA;->cur_activity:Ljava/lang/String;
iput-object v2, p0, Lcn/jiguang/analytics/page/PushSA;->cur_session_id:Ljava/lang/String;
const-wide/16 v0, 0x1e
iput-wide v0, p0, Lcn/jiguang/analytics/page/PushSA;->interval:J
iput-wide v4, p0, Lcn/jiguang/analytics/page/PushSA;->latestResumeTime:J
iput-wide v4, p0, Lcn/jiguang/analytics/page/PushSA;->latestPauseTime:J
iput-boolean v3, p0, Lcn/jiguang/analytics/page/PushSA;->firstResume:Z
const/4 v0, 0x0
iput-boolean v0, p0, Lcn/jiguang/analytics/page/PushSA;->activitySwitch:Z
iput-boolean v3, p0, Lcn/jiguang/analytics/page/PushSA;->stat_enable:Z
iput-wide v4, p0, Lcn/jiguang/analytics/page/PushSA;->tempTimelong:J
iput-object v2, p0, Lcn/jiguang/analytics/page/PushSA;->flow_cache:Lorg/json/JSONObject;
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
iput-object v0, p0, Lcn/jiguang/analytics/page/PushSA;->cur_session_file_lock:Ljava/lang/Object;
return-void
.end method
.method static synthetic access$000(Lcn/jiguang/analytics/page/PushSA;Landroid/content/Context;)V
.registers 2
invoke-direct {p0, p1}, Lcn/jiguang/analytics/page/PushSA;->sendLogRoutine(Landroid/content/Context;)V
return-void
.end method
.method static synthetic access$100(Lcn/jiguang/analytics/page/PushSA;Landroid/content/Context;)V
.registers 2
invoke-direct {p0, p1}, Lcn/jiguang/analytics/page/PushSA;->saveLogRoutine(Landroid/content/Context;)V
return-void
.end method
.method private clearCurrentLogFile(Landroid/content/Context;)V
.registers 4
const-string v0, "push_stat_cache.json"
const/4 v1, 0x0
invoke-static {p1, v0, v1}, Lcn/jiguang/az/f;->a(Landroid/content/Context;Ljava/lang/String;Lorg/json/JSONObject;)Z
return-void
.end method
.method private createNewSession(Landroid/content/Context;J)Lorg/json/JSONObject;
.registers 10
invoke-direct {p0, p1, p2, p3}, Lcn/jiguang/analytics/page/PushSA;->generateSessionID(Landroid/content/Context;J)Ljava/lang/String;
move-result-object v0
iput-object v0, p0, Lcn/jiguang/analytics/page/PushSA;->cur_session_id:Ljava/lang/String;
const/4 v0, 0x2
new-array v0, v0, [Lcn/jiguang/g/a;
const/4 v1, 0x0
invoke-static {}, Lcn/jiguang/g/a;->o()Lcn/jiguang/g/a;
move-result-object v2
iget-wide v4, p0, Lcn/jiguang/analytics/page/PushSA;->latestResumeTime:J
invoke-static {v4, v5}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v3
invoke-virtual {v2, v3}, Lcn/jiguang/g/a;->a(Ljava/lang/Object;)Lcn/jiguang/g/a;
move-result-object v2
aput-object v2, v0, v1
const/4 v1, 0x1
invoke-static {}, Lcn/jiguang/g/a;->r()Lcn/jiguang/g/a;
move-result-object v2
iget-object v3, p0, Lcn/jiguang/analytics/page/PushSA;->cur_session_id:Ljava/lang/String;
invoke-virtual {v2, v3}, Lcn/jiguang/g/a;->a(Ljava/lang/Object;)Lcn/jiguang/g/a;
move-result-object v2
aput-object v2, v0, v1
invoke-static {p1, v0}, Lcn/jiguang/g/b;->a(Landroid/content/Context;[Lcn/jiguang/g/a;)V
new-instance v0, Lorg/json/JSONObject;
invoke-direct {v0}, Lorg/json/JSONObject;-><init>()V
:try_start_2f
invoke-direct {p0, v0}, Lcn/jiguang/analytics/page/PushSA;->wrapDate(Lorg/json/JSONObject;)V
const-string v1, "active_launch"
invoke-static {p1, v0, v1}, Lcn/jiguang/d/a;->a(Landroid/content/Context;Lorg/json/JSONObject;Ljava/lang/String;)Lorg/json/JSONObject;
const-string v1, "session_id"
iget-object v2, p0, Lcn/jiguang/analytics/page/PushSA;->cur_session_id:Ljava/lang/String;
invoke-virtual {v0, v1, v2}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
:try_end_3e
.catch Lorg/json/JSONException; {:try_start_2f .. :try_end_3e} :catch_3f
:goto_3e
return-object v0
:catch_3f
move-exception v0
const/4 v0, 0x0
goto :goto_3e
.end method
.method private generateSessionID(Landroid/content/Context;J)Ljava/lang/String;
.registers 8
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
invoke-static {p1}, Lcn/jiguang/d/a;->e(Landroid/content/Context;)Ljava/lang/String;
move-result-object v1
invoke-static {v1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v2
if-nez v2, :cond_12
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
:cond_12
invoke-virtual {v0, p2, p3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Lcn/jiguang/f/f;->d(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method private getFlowCache(Landroid/content/Context;)Lorg/json/JSONObject;
.registers 3
iget-object v0, p0, Lcn/jiguang/analytics/page/PushSA;->flow_cache:Lorg/json/JSONObject;
if-nez v0, :cond_c
const-string v0, "push_stat_cache.json"
invoke-static {p1, v0}, Lcn/jiguang/d/a;->a(Landroid/content/Context;Ljava/lang/String;)Lorg/json/JSONObject;
move-result-object v0
iput-object v0, p0, Lcn/jiguang/analytics/page/PushSA;->flow_cache:Lorg/json/JSONObject;
:cond_c
iget-object v0, p0, Lcn/jiguang/analytics/page/PushSA;->flow_cache:Lorg/json/JSONObject;
return-object v0
.end method
.method public static getInstance()Lcn/jiguang/analytics/page/PushSA;
.registers 2
sget-object v0, Lcn/jiguang/analytics/page/PushSA;->instance:Lcn/jiguang/analytics/page/PushSA;
if-nez v0, :cond_f
const-class v1, Lcn/jiguang/analytics/page/PushSA;
monitor-enter v1
:try_start_7
new-instance v0, Lcn/jiguang/analytics/page/PushSA;
invoke-direct {v0}, Lcn/jiguang/analytics/page/PushSA;-><init>()V
sput-object v0, Lcn/jiguang/analytics/page/PushSA;->instance:Lcn/jiguang/analytics/page/PushSA;
monitor-exit v1
:try_end_f
.catchall {:try_start_7 .. :try_end_f} :catchall_12
:cond_f
sget-object v0, Lcn/jiguang/analytics/page/PushSA;->instance:Lcn/jiguang/analytics/page/PushSA;
return-object v0
:catchall_12
move-exception v0
:try_start_13
monitor-exit v1
:try_end_14
.catchall {:try_start_13 .. :try_end_14} :catchall_12
throw v0
.end method
.method private invokeCheck(Landroid/content/Context;Ljava/lang/String;)Z
.registers 7
const/4 v0, 0x0
iget-boolean v1, p0, Lcn/jiguang/analytics/page/PushSA;->stat_enable:Z
if-nez v1, :cond_d
const-string v1, "PushSA"
const-string v2, "stat function has been disabled"
invoke-static {v1, v2}, Lcn/jiguang/ay/c;->e(Ljava/lang/String;Ljava/lang/String;)V
:goto_c
return v0
:cond_d
if-nez p1, :cond_17
const-string v1, "PushSA"
const-string v2, "context is null"
invoke-static {v1, v2}, Lcn/jiguang/ay/c;->e(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_c
:cond_17
instance-of v1, p1, Landroid/app/Application;
if-eqz v1, :cond_34
const-string v1, "PushSA"
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Context should be an Activity on this method : "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v1, v2}, Lcn/jiguang/ay/c;->j(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_c
:cond_34
const/4 v0, 0x1
goto :goto_c
.end method
.method private isNewSession(Landroid/content/Context;)Z
.registers 12
const-wide/16 v8, 0x3e8
const/4 v1, 0x0
const/4 v2, 0x1
iget-boolean v0, p0, Lcn/jiguang/analytics/page/PushSA;->firstResume:Z
if-eqz v0, :cond_70
iput-boolean v1, p0, Lcn/jiguang/analytics/page/PushSA;->firstResume:Z
const-string v0, "PushSA"
const-string v3, "statistics start"
invoke-static {v0, v3}, Lcn/jiguang/ay/c;->c(Ljava/lang/String;Ljava/lang/String;)V
invoke-static {}, Lcn/jiguang/g/a;->q()Lcn/jiguang/g/a;
move-result-object v0
invoke-static {p1, v0}, Lcn/jiguang/g/b;->a(Landroid/content/Context;Lcn/jiguang/g/a;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/Long;
invoke-virtual {v0}, Ljava/lang/Long;->longValue()J
move-result-wide v4
const-string v0, "PushSA"
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v6, "lastPause:"
invoke-virtual {v3, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3, v4, v5}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
move-result-object v3
const-string v6, ",latestResumeTime:"
invoke-virtual {v3, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
iget-wide v6, p0, Lcn/jiguang/analytics/page/PushSA;->latestResumeTime:J
invoke-virtual {v3, v6, v7}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
move-result-object v3
const-string v6, ",interval:"
invoke-virtual {v3, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
iget-wide v6, p0, Lcn/jiguang/analytics/page/PushSA;->interval:J
mul-long/2addr v6, v8
invoke-virtual {v3, v6, v7}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
move-result-object v3
const-string v6, ",a:"
invoke-virtual {v3, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
iget-wide v6, p0, Lcn/jiguang/analytics/page/PushSA;->latestResumeTime:J
sub-long/2addr v6, v4
invoke-virtual {v3, v6, v7}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v0, v3}, Lcn/jiguang/ay/c;->c(Ljava/lang/String;Ljava/lang/String;)V
const-wide/16 v6, 0x0
cmp-long v0, v4, v6
if-lez v0, :cond_7e
iget-wide v6, p0, Lcn/jiguang/analytics/page/PushSA;->latestResumeTime:J
sub-long v4, v6, v4
iget-wide v6, p0, Lcn/jiguang/analytics/page/PushSA;->interval:J
mul-long/2addr v6, v8
cmp-long v0, v4, v6
if-gtz v0, :cond_7e
move v0, v1
:goto_6f
return v0
:cond_70
iget-wide v4, p0, Lcn/jiguang/analytics/page/PushSA;->latestResumeTime:J
iget-wide v6, p0, Lcn/jiguang/analytics/page/PushSA;->latestPauseTime:J
sub-long/2addr v4, v6
iget-wide v6, p0, Lcn/jiguang/analytics/page/PushSA;->interval:J
mul-long/2addr v6, v8
cmp-long v0, v4, v6
if-gtz v0, :cond_7e
move v0, v1
goto :goto_6f
:cond_7e
move v0, v2
goto :goto_6f
.end method
.method private saveCurrentLog(Landroid/content/Context;Lorg/json/JSONObject;)V
.registers 4
const-string v0, "push_stat_cache.json"
invoke-static {p1, v0, p2}, Lcn/jiguang/az/f;->a(Landroid/content/Context;Ljava/lang/String;Lorg/json/JSONObject;)Z
return-void
.end method
.method private saveLogRoutine(Landroid/content/Context;)V
.registers 8
if-nez p1, :cond_3
:goto_2
return-void
:cond_3
iget-object v1, p0, Lcn/jiguang/analytics/page/PushSA;->cur_session_file_lock:Ljava/lang/Object;
monitor-enter v1
const/4 v0, 0x2
:try_start_7
new-array v0, v0, [Lcn/jiguang/g/a;
const/4 v2, 0x0
invoke-static {}, Lcn/jiguang/g/a;->q()Lcn/jiguang/g/a;
move-result-object v3
iget-wide v4, p0, Lcn/jiguang/analytics/page/PushSA;->latestPauseTime:J
invoke-static {v4, v5}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v4
invoke-virtual {v3, v4}, Lcn/jiguang/g/a;->a(Ljava/lang/Object;)Lcn/jiguang/g/a;
move-result-object v3
aput-object v3, v0, v2
const/4 v2, 0x1
invoke-static {}, Lcn/jiguang/g/a;->p()Lcn/jiguang/g/a;
move-result-object v3
iget-wide v4, p0, Lcn/jiguang/analytics/page/PushSA;->latestPauseTime:J
invoke-static {v4, v5}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v4
invoke-virtual {v3, v4}, Lcn/jiguang/g/a;->a(Ljava/lang/Object;)Lcn/jiguang/g/a;
move-result-object v3
aput-object v3, v0, v2
invoke-static {p1, v0}, Lcn/jiguang/g/b;->a(Landroid/content/Context;[Lcn/jiguang/g/a;)V
invoke-direct {p0, p1}, Lcn/jiguang/analytics/page/PushSA;->getFlowCache(Landroid/content/Context;)Lorg/json/JSONObject;
move-result-object v0
if-nez v0, :cond_39
new-instance v0, Lorg/json/JSONObject;
invoke-direct {v0}, Lorg/json/JSONObject;-><init>()V
:try_end_39
.catchall {:try_start_7 .. :try_end_39} :catchall_44
:cond_39
:try_start_39
invoke-direct {p0, v0, p1}, Lcn/jiguang/analytics/page/PushSA;->updateFlowInfo(Lorg/json/JSONObject;Landroid/content/Context;)V
:try_end_3c
.catch Ljava/lang/Exception; {:try_start_39 .. :try_end_3c} :catch_47
.catchall {:try_start_39 .. :try_end_3c} :catchall_44
:goto_3c
:try_start_3c
invoke-direct {p0, v0}, Lcn/jiguang/analytics/page/PushSA;->updateFlowCache(Lorg/json/JSONObject;)V
invoke-direct {p0, p1, v0}, Lcn/jiguang/analytics/page/PushSA;->saveCurrentLog(Landroid/content/Context;Lorg/json/JSONObject;)V
monitor-exit v1
goto :goto_2
:catchall_44
move-exception v0
monitor-exit v1
:try_end_46
.catchall {:try_start_3c .. :try_end_46} :catchall_44
throw v0
:catch_47
move-exception v2
goto :goto_3c
.end method
.method private sendLogRoutine(Landroid/content/Context;)V
.registers 6
invoke-direct {p0, p1}, Lcn/jiguang/analytics/page/PushSA;->isNewSession(Landroid/content/Context;)Z
move-result v0
if-eqz v0, :cond_4a
const-string v0, "PushSA"
const-string v1, "new statistics session"
invoke-static {v0, v1}, Lcn/jiguang/ay/c;->e(Ljava/lang/String;Ljava/lang/String;)V
new-instance v0, Lorg/json/JSONArray;
invoke-direct {v0}, Lorg/json/JSONArray;-><init>()V
iget-wide v2, p0, Lcn/jiguang/analytics/page/PushSA;->latestResumeTime:J
invoke-direct {p0, p1, v2, v3}, Lcn/jiguang/analytics/page/PushSA;->createNewSession(Landroid/content/Context;J)Lorg/json/JSONObject;
move-result-object v1
if-eqz v1, :cond_1d
invoke-virtual {v0, v1}, Lorg/json/JSONArray;->put(Ljava/lang/Object;)Lorg/json/JSONArray;
:cond_1d
iget-object v1, p0, Lcn/jiguang/analytics/page/PushSA;->cur_session_file_lock:Ljava/lang/Object;
monitor-enter v1
:try_start_20
invoke-direct {p0, p1}, Lcn/jiguang/analytics/page/PushSA;->getFlowCache(Landroid/content/Context;)Lorg/json/JSONObject;
move-result-object v2
if-eqz v2, :cond_37
invoke-virtual {v2}, Lorg/json/JSONObject;->length()I
:try_end_29
.catchall {:try_start_20 .. :try_end_29} :catchall_47
move-result v3
if-lez v3, :cond_37
:try_start_2c
const-string v3, "active_terminate"
invoke-static {p1, v2, v3}, Lcn/jiguang/d/a;->a(Landroid/content/Context;Lorg/json/JSONObject;Ljava/lang/String;)Lorg/json/JSONObject;
:try_end_31
.catch Ljava/lang/Exception; {:try_start_2c .. :try_end_31} :catch_57
.catchall {:try_start_2c .. :try_end_31} :catchall_47
:goto_31
:try_start_31
invoke-direct {p0, p1}, Lcn/jiguang/analytics/page/PushSA;->clearCurrentLogFile(Landroid/content/Context;)V
const/4 v3, 0x0
iput-object v3, p0, Lcn/jiguang/analytics/page/PushSA;->flow_cache:Lorg/json/JSONObject;
:cond_37
monitor-exit v1
:try_end_38
.catchall {:try_start_31 .. :try_end_38} :catchall_47
if-eqz v2, :cond_43
invoke-virtual {v2}, Lorg/json/JSONObject;->length()I
move-result v1
if-lez v1, :cond_43
invoke-virtual {v0, v2}, Lorg/json/JSONArray;->put(Ljava/lang/Object;)Lorg/json/JSONArray;
:cond_43
invoke-static {p1, v0}, Lcn/jiguang/d/a;->a(Landroid/content/Context;Ljava/lang/Object;)V
:goto_46
return-void
:catchall_47
move-exception v0
:try_start_48
monitor-exit v1
:try_end_49
.catchall {:try_start_48 .. :try_end_49} :catchall_47
throw v0
:cond_4a
invoke-static {}, Lcn/jiguang/g/a;->r()Lcn/jiguang/g/a;
move-result-object v0
invoke-static {p1, v0}, Lcn/jiguang/g/b;->b(Landroid/content/Context;Lcn/jiguang/g/a;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/String;
iput-object v0, p0, Lcn/jiguang/analytics/page/PushSA;->cur_session_id:Ljava/lang/String;
goto :goto_46
:catch_57
move-exception v3
goto :goto_31
.end method
.method private updateFlowCache(Lorg/json/JSONObject;)V
.registers 2
iput-object p1, p0, Lcn/jiguang/analytics/page/PushSA;->flow_cache:Lorg/json/JSONObject;
return-void
.end method
.method private updateFlowInfo(Lorg/json/JSONObject;Landroid/content/Context;)V
.registers 13
const-wide/16 v6, 0x0
const-wide/16 v8, 0x3e8
invoke-static {}, Lcn/jiguang/g/a;->o()Lcn/jiguang/g/a;
move-result-object v0
invoke-static {p2, v0}, Lcn/jiguang/g/b;->a(Landroid/content/Context;Lcn/jiguang/g/a;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/Long;
invoke-virtual {v0}, Ljava/lang/Long;->longValue()J
move-result-wide v2
const-wide/16 v0, 0xa
cmp-long v4, v2, v6
if-gtz v4, :cond_54
iget-wide v2, p0, Lcn/jiguang/analytics/page/PushSA;->latestPauseTime:J
iget-wide v4, p0, Lcn/jiguang/analytics/page/PushSA;->tempTimelong:J
sub-long/2addr v2, v4
cmp-long v4, v2, v6
if-lez v4, :cond_23
div-long v0, v2, v8
:cond_23
const/4 v2, 0x1
new-array v2, v2, [Lcn/jiguang/g/a;
const/4 v3, 0x0
invoke-static {}, Lcn/jiguang/g/a;->o()Lcn/jiguang/g/a;
move-result-object v4
iget-wide v6, p0, Lcn/jiguang/analytics/page/PushSA;->tempTimelong:J
invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v5
invoke-virtual {v4, v5}, Lcn/jiguang/g/a;->a(Ljava/lang/Object;)Lcn/jiguang/g/a;
move-result-object v4
aput-object v4, v2, v3
invoke-static {p2, v2}, Lcn/jiguang/g/b;->a(Landroid/content/Context;[Lcn/jiguang/g/a;)V
:goto_3a
const-string v2, "duration"
invoke-virtual {p1, v2, v0, v1}, Lorg/json/JSONObject;->put(Ljava/lang/String;J)Lorg/json/JSONObject;
const-string v0, "itime"
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v2
div-long/2addr v2, v8
invoke-virtual {p1, v0, v2, v3}, Lorg/json/JSONObject;->put(Ljava/lang/String;J)Lorg/json/JSONObject;
const-string v0, "session_id"
iget-object v1, p0, Lcn/jiguang/analytics/page/PushSA;->cur_session_id:Ljava/lang/String;
invoke-virtual {p1, v0, v1}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
invoke-direct {p0, p1}, Lcn/jiguang/analytics/page/PushSA;->wrapDate(Lorg/json/JSONObject;)V
return-void
:cond_54
iget-wide v0, p0, Lcn/jiguang/analytics/page/PushSA;->latestPauseTime:J
sub-long/2addr v0, v2
div-long/2addr v0, v8
goto :goto_3a
.end method
.method private wrapDate(Lorg/json/JSONObject;)V
.registers 5
invoke-static {}, Lcn/jiguang/f/b;->a()Ljava/lang/String;
move-result-object v0
const-string v1, "_"
invoke-virtual {v0, v1}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object v1
const/4 v2, 0x0
aget-object v1, v1, v2
const-string v2, "_"
invoke-virtual {v0, v2}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object v0
const/4 v2, 0x1
aget-object v0, v0, v2
const-string v2, "date"
invoke-virtual {p1, v2, v1}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
const-string v1, "time"
invoke-virtual {p1, v1, v0}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
return-void
.end method
# virtual methods
.method public getInterval()J
.registers 3
iget-wide v0, p0, Lcn/jiguang/analytics/page/PushSA;->interval:J
return-wide v0
.end method
.method public isStatEnable()Z
.registers 2
iget-boolean v0, p0, Lcn/jiguang/analytics/page/PushSA;->stat_enable:Z
return v0
.end method
.method public onFragmentPause(Landroid/content/Context;Ljava/lang/String;)V
.registers 7
iget-boolean v0, p0, Lcn/jiguang/analytics/page/PushSA;->activitySwitch:Z
if-nez v0, :cond_c
const-string v0, "PushSA"
const-string v1, "JCoreInterface.onPause() must be called after called JCoreInterface.onResume() in this Activity or Fragment"
invoke-static {v0, v1}, Lcn/jiguang/ay/c;->c(Ljava/lang/String;Ljava/lang/String;)V
:goto_b
return-void
:cond_c
const/4 v0, 0x0
iput-boolean v0, p0, Lcn/jiguang/analytics/page/PushSA;->activitySwitch:Z
iget-object v0, p0, Lcn/jiguang/analytics/page/PushSA;->cur_activity:Ljava/lang/String;
if-eqz v0, :cond_34
iget-object v0, p0, Lcn/jiguang/analytics/page/PushSA;->cur_activity:Ljava/lang/String;
invoke-virtual {v0, p2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_34
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
iput-wide v0, p0, Lcn/jiguang/analytics/page/PushSA;->latestPauseTime:J
invoke-virtual {p1}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object v0
:try_start_25
const-string v1, "FUTURE_TASK"
new-instance v2, Lcn/jiguang/analytics/page/PushSA$2;
const-string v3, "PushSA#onFragmentPause"
invoke-direct {v2, p0, v3, v0}, Lcn/jiguang/analytics/page/PushSA$2;-><init>(Lcn/jiguang/analytics/page/PushSA;Ljava/lang/String;Landroid/content/Context;)V
invoke-static {v1, v2}, Lcn/jiguang/bl/d;->a(Ljava/lang/String;Ljava/lang/Runnable;)V
:try_end_31
.catch Ljava/lang/Throwable; {:try_start_25 .. :try_end_31} :catch_32
goto :goto_b
:catch_32
move-exception v0
goto :goto_b
:cond_34
const-string v0, "PushSA"
const-string v1, "page name didn\'t match the last one passed by onResume"
invoke-static {v0, v1}, Lcn/jiguang/ay/c;->j(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_b
.end method
.method public onFragmentResume(Landroid/content/Context;Ljava/lang/String;)V
.registers 7
iget-boolean v0, p0, Lcn/jiguang/analytics/page/PushSA;->activitySwitch:Z
if-eqz v0, :cond_c
const-string v0, "PushSA"
const-string v1, "JCoreInterface.onResume() must be called after called JCoreInterface.onPause() in last Activity or Fragment"
invoke-static {v0, v1}, Lcn/jiguang/ay/c;->c(Ljava/lang/String;Ljava/lang/String;)V
:goto_b
return-void
:cond_c
const/4 v0, 0x1
iput-boolean v0, p0, Lcn/jiguang/analytics/page/PushSA;->activitySwitch:Z
iput-object p2, p0, Lcn/jiguang/analytics/page/PushSA;->cur_activity:Ljava/lang/String;
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
iput-wide v0, p0, Lcn/jiguang/analytics/page/PushSA;->latestResumeTime:J
invoke-virtual {p1}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object v0
:try_start_1b
const-string v1, "FUTURE_TASK"
new-instance v2, Lcn/jiguang/analytics/page/PushSA$1;
const-string v3, "PushSA#onFragmentResume"
invoke-direct {v2, p0, v3, v0}, Lcn/jiguang/analytics/page/PushSA$1;-><init>(Lcn/jiguang/analytics/page/PushSA;Ljava/lang/String;Landroid/content/Context;)V
invoke-static {v1, v2}, Lcn/jiguang/bl/d;->a(Ljava/lang/String;Ljava/lang/Runnable;)V
:try_end_27
.catch Ljava/lang/Throwable; {:try_start_1b .. :try_end_27} :catch_28
goto :goto_b
:catch_28
move-exception v0
goto :goto_b
.end method
.method public onKillProcess(Landroid/content/Context;)V
.registers 6
:try_start_0
iget-object v0, p0, Lcn/jiguang/analytics/page/PushSA;->cur_activity:Ljava/lang/String;
if-eqz v0, :cond_1e
iget-boolean v0, p0, Lcn/jiguang/analytics/page/PushSA;->activitySwitch:Z
if-eqz v0, :cond_1e
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
iput-wide v0, p0, Lcn/jiguang/analytics/page/PushSA;->latestPauseTime:J
invoke-virtual {p1}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
:try_end_11
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_11} :catch_1f
move-result-object v0
:try_start_12
const-string v1, "FUTURE_TASK"
new-instance v2, Lcn/jiguang/analytics/page/PushSA$3;
const-string v3, "PushSA#onKillProcess"
invoke-direct {v2, p0, v3, v0}, Lcn/jiguang/analytics/page/PushSA$3;-><init>(Lcn/jiguang/analytics/page/PushSA;Ljava/lang/String;Landroid/content/Context;)V
invoke-static {v1, v2}, Lcn/jiguang/bl/d;->a(Ljava/lang/String;Ljava/lang/Runnable;)V
:try_end_1e
.catch Ljava/lang/Throwable; {:try_start_12 .. :try_end_1e} :catch_21
.catch Ljava/lang/Exception; {:try_start_12 .. :try_end_1e} :catch_1f
:cond_1e
:goto_1e
return-void
:catch_1f
move-exception v0
goto :goto_1e
:catch_21
move-exception v0
goto :goto_1e
.end method
.method public onPause(Landroid/content/Context;)V
.registers 8
const/4 v4, 0x1
const/4 v3, 0x0
const-string v2, "onPause"
invoke-direct {p0, p1, v2}, Lcn/jiguang/analytics/page/PushSA;->invokeCheck(Landroid/content/Context;Ljava/lang/String;)Z
move-result v2
if-nez v2, :cond_b
:cond_a
:goto_a
return-void
:cond_b
sput-boolean v4, Lcn/jiguang/analytics/page/PushSA;->isOnPauseInvoke:Z
:try_start_d
move-object v0, p1
check-cast v0, Landroid/app/TabActivity;
move-object v2, v0
const/4 v2, 0x1
iput-boolean v2, p0, Lcn/jiguang/analytics/page/PushSA;->activitySwitch:Z
:try_end_14
.catch Ljava/lang/ClassCastException; {:try_start_d .. :try_end_14} :catch_57
.catch Ljava/lang/Exception; {:try_start_d .. :try_end_14} :catch_4a
:goto_14
iget-boolean v2, p0, Lcn/jiguang/analytics/page/PushSA;->activitySwitch:Z
if-eqz v2, :cond_a
iput-boolean v3, p0, Lcn/jiguang/analytics/page/PushSA;->activitySwitch:Z
iget-object v2, p0, Lcn/jiguang/analytics/page/PushSA;->cur_activity:Ljava/lang/String;
if-eqz v2, :cond_4f
iget-object v2, p0, Lcn/jiguang/analytics/page/PushSA;->cur_activity:Ljava/lang/String;
invoke-virtual {p1}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_4f
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v2
iput-wide v2, p0, Lcn/jiguang/analytics/page/PushSA;->latestPauseTime:J
iget-wide v2, p0, Lcn/jiguang/analytics/page/PushSA;->latestResumeTime:J
iput-wide v2, p0, Lcn/jiguang/analytics/page/PushSA;->tempTimelong:J
:try_start_38
invoke-virtual {p1}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object v2
const-string v3, "FUTURE_TASK"
new-instance v4, Lcn/jiguang/analytics/page/PushSA$a;
const/4 v5, 0x0
invoke-direct {v4, v5, v2, p0}, Lcn/jiguang/analytics/page/PushSA$a;-><init>(ZLandroid/content/Context;Lcn/jiguang/analytics/page/PushSA;)V
invoke-static {v3, v4}, Lcn/jiguang/bl/d;->a(Ljava/lang/String;Ljava/lang/Runnable;)V
:try_end_47
.catch Ljava/lang/Throwable; {:try_start_38 .. :try_end_47} :catch_48
goto :goto_a
:catch_48
move-exception v2
goto :goto_a
:catch_4a
move-exception v2
invoke-virtual {v2}, Ljava/lang/Exception;->printStackTrace()V
goto :goto_14
:cond_4f
const-string v2, "PushSA"
const-string v3, "the activity pass by onPause didn\'t match last one passed by onResume"
invoke-static {v2, v3}, Lcn/jiguang/ay/c;->e(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_a
:catch_57
move-exception v2
goto :goto_14
.end method
.method public onResume(Landroid/content/Context;)V
.registers 8
const/4 v3, 0x1
const-string v2, "onResume"
invoke-direct {p0, p1, v2}, Lcn/jiguang/analytics/page/PushSA;->invokeCheck(Landroid/content/Context;Ljava/lang/String;)Z
move-result v2
if-nez v2, :cond_a
:cond_9
:goto_9
return-void
:cond_a
sput-boolean v3, Lcn/jiguang/analytics/page/PushSA;->isOnResumeInvoke:Z
:try_start_c
move-object v0, p1
check-cast v0, Landroid/app/TabActivity;
move-object v2, v0
const/4 v2, 0x0
iput-boolean v2, p0, Lcn/jiguang/analytics/page/PushSA;->activitySwitch:Z
:try_end_13
.catch Ljava/lang/ClassCastException; {:try_start_c .. :try_end_13} :catch_3d
.catch Ljava/lang/Exception; {:try_start_c .. :try_end_13} :catch_3b
:goto_13
iget-boolean v2, p0, Lcn/jiguang/analytics/page/PushSA;->activitySwitch:Z
if-nez v2, :cond_9
iput-boolean v3, p0, Lcn/jiguang/analytics/page/PushSA;->activitySwitch:Z
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v2
iput-wide v2, p0, Lcn/jiguang/analytics/page/PushSA;->latestResumeTime:J
invoke-virtual {p1}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v2
iput-object v2, p0, Lcn/jiguang/analytics/page/PushSA;->cur_activity:Ljava/lang/String;
:try_start_29
invoke-virtual {p1}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object v2
const-string v3, "FUTURE_TASK"
new-instance v4, Lcn/jiguang/analytics/page/PushSA$a;
const/4 v5, 0x1
invoke-direct {v4, v5, v2, p0}, Lcn/jiguang/analytics/page/PushSA$a;-><init>(ZLandroid/content/Context;Lcn/jiguang/analytics/page/PushSA;)V
invoke-static {v3, v4}, Lcn/jiguang/bl/d;->a(Ljava/lang/String;Ljava/lang/Runnable;)V
:try_end_38
.catch Ljava/lang/Throwable; {:try_start_29 .. :try_end_38} :catch_39
goto :goto_9
:catch_39
move-exception v2
goto :goto_9
:catch_3b
move-exception v2
goto :goto_13
:catch_3d
move-exception v2
goto :goto_13
.end method
.method public setInterval(J)V
.registers 4
iput-wide p1, p0, Lcn/jiguang/analytics/page/PushSA;->interval:J
return-void
.end method
.method public setStatEnable(Z)V
.registers 2
iput-boolean p1, p0, Lcn/jiguang/analytics/page/PushSA;->stat_enable:Z
return-void
.end method