DTBAdView$WebBridge.smali
.class Lcom/amazon/device/ads/DTBAdView$WebBridge;
.super Ljava/lang/Object;
.source "SourceFile"
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lcom/amazon/device/ads/DTBAdView;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x0
name = "WebBridge"
.end annotation
# instance fields
.field execException:Ljava/lang/Exception;
.field final synthetic this$0:Lcom/amazon/device/ads/DTBAdView;
# direct methods
.method constructor <init>(Lcom/amazon/device/ads/DTBAdView;)V
.registers 2
.line 716
iput-object p1, p0, Lcom/amazon/device/ads/DTBAdView$WebBridge;->this$0:Lcom/amazon/device/ads/DTBAdView;
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method private logFromJavasScript(Ljava/lang/String;)V
.registers 3
const-string v0, "mraid:JSNative"
.line 780
invoke-static {v0, p1}, Lcom/amazon/device/ads/DtbLog;->debug(Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
# virtual methods
.method echo(Lorg/json/JSONObject;)V
.registers 6
:try_start_0
const-string v0, "promiseId"
.line 786
invoke-virtual {p1, v0}, Lorg/json/JSONObject;->getInt(Ljava/lang/String;)I
move-result v0
invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v0
.line 788
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "arguments"
invoke-virtual {p1, v2}, Lorg/json/JSONObject;->getJSONObject(Ljava/lang/String;)Lorg/json/JSONObject;
move-result-object p1
const-string v2, "greeting"
invoke-virtual {p1, v2}, Lorg/json/JSONObject;->getString(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p1, " Returned"
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
const-string v1, "window.promiseResolve(%d, \'%s\');"
const/4 v2, 0x2
new-array v2, v2, [Ljava/lang/Object;
const/4 v3, 0x0
aput-object v0, v2, v3
const/4 v0, 0x1
aput-object p1, v2, v0
.line 789
invoke-static {v1, v2}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
.line 790
new-instance v0, Landroid/os/Handler;
invoke-static {}, Landroid/os/Looper;->getMainLooper()Landroid/os/Looper;
move-result-object v1
invoke-direct {v0, v1}, Landroid/os/Handler;-><init>(Landroid/os/Looper;)V
new-instance v1, Lcom/amazon/device/ads/-$$Lambda$DTBAdView$WebBridge$yp1wL8o3a9pFT6cV-StZiHOozi8;
invoke-direct {v1, p0, p1}, Lcom/amazon/device/ads/-$$Lambda$DTBAdView$WebBridge$yp1wL8o3a9pFT6cV-StZiHOozi8;-><init>(Lcom/amazon/device/ads/DTBAdView$WebBridge;Ljava/lang/String;)V
invoke-virtual {v0, v1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
:try_end_47
.catch Lorg/json/JSONException; {:try_start_0 .. :try_end_47} :catch_48
return-void
:catch_48
move-exception p1
.line 796
sget-object v0, Lcom/amazon/device/ads/DTBAdView;->LOG_TAG:Ljava/lang/String;
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
const-string v1, "JSON conversion failed:"
invoke-virtual {v1, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
invoke-static {v0, p1}, Lcom/amazon/device/ads/DtbLog;->debug(Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
.method getExecutionException()Ljava/lang/Exception;
.registers 2
.line 722
iget-object v0, p0, Lcom/amazon/device/ads/DTBAdView$WebBridge;->execException:Ljava/lang/Exception;
return-object v0
.end method
.method handleMraidCommand(Lorg/json/JSONObject;)V
.registers 7
.annotation system Ldalvik/annotation/Throws;
value = {
Lorg/json/JSONException;
}
.end annotation
const/4 v0, 0x0
.line 755
iput-object v0, p0, Lcom/amazon/device/ads/DTBAdView$WebBridge;->execException:Ljava/lang/Exception;
const-string v0, "subtype"
.line 756
invoke-virtual {p1, v0}, Lorg/json/JSONObject;->getString(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 757
invoke-static {v0}, Lcom/amazon/device/ads/MraidCommand;->findMraidCommandByName(Ljava/lang/String;)Ljava/lang/Class;
move-result-object v1
if-nez v1, :cond_49
.line 759
new-instance p1, Ljava/lang/StringBuilder;
const-string v1, "MRAID Command:"
invoke-direct {p1, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, " is not found"
invoke-virtual {p1, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {p1}, Lcom/amazon/device/ads/DtbLog;->error(Ljava/lang/String;)V
.line 760
iget-object p1, p0, Lcom/amazon/device/ads/DTBAdView$WebBridge;->this$0:Lcom/amazon/device/ads/DTBAdView;
# getter for: Lcom/amazon/device/ads/DTBAdView;->controller:Lcom/amazon/device/ads/DTBAdMRAIDController;
invoke-static {p1}, Lcom/amazon/device/ads/DTBAdView;->access$100(Lcom/amazon/device/ads/DTBAdView;)Lcom/amazon/device/ads/DTBAdMRAIDController;
move-result-object p1
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, " is not supported"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {p1, v0, v1}, Lcom/amazon/device/ads/DTBAdMRAIDController;->fireErrorEvent(Ljava/lang/String;Ljava/lang/String;)V
.line 761
iget-object p1, p0, Lcom/amazon/device/ads/DTBAdView$WebBridge;->this$0:Lcom/amazon/device/ads/DTBAdView;
# getter for: Lcom/amazon/device/ads/DTBAdView;->controller:Lcom/amazon/device/ads/DTBAdMRAIDController;
invoke-static {p1}, Lcom/amazon/device/ads/DTBAdView;->access$100(Lcom/amazon/device/ads/DTBAdView;)Lcom/amazon/device/ads/DTBAdMRAIDController;
move-result-object p1
invoke-virtual {p1, v0}, Lcom/amazon/device/ads/DTBAdMRAIDController;->commandCompleted(Ljava/lang/String;)V
return-void
.line 766
:cond_49
:try_start_49
invoke-virtual {v1}, Ljava/lang/Class;->newInstance()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/amazon/device/ads/MraidCommand;
.line 767
sget-object v2, Lcom/amazon/device/ads/DTBAdView;->LOG_TAG:Ljava/lang/String;
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "execute command "
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1}, Lcom/amazon/device/ads/MraidCommand;->getName()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v2, v3}, Lcom/amazon/device/ads/DtbLog;->debug(Ljava/lang/String;Ljava/lang/String;)V
const-string v2, "arguments"
.line 768
invoke-virtual {p1, v2}, Lorg/json/JSONObject;->getJSONObject(Ljava/lang/String;)Lorg/json/JSONObject;
move-result-object p1
.line 769
iget-object v2, p0, Lcom/amazon/device/ads/DTBAdView$WebBridge;->this$0:Lcom/amazon/device/ads/DTBAdView;
# getter for: Lcom/amazon/device/ads/DTBAdView;->controller:Lcom/amazon/device/ads/DTBAdMRAIDController;
invoke-static {v2}, Lcom/amazon/device/ads/DTBAdView;->access$100(Lcom/amazon/device/ads/DTBAdView;)Lcom/amazon/device/ads/DTBAdMRAIDController;
move-result-object v2
invoke-virtual {v1, p1, v2}, Lcom/amazon/device/ads/MraidCommand;->execute(Lorg/json/JSONObject;Lcom/amazon/device/ads/DTBAdMRAIDController;)V
:try_end_75
.catch Lorg/json/JSONException; {:try_start_49 .. :try_end_75} :catch_97
.catch Ljava/lang/Exception; {:try_start_49 .. :try_end_75} :catch_76
return-void
:catch_76
move-exception p1
.line 774
iput-object p1, p0, Lcom/amazon/device/ads/DTBAdView$WebBridge;->execException:Ljava/lang/Exception;
.line 775
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Error execution command "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v0, " "
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/Exception;->getLocalizedMessage()Ljava/lang/String;
move-result-object p1
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {p1}, Lcom/amazon/device/ads/DtbLog;->debug(Ljava/lang/String;)V
return-void
:catch_97
move-exception p1
.line 772
throw p1
.end method
.method handleServiceCall(Lorg/json/JSONObject;)V
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Lorg/json/JSONException;
}
.end annotation
const-string v0, "subtype"
.line 747
invoke-virtual {p1, v0}, Lorg/json/JSONObject;->getString(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
const-string v1, "log"
.line 748
invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_1d
const-string v0, "arguments"
.line 749
invoke-virtual {p1, v0}, Lorg/json/JSONObject;->getJSONObject(Ljava/lang/String;)Lorg/json/JSONObject;
move-result-object p1
const-string v0, "message"
.line 750
invoke-virtual {p1, v0}, Lorg/json/JSONObject;->getString(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
invoke-direct {p0, p1}, Lcom/amazon/device/ads/DTBAdView$WebBridge;->logFromJavasScript(Ljava/lang/String;)V
:cond_1d
return-void
.end method
.method public synthetic lambda$echo$0$DTBAdView$WebBridge(Ljava/lang/String;)V
.registers 4
.line 791
iget-object v0, p0, Lcom/amazon/device/ads/DTBAdView$WebBridge;->this$0:Lcom/amazon/device/ads/DTBAdView;
const/4 v1, 0x0
invoke-virtual {v0, p1, v1}, Lcom/amazon/device/ads/DTBAdView;->evaluateJavascript(Ljava/lang/String;Landroid/webkit/ValueCallback;)V
return-void
.end method
.method public postMessage(Ljava/lang/String;)V
.registers 4
.annotation runtime Landroid/webkit/JavascriptInterface;
.end annotation
const-string v0, "type"
.line 728
:try_start_2
new-instance v1, Lorg/json/JSONObject;
invoke-direct {v1, p1}, Lorg/json/JSONObject;-><init>(Ljava/lang/String;)V
.line 729
invoke-virtual {v1, v0}, Lorg/json/JSONObject;->has(Ljava/lang/String;)Z
move-result p1
if-eqz p1, :cond_29
.line 731
invoke-virtual {v1, v0}, Lorg/json/JSONObject;->getString(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
const-string v0, "service"
.line 732
invoke-virtual {v0, p1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_1d
.line 733
invoke-virtual {p0, v1}, Lcom/amazon/device/ads/DTBAdView$WebBridge;->handleServiceCall(Lorg/json/JSONObject;)V
return-void
:cond_1d
const-string v0, "mraid"
.line 734
invoke-virtual {v0, p1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result p1
if-eqz p1, :cond_28
.line 735
invoke-virtual {p0, v1}, Lcom/amazon/device/ads/DTBAdView$WebBridge;->handleMraidCommand(Lorg/json/JSONObject;)V
:cond_28
return-void
:cond_29
const-string p1, "Unrecognized bridge call"
.line 739
invoke-static {p1}, Lcom/amazon/device/ads/DtbLog;->error(Ljava/lang/String;)V
:try_end_2e
.catch Lorg/json/JSONException; {:try_start_2 .. :try_end_2e} :catch_2f
return-void
:catch_2f
move-exception p1
.line 742
sget-object v0, Lcom/amazon/device/ads/DTBAdView;->LOG_TAG:Ljava/lang/String;
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
const-string v1, "JSON conversion failed:"
invoke-virtual {v1, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
invoke-static {v0, p1}, Lcom/amazon/device/ads/DtbLog;->debug(Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method