Statistics.smali
.class public Lio/rong/imlib/statistics/Statistics;
.super Ljava/lang/Object;
.source "Statistics.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lio/rong/imlib/statistics/Statistics$SingletonHolder;,
Lio/rong/imlib/statistics/Statistics$CountlyMessagingMode;
}
.end annotation
# static fields
.field public static final COUNTLY_SDK_VERSION_STRING:Ljava/lang/String; = "15.06"
.field public static final DEFAULT_APP_VERSION:Ljava/lang/String; = "1.0"
.field private static final EVENT_QUEUE_SIZE_THRESHOLD:I = 0xa
.field public static final TAG:Ljava/lang/String; = "Statistics"
.field protected static publicKeyPinCertificates:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List<",
"Ljava/lang/String;",
">;"
}
.end annotation
.end field
# instance fields
.field private activityCount_:I
.field private connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
.field private context_:Landroid/content/Context;
.field private deviceId_Manager_:Lio/rong/imlib/statistics/DeviceId;
.field private disableUpdateSessionRequests_:Z
.field private enableLogging_:Z
.field private eventQueue_:Lio/rong/imlib/statistics/EventQueue;
.field private messagingMode_:Lio/rong/imlib/statistics/Statistics$CountlyMessagingMode;
.field private prevSessionDurationStartTime_:J
.field private timerService_:Ljava/util/concurrent/ScheduledExecutorService;
# direct methods
.method constructor <init>()V
.registers 2
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 2
new-instance v0, Lio/rong/imlib/statistics/ConnectionQueue;
invoke-direct {v0}, Lio/rong/imlib/statistics/ConnectionQueue;-><init>()V
iput-object v0, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
return-void
.end method
.method static synthetic access$000(Lio/rong/imlib/statistics/Statistics;)Lio/rong/imlib/statistics/ConnectionQueue;
.registers 1
.line 1
iget-object p0, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
return-object p0
.end method
.method static currentTimestamp()I
.registers 4
.line 1
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
const-wide/16 v2, 0x3e8
div-long/2addr v0, v2
long-to-int v1, v0
return v1
.end method
.method public static enablePublicKeyPinning(Ljava/util/List;)Lio/rong/imlib/statistics/Statistics;
.registers 1
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/List<",
"Ljava/lang/String;",
">;)",
"Lio/rong/imlib/statistics/Statistics;"
}
.end annotation
.line 1
sput-object p0, Lio/rong/imlib/statistics/Statistics;->publicKeyPinCertificates:Ljava/util/List;
.line 2
invoke-static {}, Lio/rong/imlib/statistics/Statistics;->sharedInstance()Lio/rong/imlib/statistics/Statistics;
move-result-object p0
return-object p0
.end method
.method static isValidURL(Ljava/lang/String;)Z
.registers 3
const/4 v0, 0x0
if-eqz p0, :cond_f
.line 1
invoke-virtual {p0}, Ljava/lang/String;->length()I
move-result v1
if-lez v1, :cond_f
.line 2
:try_start_9
new-instance v1, Ljava/net/URL;
invoke-direct {v1, p0}, Ljava/net/URL;-><init>(Ljava/lang/String;)V
:try_end_e
.catch Ljava/net/MalformedURLException; {:try_start_9 .. :try_end_e} :catch_f
const/4 v0, 0x1
:catch_f
:cond_f
return v0
.end method
.method public static sharedInstance()Lio/rong/imlib/statistics/Statistics;
.registers 1
.line 1
sget-object v0, Lio/rong/imlib/statistics/Statistics$SingletonHolder;->instance:Lio/rong/imlib/statistics/Statistics;
return-object v0
.end method
# virtual methods
.method public declared-synchronized addCrashLog(Ljava/lang/String;)Lio/rong/imlib/statistics/Statistics;
.registers 2
monitor-enter p0
.line 1
:try_start_1
invoke-static {p1}, Lio/rong/imlib/statistics/CrashDetails;->addLog(Ljava/lang/String;)V
:try_end_4
.catchall {:try_start_1 .. :try_end_4} :catchall_6
.line 2
monitor-exit p0
return-object p0
:catchall_6
move-exception p1
monitor-exit p0
throw p1
.end method
.method public declared-synchronized enableCrashReporting()Lio/rong/imlib/statistics/Statistics;
.registers 3
monitor-enter p0
.line 1
:try_start_1
invoke-static {}, Ljava/lang/Thread;->getDefaultUncaughtExceptionHandler()Ljava/lang/Thread$UncaughtExceptionHandler;
move-result-object v0
.line 2
new-instance v1, Lio/rong/imlib/statistics/Statistics$1;
invoke-direct {v1, p0, v0}, Lio/rong/imlib/statistics/Statistics$1;-><init>(Lio/rong/imlib/statistics/Statistics;Ljava/lang/Thread$UncaughtExceptionHandler;)V
.line 3
invoke-static {v1}, Ljava/lang/Thread;->setDefaultUncaughtExceptionHandler(Ljava/lang/Thread$UncaughtExceptionHandler;)V
:try_end_d
.catchall {:try_start_1 .. :try_end_d} :catchall_f
.line 4
monitor-exit p0
return-object p0
:catchall_f
move-exception v0
monitor-exit p0
throw v0
.end method
.method getActivityCount()I
.registers 2
.line 1
iget v0, p0, Lio/rong/imlib/statistics/Statistics;->activityCount_:I
return v0
.end method
.method getConnectionQueue()Lio/rong/imlib/statistics/ConnectionQueue;
.registers 2
.line 1
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
return-object v0
.end method
.method getDisableUpdateSessionRequests()Z
.registers 2
.line 1
iget-boolean v0, p0, Lio/rong/imlib/statistics/Statistics;->disableUpdateSessionRequests_:Z
return v0
.end method
.method getEventQueue()Lio/rong/imlib/statistics/EventQueue;
.registers 2
.line 1
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->eventQueue_:Lio/rong/imlib/statistics/EventQueue;
return-object v0
.end method
.method getPrevSessionDurationStartTime()J
.registers 3
.line 1
iget-wide v0, p0, Lio/rong/imlib/statistics/Statistics;->prevSessionDurationStartTime_:J
return-wide v0
.end method
.method getTimerService()Ljava/util/concurrent/ExecutorService;
.registers 2
.line 1
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->timerService_:Ljava/util/concurrent/ScheduledExecutorService;
return-object v0
.end method
.method public declared-synchronized halt()V
.registers 3
monitor-enter p0
const/4 v0, 0x0
.line 1
:try_start_2
iput-object v0, p0, Lio/rong/imlib/statistics/Statistics;->eventQueue_:Lio/rong/imlib/statistics/EventQueue;
.line 2
iget-object v1, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {v1}, Lio/rong/imlib/statistics/ConnectionQueue;->getCountlyStore()Lio/rong/imlib/statistics/StatisticsStore;
move-result-object v1
if-eqz v1, :cond_f
.line 3
invoke-virtual {v1}, Lio/rong/imlib/statistics/StatisticsStore;->clear()V
.line 4
:cond_f
iget-object v1, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {v1, v0}, Lio/rong/imlib/statistics/ConnectionQueue;->setContext(Landroid/content/Context;)V
.line 5
iget-object v1, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {v1, v0}, Lio/rong/imlib/statistics/ConnectionQueue;->setServerURL(Ljava/lang/String;)V
.line 6
iget-object v1, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {v1, v0}, Lio/rong/imlib/statistics/ConnectionQueue;->setAppKey(Ljava/lang/String;)V
.line 7
iget-object v1, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {v1, v0}, Lio/rong/imlib/statistics/ConnectionQueue;->setCountlyStore(Lio/rong/imlib/statistics/StatisticsStore;)V
const-wide/16 v0, 0x0
.line 8
iput-wide v0, p0, Lio/rong/imlib/statistics/Statistics;->prevSessionDurationStartTime_:J
const/4 v0, 0x0
.line 9
iput v0, p0, Lio/rong/imlib/statistics/Statistics;->activityCount_:I
:try_end_2a
.catchall {:try_start_2 .. :try_end_2a} :catchall_2c
.line 10
monitor-exit p0
return-void
:catchall_2c
move-exception v0
monitor-exit p0
throw v0
.end method
.method public init(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)Lio/rong/imlib/statistics/Statistics;
.registers 11
.line 1
invoke-static {}, Lio/rong/imlib/statistics/OpenUDIDAdapter;->isOpenUDIDAvailable()Z
move-result v0
if-eqz v0, :cond_9
sget-object v0, Lio/rong/imlib/statistics/DeviceId$Type;->OPEN_UDID:Lio/rong/imlib/statistics/DeviceId$Type;
goto :goto_b
:cond_9
sget-object v0, Lio/rong/imlib/statistics/DeviceId$Type;->ADVERTISING_ID:Lio/rong/imlib/statistics/DeviceId$Type;
:goto_b
move-object v6, v0
const/4 v5, 0x0
move-object v1, p0
move-object v2, p1
move-object v3, p2
move-object v4, p3
invoke-virtual/range {v1 .. v6}, Lio/rong/imlib/statistics/Statistics;->init(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Lio/rong/imlib/statistics/DeviceId$Type;)Lio/rong/imlib/statistics/Statistics;
move-result-object p1
return-object p1
.end method
.method public init(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Lio/rong/imlib/statistics/Statistics;
.registers 11
const/4 v5, 0x0
move-object v0, p0
move-object v1, p1
move-object v2, p2
move-object v3, p3
move-object v4, p4
.line 2
invoke-virtual/range {v0 .. v5}, Lio/rong/imlib/statistics/Statistics;->init(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Lio/rong/imlib/statistics/DeviceId$Type;)Lio/rong/imlib/statistics/Statistics;
move-result-object p1
return-object p1
.end method
.method public declared-synchronized init(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Lio/rong/imlib/statistics/DeviceId$Type;)Lio/rong/imlib/statistics/Statistics;
.registers 7
monitor-enter p0
if-eqz p1, :cond_ec
.line 3
:try_start_3
invoke-static {p2}, Lio/rong/imlib/statistics/Statistics;->isValidURL(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_e2
if-eqz p3, :cond_da
.line 4
invoke-virtual {p3}, Ljava/lang/String;->length()I
move-result v0
if-eqz v0, :cond_da
if-eqz p4, :cond_22
.line 5
invoke-virtual {p4}, Ljava/lang/String;->length()I
move-result v0
if-eqz v0, :cond_1a
goto :goto_22
.line 6
:cond_1a
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "valid deviceID is required"
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
:cond_22
:goto_22
if-nez p4, :cond_37
if-nez p5, :cond_37
.line 7
invoke-static {}, Lio/rong/imlib/statistics/OpenUDIDAdapter;->isOpenUDIDAvailable()Z
move-result v0
if-eqz v0, :cond_2f
sget-object p5, Lio/rong/imlib/statistics/DeviceId$Type;->OPEN_UDID:Lio/rong/imlib/statistics/DeviceId$Type;
goto :goto_37
.line 8
:cond_2f
invoke-static {}, Lio/rong/imlib/statistics/AdvertisingIdAdapter;->isAdvertisingIdAvailable()Z
move-result v0
if-eqz v0, :cond_37
sget-object p5, Lio/rong/imlib/statistics/DeviceId$Type;->ADVERTISING_ID:Lio/rong/imlib/statistics/DeviceId$Type;
:cond_37
:goto_37
if-nez p4, :cond_4c
.line 9
sget-object v0, Lio/rong/imlib/statistics/DeviceId$Type;->OPEN_UDID:Lio/rong/imlib/statistics/DeviceId$Type;
if-ne p5, v0, :cond_4c
invoke-static {}, Lio/rong/imlib/statistics/OpenUDIDAdapter;->isOpenUDIDAvailable()Z
move-result v0
if-eqz v0, :cond_44
goto :goto_4c
.line 10
:cond_44
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "valid deviceID is required because OpenUDID is not available"
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
:cond_4c
:goto_4c
if-nez p4, :cond_61
.line 11
sget-object v0, Lio/rong/imlib/statistics/DeviceId$Type;->ADVERTISING_ID:Lio/rong/imlib/statistics/DeviceId$Type;
if-ne p5, v0, :cond_61
invoke-static {}, Lio/rong/imlib/statistics/AdvertisingIdAdapter;->isAdvertisingIdAvailable()Z
move-result v0
if-eqz v0, :cond_59
goto :goto_61
.line 12
:cond_59
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "valid deviceID is required because Advertising ID is not available (you need to include Google Play services 4.0+ into your project)"
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
.line 13
:cond_61
:goto_61
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->eventQueue_:Lio/rong/imlib/statistics/EventQueue;
if-eqz v0, :cond_92
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {v0}, Lio/rong/imlib/statistics/ConnectionQueue;->getServerURL()Ljava/lang/String;
move-result-object v0
invoke-virtual {v0, p2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_8a
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
.line 14
invoke-virtual {v0}, Lio/rong/imlib/statistics/ConnectionQueue;->getAppKey()Ljava/lang/String;
move-result-object v0
invoke-virtual {v0, p3}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_8a
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
.line 15
invoke-virtual {v0}, Lio/rong/imlib/statistics/ConnectionQueue;->getDeviceId()Lio/rong/imlib/statistics/DeviceId;
move-result-object v0
invoke-static {p4, p5, v0}, Lio/rong/imlib/statistics/DeviceId;->deviceIDEqualsNullSafe(Ljava/lang/String;Lio/rong/imlib/statistics/DeviceId$Type;Lio/rong/imlib/statistics/DeviceId;)Z
move-result v0
if-eqz v0, :cond_8a
goto :goto_92
.line 16
:cond_8a
new-instance p1, Ljava/lang/IllegalStateException;
const-string p2, "Statistics cannot be reinitialized with different values"
invoke-direct {p1, p2}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw p1
.line 17
:cond_92
:goto_92
invoke-static {}, Lio/rong/imlib/statistics/MessagingAdapter;->isMessagingAvailable()Z
move-result v0
if-eqz v0, :cond_9b
.line 18
invoke-static {p1, p2, p3, p4, p5}, Lio/rong/imlib/statistics/MessagingAdapter;->storeConfiguration(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Lio/rong/imlib/statistics/DeviceId$Type;)Z
.line 19
:cond_9b
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->eventQueue_:Lio/rong/imlib/statistics/EventQueue;
if-nez v0, :cond_d1
if-eqz p4, :cond_a8
.line 20
new-instance p5, Lio/rong/imlib/statistics/DeviceId;
invoke-direct {p5, p4}, Lio/rong/imlib/statistics/DeviceId;-><init>(Ljava/lang/String;)V
move-object p4, p5
goto :goto_ad
.line 21
:cond_a8
new-instance p4, Lio/rong/imlib/statistics/DeviceId;
invoke-direct {p4, p5}, Lio/rong/imlib/statistics/DeviceId;-><init>(Lio/rong/imlib/statistics/DeviceId$Type;)V
.line 22
:goto_ad
new-instance p5, Lio/rong/imlib/statistics/StatisticsStore;
invoke-direct {p5, p1}, Lio/rong/imlib/statistics/StatisticsStore;-><init>(Landroid/content/Context;)V
const/4 v0, 0x1
.line 23
invoke-virtual {p4, p1, p5, v0}, Lio/rong/imlib/statistics/DeviceId;->init(Landroid/content/Context;Lio/rong/imlib/statistics/StatisticsStore;Z)V
.line 24
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {v0, p2}, Lio/rong/imlib/statistics/ConnectionQueue;->setServerURL(Ljava/lang/String;)V
.line 25
iget-object p2, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {p2, p3}, Lio/rong/imlib/statistics/ConnectionQueue;->setAppKey(Ljava/lang/String;)V
.line 26
iget-object p2, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {p2, p5}, Lio/rong/imlib/statistics/ConnectionQueue;->setCountlyStore(Lio/rong/imlib/statistics/StatisticsStore;)V
.line 27
iget-object p2, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {p2, p4}, Lio/rong/imlib/statistics/ConnectionQueue;->setDeviceId(Lio/rong/imlib/statistics/DeviceId;)V
.line 28
new-instance p2, Lio/rong/imlib/statistics/EventQueue;
invoke-direct {p2, p5}, Lio/rong/imlib/statistics/EventQueue;-><init>(Lio/rong/imlib/statistics/StatisticsStore;)V
iput-object p2, p0, Lio/rong/imlib/statistics/Statistics;->eventQueue_:Lio/rong/imlib/statistics/EventQueue;
.line 29
:cond_d1
iput-object p1, p0, Lio/rong/imlib/statistics/Statistics;->context_:Landroid/content/Context;
.line 30
iget-object p2, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {p2, p1}, Lio/rong/imlib/statistics/ConnectionQueue;->setContext(Landroid/content/Context;)V
:try_end_d8
.catchall {:try_start_3 .. :try_end_d8} :catchall_ea
.line 31
monitor-exit p0
return-object p0
.line 32
:cond_da
:try_start_da
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "valid appKey is required"
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
.line 33
:cond_e2
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "valid serverURL is required"
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
:catchall_ea
move-exception p1
goto :goto_f4
.line 34
:cond_ec
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "valid context is required"
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
:try_end_f4
.catchall {:try_start_da .. :try_end_f4} :catchall_ea
:goto_f4
monitor-exit p0
throw p1
.end method
.method public declared-synchronized isInitialized()Z
.registers 2
monitor-enter p0
.line 1
:try_start_1
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->eventQueue_:Lio/rong/imlib/statistics/EventQueue;
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_a
if-eqz v0, :cond_7
const/4 v0, 0x1
goto :goto_8
:cond_7
const/4 v0, 0x0
:goto_8
monitor-exit p0
return v0
:catchall_a
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized isLoggingEnabled()Z
.registers 2
monitor-enter p0
.line 1
:try_start_1
iget-boolean v0, p0, Lio/rong/imlib/statistics/Statistics;->enableLogging_:Z
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_5
monitor-exit p0
return v0
:catchall_5
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized logException(Ljava/lang/Exception;)Lio/rong/imlib/statistics/Statistics;
.registers 4
monitor-enter p0
.line 1
:try_start_1
new-instance v0, Ljava/io/StringWriter;
invoke-direct {v0}, Ljava/io/StringWriter;-><init>()V
.line 2
new-instance v1, Ljava/io/PrintWriter;
invoke-direct {v1, v0}, Ljava/io/PrintWriter;-><init>(Ljava/io/Writer;)V
.line 3
invoke-virtual {p1, v1}, Ljava/lang/Exception;->printStackTrace(Ljava/io/PrintWriter;)V
.line 4
iget-object p1, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {v0}, Ljava/io/StringWriter;->toString()Ljava/lang/String;
move-result-object v0
const/4 v1, 0x1
invoke-virtual {p1, v0, v1}, Lio/rong/imlib/statistics/ConnectionQueue;->sendCrashReport(Ljava/lang/String;Z)V
:try_end_18
.catchall {:try_start_1 .. :try_end_18} :catchall_1a
.line 5
monitor-exit p0
return-object p0
:catchall_1a
move-exception p1
monitor-exit p0
throw p1
.end method
.method public onRegistrationId(Ljava/lang/String;)V
.registers 4
.line 1
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
iget-object v1, p0, Lio/rong/imlib/statistics/Statistics;->messagingMode_:Lio/rong/imlib/statistics/Statistics$CountlyMessagingMode;
invoke-virtual {v0, p1, v1}, Lio/rong/imlib/statistics/ConnectionQueue;->tokenSession(Ljava/lang/String;Lio/rong/imlib/statistics/Statistics$CountlyMessagingMode;)V
return-void
.end method
.method public declared-synchronized onStart()V
.registers 5
monitor-enter p0
.line 1
:try_start_1
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->eventQueue_:Lio/rong/imlib/statistics/EventQueue;
if-eqz v0, :cond_50
.line 2
iget v0, p0, Lio/rong/imlib/statistics/Statistics;->activityCount_:I
const/4 v1, 0x1
add-int/2addr v0, v1
iput v0, p0, Lio/rong/imlib/statistics/Statistics;->activityCount_:I
.line 3
iget v0, p0, Lio/rong/imlib/statistics/Statistics;->activityCount_:I
if-ne v0, v1, :cond_19
const-string v0, "Statistics"
const-string v1, "start"
.line 4
invoke-static {v0, v1}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
.line 5
invoke-virtual {p0}, Lio/rong/imlib/statistics/Statistics;->onStartHelper()V
.line 6
:cond_19
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->context_:Landroid/content/Context;
invoke-static {v0}, Lio/rong/imlib/statistics/ReferrerReceiver;->getReferrer(Landroid/content/Context;)Ljava/lang/String;
move-result-object v0
.line 7
invoke-static {}, Lio/rong/imlib/statistics/Statistics;->sharedInstance()Lio/rong/imlib/statistics/Statistics;
move-result-object v1
invoke-virtual {v1}, Lio/rong/imlib/statistics/Statistics;->isLoggingEnabled()Z
move-result v1
if-eqz v1, :cond_3f
const-string v1, "Statistics"
.line 8
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Checking referrer: "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v1, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
:cond_3f
if-eqz v0, :cond_4b
.line 9
iget-object v1, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {v1, v0}, Lio/rong/imlib/statistics/ConnectionQueue;->sendReferrerData(Ljava/lang/String;)V
.line 10
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->context_:Landroid/content/Context;
invoke-static {v0}, Lio/rong/imlib/statistics/ReferrerReceiver;->deleteReferrer(Landroid/content/Context;)V
.line 11
:cond_4b
invoke-static {}, Lio/rong/imlib/statistics/CrashDetails;->inForeground()V
:try_end_4e
.catchall {:try_start_1 .. :try_end_4e} :catchall_58
.line 12
monitor-exit p0
return-void
.line 13
:cond_50
:try_start_50
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "init must be called before onStart"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_58
.catchall {:try_start_50 .. :try_end_58} :catchall_58
:catchall_58
move-exception v0
monitor-exit p0
throw v0
.end method
.method onStartHelper()V
.registers 3
.line 1
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v0
iput-wide v0, p0, Lio/rong/imlib/statistics/Statistics;->prevSessionDurationStartTime_:J
.line 2
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {v0}, Lio/rong/imlib/statistics/ConnectionQueue;->beginSession()V
return-void
.end method
.method public declared-synchronized onStop()V
.registers 3
monitor-enter p0
.line 1
:try_start_1
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->eventQueue_:Lio/rong/imlib/statistics/EventQueue;
if-eqz v0, :cond_23
.line 2
iget v0, p0, Lio/rong/imlib/statistics/Statistics;->activityCount_:I
if-eqz v0, :cond_1b
.line 3
iget v0, p0, Lio/rong/imlib/statistics/Statistics;->activityCount_:I
add-int/lit8 v0, v0, -0x1
iput v0, p0, Lio/rong/imlib/statistics/Statistics;->activityCount_:I
.line 4
iget v0, p0, Lio/rong/imlib/statistics/Statistics;->activityCount_:I
if-nez v0, :cond_16
.line 5
invoke-virtual {p0}, Lio/rong/imlib/statistics/Statistics;->onStopHelper()V
.line 6
:cond_16
invoke-static {}, Lio/rong/imlib/statistics/CrashDetails;->inBackground()V
:try_end_19
.catchall {:try_start_1 .. :try_end_19} :catchall_2b
.line 7
monitor-exit p0
return-void
.line 8
:cond_1b
:try_start_1b
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "must call onStart before onStop"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 9
:cond_23
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "init must be called before onStop"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_2b
.catchall {:try_start_1b .. :try_end_2b} :catchall_2b
:catchall_2b
move-exception v0
monitor-exit p0
throw v0
.end method
.method onStopHelper()V
.registers 3
.line 1
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {p0}, Lio/rong/imlib/statistics/Statistics;->roundedSecondsSinceLastSessionDurationUpdate()I
move-result v1
invoke-virtual {v0, v1}, Lio/rong/imlib/statistics/ConnectionQueue;->endSession(I)V
const-wide/16 v0, 0x0
.line 2
iput-wide v0, p0, Lio/rong/imlib/statistics/Statistics;->prevSessionDurationStartTime_:J
.line 3
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->eventQueue_:Lio/rong/imlib/statistics/EventQueue;
invoke-virtual {v0}, Lio/rong/imlib/statistics/EventQueue;->size()I
move-result v0
if-lez v0, :cond_20
.line 4
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
iget-object v1, p0, Lio/rong/imlib/statistics/Statistics;->eventQueue_:Lio/rong/imlib/statistics/EventQueue;
invoke-virtual {v1}, Lio/rong/imlib/statistics/EventQueue;->events()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Lio/rong/imlib/statistics/ConnectionQueue;->recordEvents(Ljava/lang/String;)V
:cond_20
return-void
.end method
.method declared-synchronized onTimer()V
.registers 6
monitor-enter p0
.line 1
:try_start_1
iget v0, p0, Lio/rong/imlib/statistics/Statistics;->activityCount_:I
const/4 v1, 0x1
const/4 v2, 0x0
if-lez v0, :cond_9
const/4 v0, 0x1
goto :goto_a
:cond_9
const/4 v0, 0x0
:goto_a
if-eqz v0, :cond_56
const-string v0, "Statistics"
.line 2
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "onTimer: update="
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-boolean v4, p0, Lio/rong/imlib/statistics/Statistics;->disableUpdateSessionRequests_:Z
if-nez v4, :cond_1d
goto :goto_1e
:cond_1d
const/4 v1, 0x0
:goto_1e
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
const-string v1, ", queue="
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lio/rong/imlib/statistics/Statistics;->eventQueue_:Lio/rong/imlib/statistics/EventQueue;
invoke-virtual {v1}, Lio/rong/imlib/statistics/EventQueue;->size()I
move-result v1
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 3
iget-boolean v0, p0, Lio/rong/imlib/statistics/Statistics;->disableUpdateSessionRequests_:Z
if-nez v0, :cond_43
.line 4
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {p0}, Lio/rong/imlib/statistics/Statistics;->roundedSecondsSinceLastSessionDurationUpdate()I
move-result v1
invoke-virtual {v0, v1}, Lio/rong/imlib/statistics/ConnectionQueue;->updateSession(I)V
.line 5
:cond_43
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->eventQueue_:Lio/rong/imlib/statistics/EventQueue;
invoke-virtual {v0}, Lio/rong/imlib/statistics/EventQueue;->size()I
move-result v0
if-lez v0, :cond_56
.line 6
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
iget-object v1, p0, Lio/rong/imlib/statistics/Statistics;->eventQueue_:Lio/rong/imlib/statistics/EventQueue;
invoke-virtual {v1}, Lio/rong/imlib/statistics/EventQueue;->events()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Lio/rong/imlib/statistics/ConnectionQueue;->recordEvents(Ljava/lang/String;)V
:try_end_56
.catchall {:try_start_1 .. :try_end_56} :catchall_58
.line 7
:cond_56
monitor-exit p0
return-void
:catchall_58
move-exception v0
monitor-exit p0
throw v0
.end method
.method public recordEvent(Ljava/lang/String;)V
.registers 8
const/4 v2, 0x0
const/4 v3, 0x1
const-wide/16 v4, 0x0
move-object v0, p0
move-object v1, p1
.line 1
invoke-virtual/range {v0 .. v5}, Lio/rong/imlib/statistics/Statistics;->recordEvent(Ljava/lang/String;Ljava/util/Map;ID)V
return-void
.end method
.method public recordEvent(Ljava/lang/String;I)V
.registers 9
const/4 v2, 0x0
const-wide/16 v4, 0x0
move-object v0, p0
move-object v1, p1
move v3, p2
.line 2
invoke-virtual/range {v0 .. v5}, Lio/rong/imlib/statistics/Statistics;->recordEvent(Ljava/lang/String;Ljava/util/Map;ID)V
return-void
.end method
.method public recordEvent(Ljava/lang/String;ID)V
.registers 11
const/4 v2, 0x0
move-object v0, p0
move-object v1, p1
move v3, p2
move-wide v4, p3
.line 3
invoke-virtual/range {v0 .. v5}, Lio/rong/imlib/statistics/Statistics;->recordEvent(Ljava/lang/String;Ljava/util/Map;ID)V
return-void
.end method
.method public declared-synchronized recordEvent(Ljava/lang/String;Ljava/util/Map;)V
.registers 8
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/lang/String;",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;)V"
}
.end annotation
monitor-enter p0
.line 18
:try_start_1
invoke-interface {p2}, Ljava/util/Map;->size()I
move-result v0
mul-int/lit8 v0, v0, 0x2
new-array v0, v0, [Ljava/lang/String;
const/4 v1, 0x0
.line 19
invoke-virtual {p0}, Lio/rong/imlib/statistics/Statistics;->isInitialized()Z
move-result v2
if-eqz v2, :cond_88
if-eqz p1, :cond_80
.line 20
invoke-virtual {p1}, Ljava/lang/String;->length()I
move-result v2
if-eqz v2, :cond_80
if-eqz p2, :cond_67
.line 21
invoke-interface {p2}, Ljava/util/Map;->keySet()Ljava/util/Set;
move-result-object v2
invoke-interface {v2}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v2
:goto_22
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v3
if-eqz v3, :cond_67
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/lang/String;
if-eqz v3, :cond_5f
.line 22
invoke-virtual {v3}, Ljava/lang/String;->length()I
move-result v4
if-eqz v4, :cond_5f
.line 23
invoke-interface {p2, v3}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v4
if-eqz v4, :cond_57
invoke-interface {p2, v3}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v4
check-cast v4, Ljava/lang/String;
invoke-virtual {v4}, Ljava/lang/String;->length()I
move-result v4
if-eqz v4, :cond_57
.line 24
aput-object v3, v0, v1
add-int/lit8 v1, v1, 0x1
.line 25
invoke-interface {p2, v3}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/lang/String;
aput-object v3, v0, v1
add-int/lit8 v1, v1, 0x1
goto :goto_22
.line 26
:cond_57
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "Countly event segmentation value cannot be null or empty"
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
.line 27
:cond_5f
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "Countly event segmentation key cannot be null or empty"
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
.line 28
:cond_67
new-instance p2, Lorg/json/JSONObject;
invoke-direct {p2}, Lorg/json/JSONObject;-><init>()V
.line 29
invoke-static {p2, v0}, Lio/rong/imlib/statistics/DeviceInfo;->fillJSONIfValuesNotEmpty(Lorg/json/JSONObject;[Ljava/lang/String;)V
.line 30
invoke-virtual {p2}, Lorg/json/JSONObject;->toString()Ljava/lang/String;
move-result-object p2
:try_end_73
.catchall {:try_start_1 .. :try_end_73} :catchall_90
:try_start_73
const-string v0, "UTF-8"
.line 31
invoke-static {p2, v0}, Ljava/net/URLEncoder;->encode(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object p2
:try_end_79
.catch Ljava/io/UnsupportedEncodingException; {:try_start_73 .. :try_end_79} :catch_79
.catchall {:try_start_73 .. :try_end_79} :catchall_90
.line 32
:catch_79
:try_start_79
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {v0, p1, p2}, Lio/rong/imlib/statistics/ConnectionQueue;->recordEvents(Ljava/lang/String;Ljava/lang/String;)V
:try_end_7e
.catchall {:try_start_79 .. :try_end_7e} :catchall_90
.line 33
monitor-exit p0
return-void
.line 34
:cond_80
:try_start_80
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "Valid Countly event key is required"
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
.line 35
:cond_88
new-instance p1, Ljava/lang/IllegalStateException;
const-string p2, "Countly.sharedInstance().init must be called before recordEvent"
invoke-direct {p1, p2}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw p1
:try_end_90
.catchall {:try_start_80 .. :try_end_90} :catchall_90
:catchall_90
move-exception p1
monitor-exit p0
goto :goto_94
:goto_93
throw p1
:goto_94
goto :goto_93
.end method
.method public recordEvent(Ljava/lang/String;Ljava/util/Map;I)V
.registers 10
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/lang/String;",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;I)V"
}
.end annotation
const-wide/16 v4, 0x0
move-object v0, p0
move-object v1, p1
move-object v2, p2
move v3, p3
.line 4
invoke-virtual/range {v0 .. v5}, Lio/rong/imlib/statistics/Statistics;->recordEvent(Ljava/lang/String;Ljava/util/Map;ID)V
return-void
.end method
.method public declared-synchronized recordEvent(Ljava/lang/String;Ljava/util/Map;ID)V
.registers 12
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/lang/String;",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;ID)V"
}
.end annotation
monitor-enter p0
.line 5
:try_start_1
invoke-virtual {p0}, Lio/rong/imlib/statistics/Statistics;->isInitialized()Z
move-result v0
if-eqz v0, :cond_71
if-eqz p1, :cond_69
.line 6
invoke-virtual {p1}, Ljava/lang/String;->length()I
move-result v0
if-eqz v0, :cond_69
const/4 v0, 0x1
if-lt p3, v0, :cond_61
if-eqz p2, :cond_53
.line 7
invoke-interface {p2}, Ljava/util/Map;->keySet()Ljava/util/Set;
move-result-object v0
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v0
:goto_1c
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_53
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
if-eqz v1, :cond_4b
.line 8
invoke-virtual {v1}, Ljava/lang/String;->length()I
move-result v2
if-eqz v2, :cond_4b
.line 9
invoke-interface {p2, v1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v2
if-eqz v2, :cond_43
invoke-interface {p2, v1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
invoke-virtual {v1}, Ljava/lang/String;->length()I
move-result v1
if-eqz v1, :cond_43
goto :goto_1c
.line 10
:cond_43
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "Statistics event segmentation value cannot be null or empty"
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
.line 11
:cond_4b
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "Statistics event segmentation key cannot be null or empty"
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
.line 12
:cond_53
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->eventQueue_:Lio/rong/imlib/statistics/EventQueue;
move-object v1, p1
move-object v2, p2
move v3, p3
move-wide v4, p4
invoke-virtual/range {v0 .. v5}, Lio/rong/imlib/statistics/EventQueue;->recordEvent(Ljava/lang/String;Ljava/util/Map;ID)V
.line 13
invoke-virtual {p0}, Lio/rong/imlib/statistics/Statistics;->sendEventsIfNeeded()V
:try_end_5f
.catchall {:try_start_1 .. :try_end_5f} :catchall_79
.line 14
monitor-exit p0
return-void
.line 15
:cond_61
:try_start_61
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "Statistics event count should be greater than zero"
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
.line 16
:cond_69
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "Valid Statistics event key is required"
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
.line 17
:cond_71
new-instance p1, Ljava/lang/IllegalStateException;
const-string p2, "Statistics.sharedInstance().init must be called before recordEvent"
invoke-direct {p1, p2}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw p1
:try_end_79
.catchall {:try_start_61 .. :try_end_79} :catchall_79
:catchall_79
move-exception p1
monitor-exit p0
goto :goto_7d
:goto_7c
throw p1
:goto_7d
goto :goto_7c
.end method
.method roundedSecondsSinceLastSessionDurationUpdate()I
.registers 5
.line 1
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v0
.line 2
iget-wide v2, p0, Lio/rong/imlib/statistics/Statistics;->prevSessionDurationStartTime_:J
sub-long v2, v0, v2
.line 3
iput-wide v0, p0, Lio/rong/imlib/statistics/Statistics;->prevSessionDurationStartTime_:J
long-to-double v0, v2
const-wide v2, 0x41cdcd6500000000L # 1.0E9
.line 4
invoke-static {v0, v1}, Ljava/lang/Double;->isNaN(D)Z
div-double/2addr v0, v2
invoke-static {v0, v1}, Ljava/lang/Math;->round(D)J
move-result-wide v0
long-to-int v1, v0
return v1
.end method
.method sendEventsIfNeeded()V
.registers 3
.line 1
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "sendEventsIfNeeded: queue="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lio/rong/imlib/statistics/Statistics;->eventQueue_:Lio/rong/imlib/statistics/EventQueue;
invoke-virtual {v1}, Lio/rong/imlib/statistics/EventQueue;->size()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
const-string v1, "Statistics"
invoke-static {v1, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 2
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->eventQueue_:Lio/rong/imlib/statistics/EventQueue;
invoke-virtual {v0}, Lio/rong/imlib/statistics/EventQueue;->size()I
move-result v0
const/16 v1, 0xa
if-lt v0, v1, :cond_31
.line 3
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
iget-object v1, p0, Lio/rong/imlib/statistics/Statistics;->eventQueue_:Lio/rong/imlib/statistics/EventQueue;
invoke-virtual {v1}, Lio/rong/imlib/statistics/EventQueue;->events()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Lio/rong/imlib/statistics/ConnectionQueue;->recordEvents(Ljava/lang/String;)V
:cond_31
return-void
.end method
.method setConnectionQueue(Lio/rong/imlib/statistics/ConnectionQueue;)V
.registers 2
.line 1
iput-object p1, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
return-void
.end method
.method public declared-synchronized setCustomCrashSegments(Ljava/util/Map;)Lio/rong/imlib/statistics/Statistics;
.registers 2
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;)",
"Lio/rong/imlib/statistics/Statistics;"
}
.end annotation
monitor-enter p0
if-eqz p1, :cond_a
.line 1
:try_start_3
invoke-static {p1}, Lio/rong/imlib/statistics/CrashDetails;->setCustomSegments(Ljava/util/Map;)V
:try_end_6
.catchall {:try_start_3 .. :try_end_6} :catchall_7
goto :goto_a
:catchall_7
move-exception p1
monitor-exit p0
throw p1
.line 2
:cond_a
:goto_a
monitor-exit p0
return-object p0
.end method
.method public declared-synchronized setCustomUserData(Ljava/util/Map;)Lio/rong/imlib/statistics/Statistics;
.registers 2
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;)",
"Lio/rong/imlib/statistics/Statistics;"
}
.end annotation
monitor-enter p0
if-eqz p1, :cond_6
.line 1
:try_start_3
invoke-static {p1}, Lio/rong/imlib/statistics/UserData;->setCustomData(Ljava/util/Map;)V
.line 2
:cond_6
iget-object p1, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {p1}, Lio/rong/imlib/statistics/ConnectionQueue;->sendUserData()V
:try_end_b
.catchall {:try_start_3 .. :try_end_b} :catchall_d
.line 3
monitor-exit p0
return-object p0
:catchall_d
move-exception p1
monitor-exit p0
throw p1
.end method
.method public declared-synchronized setDisableUpdateSessionRequests(Z)Lio/rong/imlib/statistics/Statistics;
.registers 2
monitor-enter p0
.line 1
:try_start_1
iput-boolean p1, p0, Lio/rong/imlib/statistics/Statistics;->disableUpdateSessionRequests_:Z
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_5
.line 2
monitor-exit p0
return-object p0
:catchall_5
move-exception p1
monitor-exit p0
throw p1
.end method
.method setEventQueue(Lio/rong/imlib/statistics/EventQueue;)V
.registers 2
.line 1
iput-object p1, p0, Lio/rong/imlib/statistics/Statistics;->eventQueue_:Lio/rong/imlib/statistics/EventQueue;
return-void
.end method
.method public declared-synchronized setLocation(DD)Lio/rong/imlib/statistics/Statistics;
.registers 6
monitor-enter p0
.line 1
:try_start_1
iget-object v0, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {v0}, Lio/rong/imlib/statistics/ConnectionQueue;->getCountlyStore()Lio/rong/imlib/statistics/StatisticsStore;
move-result-object v0
invoke-virtual {v0, p1, p2, p3, p4}, Lio/rong/imlib/statistics/StatisticsStore;->setLocation(DD)V
.line 2
iget-boolean p1, p0, Lio/rong/imlib/statistics/Statistics;->disableUpdateSessionRequests_:Z
if-eqz p1, :cond_17
.line 3
iget-object p1, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {p0}, Lio/rong/imlib/statistics/Statistics;->roundedSecondsSinceLastSessionDurationUpdate()I
move-result p2
invoke-virtual {p1, p2}, Lio/rong/imlib/statistics/ConnectionQueue;->updateSession(I)V
:try_end_17
.catchall {:try_start_1 .. :try_end_17} :catchall_19
.line 4
:cond_17
monitor-exit p0
return-object p0
:catchall_19
move-exception p1
monitor-exit p0
throw p1
.end method
.method public declared-synchronized setLoggingEnabled(Z)Lio/rong/imlib/statistics/Statistics;
.registers 2
monitor-enter p0
.line 1
:try_start_1
iput-boolean p1, p0, Lio/rong/imlib/statistics/Statistics;->enableLogging_:Z
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_5
.line 2
monitor-exit p0
return-object p0
:catchall_5
move-exception p1
monitor-exit p0
throw p1
.end method
.method setPrevSessionDurationStartTime(J)V
.registers 3
.line 1
iput-wide p1, p0, Lio/rong/imlib/statistics/Statistics;->prevSessionDurationStartTime_:J
return-void
.end method
.method public declared-synchronized setUserData(Ljava/util/Map;)Lio/rong/imlib/statistics/Statistics;
.registers 3
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;)",
"Lio/rong/imlib/statistics/Statistics;"
}
.end annotation
monitor-enter p0
const/4 v0, 0x0
.line 1
:try_start_2
invoke-virtual {p0, p1, v0}, Lio/rong/imlib/statistics/Statistics;->setUserData(Ljava/util/Map;Ljava/util/Map;)Lio/rong/imlib/statistics/Statistics;
move-result-object p1
:try_end_6
.catchall {:try_start_2 .. :try_end_6} :catchall_8
monitor-exit p0
return-object p1
:catchall_8
move-exception p1
monitor-exit p0
throw p1
.end method
.method public declared-synchronized setUserData(Ljava/util/Map;Ljava/util/Map;)Lio/rong/imlib/statistics/Statistics;
.registers 3
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;)",
"Lio/rong/imlib/statistics/Statistics;"
}
.end annotation
monitor-enter p0
.line 2
:try_start_1
invoke-static {p1}, Lio/rong/imlib/statistics/UserData;->setData(Ljava/util/Map;)V
if-eqz p2, :cond_9
.line 3
invoke-static {p2}, Lio/rong/imlib/statistics/UserData;->setCustomData(Ljava/util/Map;)V
.line 4
:cond_9
iget-object p1, p0, Lio/rong/imlib/statistics/Statistics;->connectionQueue_:Lio/rong/imlib/statistics/ConnectionQueue;
invoke-virtual {p1}, Lio/rong/imlib/statistics/ConnectionQueue;->sendUserData()V
:try_end_e
.catchall {:try_start_1 .. :try_end_e} :catchall_10
.line 5
monitor-exit p0
return-object p0
:catchall_10
move-exception p1
monitor-exit p0
throw p1
.end method