.class public Lcom/ea/nimble/SynergyRequest; .super Ljava/lang/Object; .source "SourceFile" # interfaces .implements Lcom/ea/nimble/ISynergyRequest; # annotations .annotation system Ldalvik/annotation/MemberClasses; value = { Lcom/ea/nimble/SynergyRequest$SynergyRequestPreparingCallback; } .end annotation # instance fields .field public api:Ljava/lang/String; .field public baseUrl:Ljava/lang/String; .field public httpRequest:Lcom/ea/nimble/HttpRequest; .field public jsonData:Lcom/ea/nimble/ISynergyRequest$IJsonData; .field private m_connection:Lcom/ea/nimble/SynergyNetworkConnection; .field public prepareRequestCallback:Lcom/ea/nimble/SynergyRequest$SynergyRequestPreparingCallback; .field public urlParameters:Ljava/util/Map; .annotation system Ldalvik/annotation/Signature; value = { "Ljava/util/Map<", "Ljava/lang/String;", "Ljava/lang/String;", ">;" } .end annotation .end field # direct methods .method public constructor (Ljava/lang/String;Lcom/ea/nimble/IHttpRequest$Method;Lcom/ea/nimble/SynergyRequest$SynergyRequestPreparingCallback;)V .locals 1 .line 37 invoke-direct {p0}, Ljava/lang/Object;->()V const/4 v0, 0x0 iput-object v0, p0, Lcom/ea/nimble/SynergyRequest;->m_connection:Lcom/ea/nimble/SynergyNetworkConnection; iput-object p1, p0, Lcom/ea/nimble/SynergyRequest;->api:Ljava/lang/String; .line 40 new-instance p1, Lcom/ea/nimble/HttpRequest; invoke-direct {p1}, Lcom/ea/nimble/HttpRequest;->()V iput-object p1, p0, Lcom/ea/nimble/SynergyRequest;->httpRequest:Lcom/ea/nimble/HttpRequest; iput-object p3, p0, Lcom/ea/nimble/SynergyRequest;->prepareRequestCallback:Lcom/ea/nimble/SynergyRequest$SynergyRequestPreparingCallback; iput-object v0, p0, Lcom/ea/nimble/SynergyRequest;->urlParameters:Ljava/util/Map; iput-object v0, p0, Lcom/ea/nimble/SynergyRequest;->jsonData:Lcom/ea/nimble/ISynergyRequest$IJsonData; iput-object p2, p1, Lcom/ea/nimble/HttpRequest;->method:Lcom/ea/nimble/IHttpRequest$Method; iget-object p1, p1, Lcom/ea/nimble/HttpRequest;->headers:Ljava/util/HashMap; const-string p2, "Content-Type" const-string p3, "application/json" .line 45 invoke-virtual {p1, p2, p3}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; iget-object p1, p0, Lcom/ea/nimble/SynergyRequest;->httpRequest:Lcom/ea/nimble/HttpRequest; .line 46 iget-object p1, p1, Lcom/ea/nimble/HttpRequest;->headers:Ljava/util/HashMap; const-string p2, "SDK-VERSION" const-string p3, "1.63.0.2" invoke-virtual {p1, p2, p3}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; iget-object p1, p0, Lcom/ea/nimble/SynergyRequest;->httpRequest:Lcom/ea/nimble/HttpRequest; .line 47 iget-object p1, p1, Lcom/ea/nimble/HttpRequest;->headers:Ljava/util/HashMap; const-string p2, "SDK-TYPE" const-string p3, "Nimble" invoke-virtual {p1, p2, p3}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 49 invoke-static {}, Lcom/ea/nimble/SynergyNetwork;->getComponent()Lcom/ea/nimble/ISynergyNetwork; move-result-object p1 check-cast p1, Lcom/ea/nimble/SynergyNetworkImpl; invoke-virtual {p1}, Lcom/ea/nimble/SynergyNetworkImpl;->getSessionId()Ljava/lang/String; move-result-object p1 .line 50 invoke-static {p1}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result p2 if-eqz p2, :cond_0 iget-object p2, p0, Lcom/ea/nimble/SynergyRequest;->httpRequest:Lcom/ea/nimble/HttpRequest; .line 52 iget-object p2, p2, Lcom/ea/nimble/HttpRequest;->headers:Ljava/util/HashMap; const-string p3, "EAM-SESSION" invoke-virtual {p2, p3, p1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; goto :goto_0 :cond_0 const/4 p1, 0x0 new-array p1, p1, [Ljava/lang/Object; const-string p2, "SynergyRequest" const-string p3, "Synergy Network session ID is null" .line 56 invoke-static {p2, p3, p1}, Lcom/ea/nimble/Log$Helper;->LOGES(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V .line 58 :goto_0 invoke-static {}, Lcom/ea/nimble/SynergyIdManager;->getComponent()Lcom/ea/nimble/ISynergyIdManager; move-result-object p1 invoke-interface {p1}, Lcom/ea/nimble/ISynergyIdManager;->getSynergyId()Ljava/lang/String; move-result-object p1 .line 59 invoke-static {p1}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result p2 if-eqz p2, :cond_1 iget-object p2, p0, Lcom/ea/nimble/SynergyRequest;->httpRequest:Lcom/ea/nimble/HttpRequest; .line 61 iget-object p2, p2, Lcom/ea/nimble/HttpRequest;->headers:Ljava/util/HashMap; const-string p3, "EAM-USER-ID" invoke-virtual {p2, p3, p1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 63 :cond_1 invoke-static {}, Lcom/ea/nimble/SynergyEnvironment;->getComponent()Lcom/ea/nimble/ISynergyEnvironment; move-result-object p1 invoke-interface {p1}, Lcom/ea/nimble/ISynergyEnvironment;->getSellId()Ljava/lang/String; move-result-object p1 .line 64 invoke-static {p1}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result p2 if-eqz p2, :cond_2 iget-object p2, p0, Lcom/ea/nimble/SynergyRequest;->httpRequest:Lcom/ea/nimble/HttpRequest; .line 66 iget-object p2, p2, Lcom/ea/nimble/HttpRequest;->headers:Ljava/util/HashMap; const-string p3, "EA-SELL-ID" invoke-virtual {p2, p3, p1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; :cond_2 return-void .end method # virtual methods .method public build()V .locals 4 .annotation system Ldalvik/annotation/Throws; value = { Lcom/ea/nimble/Error; } .end annotation .line 135 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/SynergyRequest;->baseUrl:Ljava/lang/String; .line 136 invoke-static {v0}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result v0 if-eqz v0, :cond_4 iget-object v0, p0, Lcom/ea/nimble/SynergyRequest;->api:Ljava/lang/String; .line 137 invoke-static {v0}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result v0 if-eqz v0, :cond_4 .line 142 invoke-static {}, Lcom/ea/nimble/ApplicationEnvironment;->getComponent()Lcom/ea/nimble/IApplicationEnvironment; move-result-object v0 .line 143 new-instance v1, Ljava/util/HashMap; invoke-direct {v1}, Ljava/util/HashMap;->()V .line 144 invoke-interface {v0}, Lcom/ea/nimble/IApplicationEnvironment;->getApplicationVersion()Ljava/lang/String; move-result-object v2 const-string v3, "appVer" invoke-interface {v1, v3, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; const-string v2, "appLang" .line 145 invoke-interface {v0}, Lcom/ea/nimble/IApplicationEnvironment;->getShortApplicationLanguageCode()Ljava/lang/String; move-result-object v3 invoke-interface {v1, v2, v3}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; const-string v2, "localization" .line 146 invoke-interface {v0}, Lcom/ea/nimble/IApplicationEnvironment;->getApplicationLanguageCode()Ljava/lang/String; move-result-object v0 invoke-interface {v1, v2, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 147 invoke-static {}, Ljava/util/Locale;->getDefault()Ljava/util/Locale; move-result-object v0 invoke-virtual {v0}, Ljava/util/Locale;->getLanguage()Ljava/lang/String; move-result-object v0 const-string v2, "deviceLanguage" invoke-interface {v1, v2, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 148 invoke-static {}, Ljava/util/Locale;->getDefault()Ljava/util/Locale; move-result-object v0 invoke-virtual {v0}, Ljava/util/Locale;->toString()Ljava/lang/String; move-result-object v0 const-string v2, "deviceLocale" invoke-interface {v1, v2, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 150 invoke-static {}, Lcom/ea/nimble/SynergyEnvironment;->getComponent()Lcom/ea/nimble/ISynergyEnvironment; move-result-object v0 .line 151 invoke-interface {v0}, Lcom/ea/nimble/ISynergyEnvironment;->getEAHardwareId()Ljava/lang/String; move-result-object v0 .line 152 invoke-static {v0}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result v2 if-eqz v2, :cond_0 const-string v2, "hwId" .line 154 invoke-interface {v1, v2, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; :cond_0 iget-object v0, p0, Lcom/ea/nimble/SynergyRequest;->urlParameters:Ljava/util/Map; if-eqz v0, :cond_1 .line 159 invoke-interface {v1, v0}, Ljava/util/Map;->putAll(Ljava/util/Map;)V :cond_1 iget-object v0, p0, Lcom/ea/nimble/SynergyRequest;->httpRequest:Lcom/ea/nimble/HttpRequest; .line 162 new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V iget-object v3, p0, Lcom/ea/nimble/SynergyRequest;->baseUrl:Ljava/lang/String; invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; iget-object v3, p0, Lcom/ea/nimble/SynergyRequest;->api:Ljava/lang/String; invoke-virtual {v2, v3}, 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 {v2, v1}, Lcom/ea/nimble/Network;->generateURL(Ljava/lang/String;Ljava/util/Map;)Ljava/net/URL; move-result-object v1 iput-object v1, v0, Lcom/ea/nimble/HttpRequest;->url:Ljava/net/URL; iget-object v0, p0, Lcom/ea/nimble/SynergyRequest;->httpRequest:Lcom/ea/nimble/HttpRequest; .line 164 iget-object v0, v0, Lcom/ea/nimble/HttpRequest;->method:Lcom/ea/nimble/IHttpRequest$Method; sget-object v1, Lcom/ea/nimble/IHttpRequest$Method;->POST:Lcom/ea/nimble/IHttpRequest$Method; if-eq v0, v1, :cond_2 sget-object v1, Lcom/ea/nimble/IHttpRequest$Method;->PUT:Lcom/ea/nimble/IHttpRequest$Method; if-ne v0, v1, :cond_3 :cond_2 iget-object v0, p0, Lcom/ea/nimble/SynergyRequest;->jsonData:Lcom/ea/nimble/ISynergyRequest$IJsonData; if-eqz v0, :cond_3 .line 165 invoke-interface {v0}, Lcom/ea/nimble/ISynergyRequest$IJsonData;->size()I move-result v0 if-lez v0, :cond_3 iget-object v0, p0, Lcom/ea/nimble/SynergyRequest;->jsonData:Lcom/ea/nimble/ISynergyRequest$IJsonData; .line 167 invoke-interface {v0}, Lcom/ea/nimble/ISynergyRequest$IJsonData;->getData()Ljava/lang/Object; move-result-object v0 invoke-static {v0}, Lcom/ea/nimble/Utility;->convertObjectToJSONString(Ljava/lang/Object;)Ljava/lang/String; move-result-object v0 iget-object v1, p0, Lcom/ea/nimble/SynergyRequest;->httpRequest:Lcom/ea/nimble/HttpRequest; .line 168 new-instance v2, Ljava/io/ByteArrayOutputStream; invoke-direct {v2}, Ljava/io/ByteArrayOutputStream;->()V iput-object v2, v1, Lcom/ea/nimble/HttpRequest;->data:Ljava/io/ByteArrayOutputStream; :try_start_0 iget-object v1, p0, Lcom/ea/nimble/SynergyRequest;->httpRequest:Lcom/ea/nimble/HttpRequest; .line 171 iget-object v1, v1, Lcom/ea/nimble/HttpRequest;->data:Ljava/io/ByteArrayOutputStream; invoke-virtual {v0}, Ljava/lang/String;->getBytes()[B move-result-object v0 invoke-virtual {v1, v0}, Ljava/io/OutputStream;->write([B)V :try_end_0 .catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_0 goto :goto_0 :catch_0 move-exception v0 .line 175 new-instance v1, Lcom/ea/nimble/Error; sget-object v2, Lcom/ea/nimble/Error$Code;->INVALID_ARGUMENT:Lcom/ea/nimble/Error$Code; const-string v3, "Error converting jsonData in SynergyRequest to a data stream" invoke-direct {v1, v2, v3, v0}, Lcom/ea/nimble/Error;->(Lcom/ea/nimble/Error$Code;Ljava/lang/String;Ljava/lang/Throwable;)V throw v1 :cond_3 :goto_0 return-void .line 139 :cond_4 new-instance v0, Lcom/ea/nimble/Error; sget-object v1, Lcom/ea/nimble/Error$Code;->INVALID_ARGUMENT:Lcom/ea/nimble/Error$Code; iget-object v2, p0, Lcom/ea/nimble/SynergyRequest;->baseUrl:Ljava/lang/String; iget-object v3, p0, Lcom/ea/nimble/SynergyRequest;->api:Ljava/lang/String; filled-new-array {v2, v3}, [Ljava/lang/Object; move-result-object v2 const-string v3, "Invalid synergy request parameter (%s, %s) to build http request url" .line 140 invoke-static {v3, v2}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String; move-result-object v2 invoke-direct {v0, v1, v2}, Lcom/ea/nimble/Error;->(Lcom/ea/nimble/Error$Code;Ljava/lang/String;)V throw v0 .end method .method public getApi()Ljava/lang/String; .locals 1 .line 84 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/SynergyRequest;->api:Ljava/lang/String; return-object v0 .end method .method public getBaseUrl()Ljava/lang/String; .locals 1 .line 78 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/SynergyRequest;->baseUrl:Ljava/lang/String; return-object v0 .end method .method public getHttpRequest()Lcom/ea/nimble/HttpRequest; .locals 1 .line 72 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/SynergyRequest;->httpRequest:Lcom/ea/nimble/HttpRequest; return-object v0 .end method .method public bridge synthetic getHttpRequest()Lcom/ea/nimble/IHttpRequest; .locals 1 .line 21 invoke-virtual {p0}, Lcom/ea/nimble/SynergyRequest;->getHttpRequest()Lcom/ea/nimble/HttpRequest; move-result-object v0 return-object v0 .end method .method public getJsonData()Lcom/ea/nimble/ISynergyRequest$IJsonData; .locals 1 .line 108 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/SynergyRequest;->jsonData:Lcom/ea/nimble/ISynergyRequest$IJsonData; return-object v0 .end method .method public getMethod()Lcom/ea/nimble/IHttpRequest$Method; .locals 1 .line 90 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/SynergyRequest;->httpRequest:Lcom/ea/nimble/HttpRequest; .line 91 invoke-virtual {v0}, Lcom/ea/nimble/HttpRequest;->getMethod()Lcom/ea/nimble/IHttpRequest$Method; move-result-object v0 return-object v0 .end method .method public getUrlParameters()Ljava/util/Map; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "()", "Ljava/util/Map<", "Ljava/lang/String;", "Ljava/lang/String;", ">;" } .end annotation .line 102 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/SynergyRequest;->urlParameters:Ljava/util/Map; return-object v0 .end method .method public prepare(Lcom/ea/nimble/SynergyNetworkConnection;)V .locals 0 .line 120 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V iput-object p1, p0, Lcom/ea/nimble/SynergyRequest;->m_connection:Lcom/ea/nimble/SynergyNetworkConnection; iget-object p1, p0, Lcom/ea/nimble/SynergyRequest;->prepareRequestCallback:Lcom/ea/nimble/SynergyRequest$SynergyRequestPreparingCallback; if-eqz p1, :cond_0 .line 124 invoke-interface {p1, p0}, Lcom/ea/nimble/SynergyRequest$SynergyRequestPreparingCallback;->prepareRequest(Lcom/ea/nimble/SynergyRequest;)V goto :goto_0 .line 128 :cond_0 invoke-virtual {p0}, Lcom/ea/nimble/SynergyRequest;->send()V :goto_0 return-void .end method .method public send()V .locals 1 .line 114 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/SynergyRequest;->m_connection:Lcom/ea/nimble/SynergyNetworkConnection; .line 115 invoke-virtual {v0}, Lcom/ea/nimble/SynergyNetworkConnection;->send()V return-void .end method .method public setMethod(Lcom/ea/nimble/IHttpRequest$Method;)V .locals 1 .line 96 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/SynergyRequest;->httpRequest:Lcom/ea/nimble/HttpRequest; .line 97 iput-object p1, v0, Lcom/ea/nimble/HttpRequest;->method:Lcom/ea/nimble/IHttpRequest$Method; return-void .end method