Sender.smali
.class public Lcom/umeng/commonsdk/vchannel/Sender;
.super Ljava/lang/Object;
.source "Sender.java"
# static fields
.field private static INTERVAL_THRESHOLD:J
.field private static customHeader:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map",
"<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;"
}
.end annotation
.end field
.field private static lastTriggerTime:J
# direct methods
.method static constructor <clinit>()V
.registers 2
.prologue
.line 21
const-wide/16 v0, 0x0
sput-wide v0, Lcom/umeng/commonsdk/vchannel/Sender;->lastTriggerTime:J
.line 22
const-wide/16 v0, 0x1f4
sput-wide v0, Lcom/umeng/commonsdk/vchannel/Sender;->INTERVAL_THRESHOLD:J
.line 23
const/4 v0, 0x0
sput-object v0, Lcom/umeng/commonsdk/vchannel/Sender;->customHeader:Ljava/util/Map;
return-void
.end method
.method public constructor <init>()V
.registers 1
.prologue
.line 19
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method public static handleEvent(Landroid/content/Context;Lcom/umeng/commonsdk/vchannel/b;)V
.registers 8
.prologue
.line 77
if-nez p0, :cond_a
.line 78
const-string v0, "MobclickRT"
const-string v1, "--->>> Sender:handleEvent: context is null."
invoke-static {v0, v1}, Lcom/umeng/commonsdk/debug/UMRTLog;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 110
:goto_9
return-void
.line 82
:cond_a
:try_start_a
new-instance v2, Lcom/umeng/commonsdk/stateless/UMSLEnvelopeBuild;
invoke-direct {v2}, Lcom/umeng/commonsdk/stateless/UMSLEnvelopeBuild;-><init>()V
.line 83
invoke-virtual {v2, p0}, Lcom/umeng/commonsdk/stateless/UMSLEnvelopeBuild;->buildSLBaseHeader(Landroid/content/Context;)Lorg/json/JSONObject;
move-result-object v3
.line 84
if-eqz v3, :cond_5b
const-string v0, "header"
invoke-virtual {v3, v0}, Lorg/json/JSONObject;->has(Ljava/lang/String;)Z
:try_end_1a
.catch Ljava/lang/Throwable; {:try_start_a .. :try_end_1a} :catch_6f
move-result v0
if-eqz v0, :cond_5b
.line 86
:try_start_1d
const-string v0, "header"
invoke-virtual {v3, v0}, Lorg/json/JSONObject;->opt(Ljava/lang/String;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/json/JSONObject;
.line 87
if-eqz v0, :cond_2e
.line 88
const-string v1, "i_sdk_v"
const-string v4, "1.2.0"
invoke-virtual {v0, v1, v4}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 90
:cond_2e
sget-object v1, Lcom/umeng/commonsdk/vchannel/Sender;->customHeader:Ljava/util/Map;
if-eqz v1, :cond_5b
sget-object v1, Lcom/umeng/commonsdk/vchannel/Sender;->customHeader:Ljava/util/Map;
invoke-interface {v1}, Ljava/util/Map;->size()I
move-result v1
if-lez v1, :cond_5b
.line 91
sget-object v1, Lcom/umeng/commonsdk/vchannel/Sender;->customHeader:Ljava/util/Map;
invoke-interface {v1}, Ljava/util/Map;->keySet()Ljava/util/Set;
move-result-object v1
invoke-interface {v1}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v4
:goto_44
invoke-interface {v4}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_5b
invoke-interface {v4}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
.line 92
sget-object v5, Lcom/umeng/commonsdk/vchannel/Sender;->customHeader:Ljava/util/Map;
invoke-interface {v5, v1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v5
invoke-virtual {v0, v1, v5}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
:try_end_59
.catch Ljava/lang/Throwable; {:try_start_1d .. :try_end_59} :catch_5a
goto :goto_44
.line 95
:catch_5a
move-exception v0
.line 99
:cond_5b
:try_start_5b
new-instance v0, Lorg/json/JSONObject;
invoke-direct {v0}, Lorg/json/JSONObject;-><init>()V
.line 100
const-string v1, "analytics"
invoke-virtual {p1}, Lcom/umeng/commonsdk/vchannel/b;->d()Lorg/json/JSONObject;
move-result-object v4
invoke-virtual {v0, v1, v4}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 102
sget-object v1, Lcom/umeng/commonsdk/vchannel/a;->c:Ljava/lang/String;
invoke-virtual {v2, p0, v3, v0, v1}, Lcom/umeng/commonsdk/stateless/UMSLEnvelopeBuild;->buildSLEnvelope(Landroid/content/Context;Lorg/json/JSONObject;Lorg/json/JSONObject;Ljava/lang/String;)Lorg/json/JSONObject;
:try_end_6e
.catch Ljava/lang/Throwable; {:try_start_5b .. :try_end_6e} :catch_6f
goto :goto_9
.line 107
:catch_6f
move-exception v0
.line 108
invoke-static {p0, v0}, Lcom/umeng/commonsdk/internal/crash/UMCrashManager;->reportCrash(Landroid/content/Context;Ljava/lang/Throwable;)V
goto :goto_9
.end method
.method public static onEvent(Landroid/content/Context;Ljava/lang/String;Ljava/util/Map;)V
.registers 7
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Landroid/content/Context;",
"Ljava/lang/String;",
"Ljava/util/Map",
"<",
"Ljava/lang/String;",
"Ljava/lang/Object;",
">;)V"
}
.end annotation
.prologue
.line 38
if-nez p0, :cond_a
.line 39
const-string v0, "MobclickRT"
const-string v1, "--->>> Sender: onEvent: context is null."
invoke-static {v0, v1}, Lcom/umeng/commonsdk/debug/UMRTLog;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 74
:goto_9
return-void
.line 42
:cond_a
invoke-static {p1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-eqz v0, :cond_18
.line 43
const-string v0, "MobclickRT"
const-string v1, "--->>> Sender: onEvent: eventID is null or an empty string."
invoke-static {v0, v1}, Lcom/umeng/commonsdk/debug/UMRTLog;->e(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_9
.line 46
:cond_18
if-nez p2, :cond_22
.line 47
const-string v0, "MobclickRT"
const-string v1, "--->>> Sender: onEvent: map is null."
invoke-static {v0, v1}, Lcom/umeng/commonsdk/debug/UMRTLog;->e(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_9
.line 51
:cond_22
invoke-static {p0}, Lcom/umeng/commonsdk/framework/UMFrUtils;->isOnline(Landroid/content/Context;)Z
move-result v0
if-nez v0, :cond_30
.line 52
const-string v0, "MobclickRT"
const-string v1, "--->>> Sender: onEvent: Network unavailable."
invoke-static {v0, v1}, Lcom/umeng/commonsdk/debug/UMRTLog;->e(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_9
.line 55
:cond_30
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
.line 56
sget-wide v2, Lcom/umeng/commonsdk/vchannel/Sender;->lastTriggerTime:J
sub-long/2addr v0, v2
sget-wide v2, Lcom/umeng/commonsdk/vchannel/Sender;->INTERVAL_THRESHOLD:J
cmp-long v0, v0, v2
if-gez v0, :cond_45
.line 57
const-string v0, "MobclickRT"
const-string v1, "--->>> Sender: onEvent: The interval between events is less than 500 milliseconds."
invoke-static {v0, v1}, Lcom/umeng/commonsdk/debug/UMRTLog;->e(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_9
.line 61
:cond_45
new-instance v0, Lcom/umeng/commonsdk/vchannel/b;
invoke-direct {v0, p0}, Lcom/umeng/commonsdk/vchannel/b;-><init>(Landroid/content/Context;)V
.line 62
invoke-virtual {v0, p1}, Lcom/umeng/commonsdk/vchannel/b;->a(Ljava/lang/String;)V
.line 63
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v2
invoke-virtual {v0, v2, v3}, Lcom/umeng/commonsdk/vchannel/b;->a(J)V
.line 64
invoke-virtual {v0, p2}, Lcom/umeng/commonsdk/vchannel/b;->a(Ljava/util/Map;)V
.line 66
const v1, 0x800b
.line 68
:try_start_5a
invoke-static {p0}, Lcom/umeng/commonsdk/internal/b;->a(Landroid/content/Context;)Lcom/umeng/commonsdk/internal/b;
move-result-object v2
invoke-virtual {v2}, Lcom/umeng/commonsdk/internal/b;->a()Lcom/umeng/commonsdk/internal/c;
move-result-object v2
.line 66
invoke-static {p0, v1, v2, v0}, Lcom/umeng/commonsdk/framework/UMWorkDispatch;->sendEvent(Landroid/content/Context;ILcom/umeng/commonsdk/framework/UMLogDataProtocol;Ljava/lang/Object;)V
:try_end_65
.catch Ljava/lang/Throwable; {:try_start_5a .. :try_end_65} :catch_6c
.line 73
:goto_65
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
sput-wide v0, Lcom/umeng/commonsdk/vchannel/Sender;->lastTriggerTime:J
goto :goto_9
.line 70
:catch_6c
move-exception v0
goto :goto_65
.end method
.method public static setCustomHeader(Ljava/util/Map;)V
.registers 1
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/Map",
"<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;)V"
}
.end annotation
.prologue
.line 26
if-eqz p0, :cond_4
.line 27
sput-object p0, Lcom/umeng/commonsdk/vchannel/Sender;->customHeader:Ljava/util/Map;
.line 29
:cond_4
return-void
.end method