Sender.smali
.class public Lcom/umeng/commonsdk/vchannel/Sender;
.super Ljava/lang/Object;
.source "Sender.java"
# static fields
.field private static INTERVAL_THRESHOLD:J = 0x1f4L
.field public static final VCHANNEL_VERSION:Ljava/lang/String; = "1.0.0"
.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 0
return-void
.end method
.method public constructor <init>()V
.registers 1
.line 1
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
if-nez p0, :cond_a
const-string p0, "MobclickRT"
const-string p1, "--->>> Sender:handleEvent: context is null."
.line 1
invoke-static {p0, p1}, Lcom/umeng/commonsdk/debug/UMRTLog;->e(Ljava/lang/String;Ljava/lang/String;)V
return-void
.line 2
:cond_a
:try_start_a
new-instance v1, Lorg/json/JSONObject;
invoke-direct {v1}, Lorg/json/JSONObject;-><init>()V
:try_end_f
.catch Ljava/lang/Throwable; {:try_start_a .. :try_end_f} :catch_5b
:try_start_f
const-string v0, "v_sdk_v"
const-string v2, "1.0.0"
.line 3
invoke-virtual {v1, v0, v2}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 4
sget-object v0, Lcom/umeng/commonsdk/vchannel/Sender;->customHeader:Ljava/util/Map;
if-eqz v0, :cond_42
sget-object v0, Lcom/umeng/commonsdk/vchannel/Sender;->customHeader:Ljava/util/Map;
invoke-interface {v0}, Ljava/util/Map;->size()I
move-result v0
if-lez v0, :cond_42
.line 5
sget-object v0, Lcom/umeng/commonsdk/vchannel/Sender;->customHeader:Ljava/util/Map;
invoke-interface {v0}, 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_2c
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_42
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/String;
.line 6
sget-object v3, Lcom/umeng/commonsdk/vchannel/Sender;->customHeader:Ljava/util/Map;
invoke-interface {v3, v2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v3
invoke-virtual {v1, v2, v3}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
:try_end_41
.catch Ljava/lang/Throwable; {:try_start_f .. :try_end_41} :catch_42
goto :goto_2c
.line 7
:catch_42
:cond_42
:try_start_42
new-instance v2, Lorg/json/JSONObject;
invoke-direct {v2}, Lorg/json/JSONObject;-><init>()V
const-string v0, "analytics"
.line 8
invoke-virtual {p1}, Lcom/umeng/commonsdk/vchannel/b;->d()Lorg/json/JSONObject;
move-result-object p1
invoke-virtual {v2, v0, p1}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 9
sget-object v3, Lcom/umeng/commonsdk/vchannel/a;->c:Ljava/lang/String;
const-string v4, "v"
const-string v5, "1.0.0"
move-object v0, p0
invoke-static/range {v0 .. v5}, Lcom/umeng/commonsdk/framework/UMEnvelopeBuild;->buildEnvelopeWithExtHeader(Landroid/content/Context;Lorg/json/JSONObject;Lorg/json/JSONObject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Lorg/json/JSONObject;
:try_end_5a
.catch Ljava/lang/Throwable; {:try_start_42 .. :try_end_5a} :catch_5b
goto :goto_5f
:catch_5b
move-exception p1
.line 10
invoke-static {p0, p1}, Lcom/umeng/commonsdk/internal/crash/UMCrashManager;->reportCrash(Landroid/content/Context;Ljava/lang/Throwable;)V
:goto_5f
return-void
.end method
.method public static onEvent(Landroid/content/Context;Ljava/lang/String;Ljava/util/Map;)V
.registers 9
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Landroid/content/Context;",
"Ljava/lang/String;",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/Object;",
">;)V"
}
.end annotation
const-string v0, "MobclickRT"
if-nez p0, :cond_a
const-string p0, "--->>> Sender: onEvent: context is null."
.line 1
invoke-static {v0, p0}, Lcom/umeng/commonsdk/debug/UMRTLog;->e(Ljava/lang/String;Ljava/lang/String;)V
return-void
.line 2
:cond_a
invoke-static {p1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v1
if-eqz v1, :cond_16
const-string p0, "--->>> Sender: onEvent: eventID is null or an empty string."
.line 3
invoke-static {v0, p0}, Lcom/umeng/commonsdk/debug/UMRTLog;->e(Ljava/lang/String;Ljava/lang/String;)V
return-void
:cond_16
if-nez p2, :cond_1e
const-string p0, "--->>> Sender: onEvent: map is null."
.line 4
invoke-static {v0, p0}, Lcom/umeng/commonsdk/debug/UMRTLog;->e(Ljava/lang/String;Ljava/lang/String;)V
return-void
.line 5
:cond_1e
invoke-static {p0}, Lcom/umeng/commonsdk/framework/UMFrUtils;->isOnline(Landroid/content/Context;)Z
move-result v1
if-nez v1, :cond_2a
const-string p0, "--->>> Sender: onEvent: Network unavailable."
.line 6
invoke-static {v0, p0}, Lcom/umeng/commonsdk/debug/UMRTLog;->e(Ljava/lang/String;Ljava/lang/String;)V
return-void
.line 7
:cond_2a
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v1
.line 8
sget-wide v3, Lcom/umeng/commonsdk/vchannel/Sender;->lastTriggerTime:J
sub-long/2addr v1, v3
sget-wide v3, Lcom/umeng/commonsdk/vchannel/Sender;->INTERVAL_THRESHOLD:J
cmp-long v5, v1, v3
if-gez v5, :cond_3d
const-string p0, "--->>> Sender: onEvent: The interval between events is less than 500 milliseconds."
.line 9
invoke-static {v0, p0}, Lcom/umeng/commonsdk/debug/UMRTLog;->e(Ljava/lang/String;Ljava/lang/String;)V
return-void
.line 10
:cond_3d
new-instance v0, Lcom/umeng/commonsdk/vchannel/b;
invoke-direct {v0, p0}, Lcom/umeng/commonsdk/vchannel/b;-><init>(Landroid/content/Context;)V
.line 11
invoke-virtual {v0, p1}, Lcom/umeng/commonsdk/vchannel/b;->a(Ljava/lang/String;)V
.line 12
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v1
invoke-virtual {v0, v1, v2}, Lcom/umeng/commonsdk/vchannel/b;->a(J)V
.line 13
invoke-virtual {v0, p2}, Lcom/umeng/commonsdk/vchannel/b;->a(Ljava/util/Map;)V
const p1, 0x800b
.line 14
:try_start_52
invoke-static {p0}, Lcom/umeng/commonsdk/internal/b;->a(Landroid/content/Context;)Lcom/umeng/commonsdk/internal/b;
move-result-object p2
invoke-virtual {p2}, Lcom/umeng/commonsdk/internal/b;->a()Lcom/umeng/commonsdk/internal/c;
move-result-object p2
.line 15
invoke-static {p0, p1, p2, v0}, Lcom/umeng/commonsdk/framework/UMWorkDispatch;->sendEvent(Landroid/content/Context;ILcom/umeng/commonsdk/framework/UMLogDataProtocol;Ljava/lang/Object;)V
:try_end_5d
.catch Ljava/lang/Throwable; {:try_start_52 .. :try_end_5d} :catch_5d
.line 16
:catch_5d
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide p0
sput-wide p0, Lcom/umeng/commonsdk/vchannel/Sender;->lastTriggerTime:J
return-void
.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
if-eqz p0, :cond_4
.line 1
sput-object p0, Lcom/umeng/commonsdk/vchannel/Sender;->customHeader:Ljava/util/Map;
:cond_4
return-void
.end method