.class public abstract Lcom/singular/sdk/internal/SingularRequestHandler; .super Ljava/lang/Object; .source "SourceFile" # static fields .field public static final POST_PAYLOAD_PARAMS_KEYS:[Ljava/lang/String; .field public static counter:I .field public static final logger:Lcom/singular/sdk/internal/SingularLog; # direct methods .method static constructor ()V .locals 2 const-class v0, Lcom/singular/sdk/internal/SingularRequestHandler; .line 29 invoke-virtual {v0}, Ljava/lang/Class;->getSimpleName()Ljava/lang/String; move-result-object v0 invoke-static {v0}, Lcom/singular/sdk/internal/SingularLog;->getLogger(Ljava/lang/String;)Lcom/singular/sdk/internal/SingularLog; move-result-object v0 sput-object v0, Lcom/singular/sdk/internal/SingularRequestHandler;->logger:Lcom/singular/sdk/internal/SingularLog; const/4 v0, 0x0 sput v0, Lcom/singular/sdk/internal/SingularRequestHandler;->counter:I const-string v0, "e" const-string v1, "global_properties" filled-new-array {v0, v1}, [Ljava/lang/String; move-result-object v0 sput-object v0, Lcom/singular/sdk/internal/SingularRequestHandler;->POST_PAYLOAD_PARAMS_KEYS:[Ljava/lang/String; return-void .end method .method public static appendHash(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String; .locals 3 if-nez p0, :cond_0 const-string p0, "" return-object p0 :cond_0 const-string v0, "?%s" filled-new-array {p0}, [Ljava/lang/Object; move-result-object v1 .line 259 invoke-static {v0, v1}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String; move-result-object v0 invoke-static {v0, p1}, Lcom/singular/sdk/internal/Utils;->sha1Hash(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String; move-result-object p1 sget-object v0, Lcom/singular/sdk/internal/SingularRequestHandler;->logger:Lcom/singular/sdk/internal/SingularLog; const-string v1, "hash = %s" filled-new-array {p1}, [Ljava/lang/Object; move-result-object v2 .line 260 invoke-virtual {v0, v1, v2}, Lcom/singular/sdk/internal/SingularLog;->debug(Ljava/lang/String;[Ljava/lang/Object;)I .line 261 invoke-static {p1}, Lcom/singular/sdk/internal/Utils;->isEmptyOrNull(Ljava/lang/String;)Z move-result v0 if-eqz v0, :cond_1 goto :goto_0 :cond_1 new-instance v0, Ljava/lang/StringBuilder; invoke-direct {v0}, Ljava/lang/StringBuilder;->()V .line 263 invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string p0, "&h=" invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p0 :goto_0 return-object p0 .end method .method public static buildRequest(Lcom/singular/sdk/internal/SingularInstance;Ljava/lang/String;Ljava/util/Map;J)Ljava/net/HttpURLConnection; .locals 1 .line 76 invoke-static {p2}, Lcom/singular/sdk/internal/SingularRequestHandler;->getPostPayloadParams(Ljava/util/Map;)Ljava/util/Map; move-result-object v0 .line 79 invoke-static {p0, p2, p3, p4}, Lcom/singular/sdk/internal/SingularRequestHandler;->getQueryString(Lcom/singular/sdk/internal/SingularInstance;Ljava/util/Map;J)Ljava/lang/String; move-result-object p2 .line 82 invoke-virtual {p0}, Lcom/singular/sdk/internal/SingularInstance;->getSingularConfig()Lcom/singular/sdk/SingularConfig; move-result-object p3 iget-object p3, p3, Lcom/singular/sdk/SingularConfig;->secret:Ljava/lang/String; invoke-static {p2, p3}, Lcom/singular/sdk/internal/SingularRequestHandler;->appendHash(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String; move-result-object p2 .line 85 new-instance p3, Ljava/lang/StringBuilder; invoke-direct {p3}, Ljava/lang/StringBuilder;->()V invoke-virtual {p3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string p1, "?" invoke-virtual {p3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p3, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 .line 88 new-instance p2, Ljava/net/URL; invoke-direct {p2, p1}, Ljava/net/URL;->(Ljava/lang/String;)V .line 89 invoke-virtual {p2}, Ljava/net/URL;->getProtocol()Ljava/lang/String; move-result-object p3 const-string p4, "https" invoke-virtual {p3, p4}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z move-result p3 if-eqz p3, :cond_0 .line 90 invoke-static {p2}, Lcom/singular/sdk/internal/SingularRequestHandler;->getHttpsConnection(Ljava/net/URL;)Ljava/net/HttpURLConnection; move-result-object p2 goto :goto_0 .line 91 :cond_0 invoke-static {p2}, Lcom/singular/sdk/internal/SingularRequestHandler;->getHttpConnection(Ljava/net/URL;)Ljava/net/HttpURLConnection; move-result-object p2 .line 94 :goto_0 invoke-static {p2}, Lcom/singular/sdk/internal/SingularRequestHandler;->setDefaultConnectionProperties(Ljava/net/HttpURLConnection;)V .line 96 invoke-virtual {p0}, Lcom/singular/sdk/internal/SingularInstance;->getSingularConfig()Lcom/singular/sdk/SingularConfig; move-result-object p0 iget-object p0, p0, Lcom/singular/sdk/SingularConfig;->secret:Ljava/lang/String; invoke-static {p2, v0, p0}, Lcom/singular/sdk/internal/SingularRequestHandler;->setPayloadForRequest(Ljava/net/HttpURLConnection;Ljava/util/Map;Ljava/lang/String;)V sget-object p0, Lcom/singular/sdk/internal/SingularRequestHandler;->logger:Lcom/singular/sdk/internal/SingularLog; .line 98 invoke-virtual {p2}, Ljava/net/HttpURLConnection;->getRequestMethod()Ljava/lang/String; move-result-object p3 filled-new-array {p3, p1}, [Ljava/lang/Object; move-result-object p1 const-string p3, "__API__ %s %s" invoke-virtual {p0, p3, p1}, Lcom/singular/sdk/internal/SingularLog;->debug(Ljava/lang/String;[Ljava/lang/Object;)I return-object p2 .end method .method public static getHttpConnection(Ljava/net/URL;)Ljava/net/HttpURLConnection; .locals 0 if-eqz p0, :cond_0 .line 275 invoke-virtual {p0}, Ljava/net/URL;->openConnection()Ljava/net/URLConnection; move-result-object p0 invoke-static {p0}, Lcom/google/firebase/perf/network/FirebasePerfUrlConnection;->instrument(Ljava/lang/Object;)Ljava/lang/Object; move-result-object p0 check-cast p0, Ljava/net/URLConnection; check-cast p0, Ljava/net/HttpURLConnection; goto :goto_0 :cond_0 const/4 p0, 0x0 :goto_0 return-object p0 .end method .method public static getHttpsConnection(Ljava/net/URL;)Ljava/net/HttpURLConnection; .locals 0 if-nez p0, :cond_0 const/4 p0, 0x0 return-object p0 .line 284 :cond_0 invoke-virtual {p0}, Ljava/net/URL;->openConnection()Ljava/net/URLConnection; move-result-object p0 invoke-static {p0}, Lcom/google/firebase/perf/network/FirebasePerfUrlConnection;->instrument(Ljava/lang/Object;)Ljava/lang/Object; move-result-object p0 check-cast p0, Ljava/net/URLConnection; check-cast p0, Ljavax/net/ssl/HttpsURLConnection; return-object p0 .end method .method public static getPostPayloadParams(Ljava/util/Map;)Ljava/util/Map; .locals 6 .line 148 new-instance v0, Ljava/util/HashMap; invoke-direct {v0}, Ljava/util/HashMap;->()V sget-object v1, Lcom/singular/sdk/internal/SingularRequestHandler;->POST_PAYLOAD_PARAMS_KEYS:[Ljava/lang/String; .line 150 array-length v2, v1 const/4 v3, 0x0 :goto_0 if-ge v3, v2, :cond_1 aget-object v4, v1, v3 .line 151 invoke-interface {p0, v4}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z move-result v5 if-eqz v5, :cond_0 .line 152 invoke-interface {p0, v4}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v5 invoke-interface {v0, v4, v5}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 155 invoke-interface {p0, v4}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object; :cond_0 add-int/lit8 v3, v3, 0x1 goto :goto_0 :cond_1 return-object v0 .end method .method public static getQueryString(Lcom/singular/sdk/internal/SingularInstance;Ljava/util/Map;J)Ljava/lang/String; .locals 3 .line 220 new-instance v0, Ljava/lang/StringBuilder; invoke-direct {v0}, Ljava/lang/StringBuilder;->()V .line 223 new-instance v1, Ljava/util/TreeMap; if-eqz p1, :cond_0 goto :goto_0 :cond_0 new-instance p1, Ljava/util/HashMap; invoke-direct {p1}, Ljava/util/HashMap;->()V :goto_0 invoke-direct {v1, p1}, Ljava/util/TreeMap;->(Ljava/util/Map;)V const-string p1, "rt" const-string v2, "json" .line 225 invoke-interface {v1, p1, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 226 invoke-static {p2, p3}, Lcom/singular/sdk/internal/Utils;->lagSince(J)D move-result-wide p1 invoke-static {p1, p2}, Ljava/lang/String;->valueOf(D)Ljava/lang/String; move-result-object p1 const-string p2, "lag" invoke-interface {v1, p2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 227 invoke-virtual {p0}, Lcom/singular/sdk/internal/SingularInstance;->getContext()Landroid/content/Context; move-result-object p0 invoke-static {p0}, Lcom/singular/sdk/internal/Utils;->getConnectionType(Landroid/content/Context;)Ljava/lang/String; move-result-object p0 const-string p1, "c" invoke-interface {v1, p1, p0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 230 invoke-interface {v1}, Ljava/util/Map;->entrySet()Ljava/util/Set; move-result-object p0 invoke-interface {p0}, Ljava/util/Set;->iterator()Ljava/util/Iterator; move-result-object p0 :goto_1 invoke-interface {p0}, Ljava/util/Iterator;->hasNext()Z move-result p1 if-eqz p1, :cond_3 invoke-interface {p0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object p1 check-cast p1, Ljava/util/Map$Entry; .line 231 invoke-interface {p1}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object; move-result-object p2 check-cast p2, Ljava/lang/String; const-string p3, "UTF-8" invoke-static {p2, p3}, Ljava/net/URLEncoder;->encode(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String; move-result-object p2 .line 232 invoke-interface {p1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object; move-result-object p1 check-cast p1, Ljava/lang/String; if-eqz p1, :cond_1 .line 233 invoke-static {p1, p3}, Ljava/net/URLEncoder;->encode(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String; move-result-object p1 goto :goto_2 :cond_1 const-string p1, "" .line 234 :goto_2 invoke-virtual {v0}, Ljava/lang/StringBuilder;->length()I move-result p3 if-lez p3, :cond_2 const-string p3, "&" .line 235 invoke-virtual {v0, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; .line 238 :cond_2 invoke-virtual {v0, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string p2, "=" .line 239 invoke-virtual {v0, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; .line 240 invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; goto :goto_1 .line 243 :cond_3 invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p0 return-object p0 .end method .method public static makeRequest(Lcom/singular/sdk/internal/SingularInstance;Ljava/lang/String;Ljava/util/Map;JLcom/singular/sdk/internal/Api$OnApiCallback;)Z .locals 6 .line 52 invoke-static {}, Lcom/singular/sdk/internal/Utils;->getCurrentTimeMillis()J move-result-wide v2 sget v0, Lcom/singular/sdk/internal/SingularRequestHandler;->counter:I add-int/lit8 v4, v0, 0x1 sput v4, Lcom/singular/sdk/internal/SingularRequestHandler;->counter:I sget-object v0, Lcom/singular/sdk/internal/SingularRequestHandler;->logger:Lcom/singular/sdk/internal/SingularLog; .line 55 invoke-static {v4}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object v1 filled-new-array {v1}, [Ljava/lang/Object; move-result-object v1 const-string v5, "---------------------------> /%d" invoke-virtual {v0, v5, v1}, Lcom/singular/sdk/internal/SingularLog;->debug(Ljava/lang/String;[Ljava/lang/Object;)I const-string v1, "url = %s" filled-new-array {p1}, [Ljava/lang/Object; move-result-object v5 .line 56 invoke-virtual {v0, v1, v5}, Lcom/singular/sdk/internal/SingularLog;->debug(Ljava/lang/String;[Ljava/lang/Object;)I const-string v1, "params = %s" filled-new-array {p2}, [Ljava/lang/Object; move-result-object v5 .line 57 invoke-virtual {v0, v1, v5}, Lcom/singular/sdk/internal/SingularLog;->debug(Ljava/lang/String;[Ljava/lang/Object;)I .line 59 invoke-static {p0, p1, p2, p3, p4}, Lcom/singular/sdk/internal/SingularRequestHandler;->buildRequest(Lcom/singular/sdk/internal/SingularInstance;Ljava/lang/String;Ljava/util/Map;J)Ljava/net/HttpURLConnection; move-result-object p1 move-object v0, p0 move-object v1, p5 move-object v5, p1 .line 62 :try_start_0 invoke-static/range {v0 .. v5}, Lcom/singular/sdk/internal/SingularRequestHandler;->sendRequest(Lcom/singular/sdk/internal/SingularInstance;Lcom/singular/sdk/internal/Api$OnApiCallback;JILjava/net/HttpURLConnection;)Z move-result p0 :try_end_0 .catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 if-eqz p1, :cond_0 .line 68 invoke-virtual {p1}, Ljava/net/HttpURLConnection;->disconnect()V :cond_0 return p0 :catchall_0 move-exception p0 goto :goto_0 :catch_0 move-exception p0 .line 64 :try_start_1 throw p0 :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 :goto_0 if-eqz p1, :cond_1 .line 68 invoke-virtual {p1}, Ljava/net/HttpURLConnection;->disconnect()V .line 70 :cond_1 throw p0 .end method .method public static readResponse(Ljava/net/HttpURLConnection;)Ljava/lang/String; .locals 3 .line 125 new-instance v0, Ljava/lang/StringBuffer; invoke-direct {v0}, Ljava/lang/StringBuffer;->()V .line 126 invoke-virtual {p0}, Ljava/net/URLConnection;->getInputStream()Ljava/io/InputStream; move-result-object v1 .line 129 invoke-virtual {p0}, Ljava/net/URLConnection;->getContentEncoding()Ljava/lang/String; move-result-object v2 if-eqz v2, :cond_0 invoke-virtual {p0}, Ljava/net/URLConnection;->getContentEncoding()Ljava/lang/String; move-result-object p0 const-string v2, "gzip" invoke-virtual {p0, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result p0 if-eqz p0, :cond_0 .line 130 new-instance p0, Ljava/io/InputStreamReader; new-instance v2, Ljava/util/zip/GZIPInputStream; invoke-direct {v2, v1}, Ljava/util/zip/GZIPInputStream;->(Ljava/io/InputStream;)V invoke-direct {p0, v2}, Ljava/io/InputStreamReader;->(Ljava/io/InputStream;)V goto :goto_0 .line 132 :cond_0 new-instance p0, Ljava/io/InputStreamReader; invoke-direct {p0, v1}, Ljava/io/InputStreamReader;->(Ljava/io/InputStream;)V .line 135 :goto_0 new-instance v1, Ljava/io/BufferedReader; invoke-direct {v1, p0}, Ljava/io/BufferedReader;->(Ljava/io/Reader;)V .line 139 :goto_1 invoke-virtual {v1}, Ljava/io/BufferedReader;->readLine()Ljava/lang/String; move-result-object p0 if-eqz p0, :cond_1 .line 140 invoke-virtual {v0, p0}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer; goto :goto_1 .line 143 :cond_1 invoke-virtual {v0}, Ljava/lang/StringBuffer;->toString()Ljava/lang/String; move-result-object p0 return-object p0 .end method .method public static sendRequest(Lcom/singular/sdk/internal/SingularInstance;Lcom/singular/sdk/internal/Api$OnApiCallback;JILjava/net/HttpURLConnection;)Z .locals 4 .line 105 invoke-virtual {p5}, Ljava/net/URLConnection;->connect()V .line 108 invoke-virtual {p5}, Ljava/net/HttpURLConnection;->getResponseCode()I move-result v0 .line 110 invoke-static {p5}, Lcom/singular/sdk/internal/SingularRequestHandler;->readResponse(Ljava/net/HttpURLConnection;)Ljava/lang/String; move-result-object v1 .line 112 invoke-virtual {p5}, Ljava/net/HttpURLConnection;->disconnect()V .line 115 invoke-static {}, Lcom/singular/sdk/internal/Utils;->getCurrentTimeMillis()J move-result-wide v2 sub-long/2addr v2, p2 sget-object p2, Lcom/singular/sdk/internal/SingularRequestHandler;->logger:Lcom/singular/sdk/internal/SingularLog; .line 117 invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object p3 filled-new-array {p3, v1}, [Ljava/lang/Object; move-result-object p3 const-string p5, "%d %s" invoke-virtual {p2, p5, p3}, Lcom/singular/sdk/internal/SingularLog;->debug(Ljava/lang/String;[Ljava/lang/Object;)I .line 118 invoke-static {p4}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object p3 invoke-static {v2, v3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object p4 filled-new-array {p3, p4}, [Ljava/lang/Object; move-result-object p3 const-string p4, "<--------------------------- /%d - took %dms" invoke-virtual {p2, p4, p3}, Lcom/singular/sdk/internal/SingularLog;->debug(Ljava/lang/String;[Ljava/lang/Object;)I .line 121 invoke-interface {p1, p0, v0, v1}, Lcom/singular/sdk/internal/Api$OnApiCallback;->handle(Lcom/singular/sdk/internal/SingularInstance;ILjava/lang/String;)Z move-result p0 return p0 .end method .method public static setDefaultConnectionProperties(Ljava/net/HttpURLConnection;)V .locals 2 const/16 v0, 0x2710 .line 194 invoke-virtual {p0, v0}, Ljava/net/URLConnection;->setConnectTimeout(I)V .line 195 invoke-virtual {p0, v0}, Ljava/net/URLConnection;->setReadTimeout(I)V const-string v0, "POST" .line 196 invoke-virtual {p0, v0}, Ljava/net/HttpURLConnection;->setRequestMethod(Ljava/lang/String;)V const/4 v0, 0x1 .line 197 invoke-virtual {p0, v0}, Ljava/net/URLConnection;->setDoInput(Z)V const/4 v0, 0x0 .line 201 invoke-virtual {p0, v0}, Ljava/net/URLConnection;->setUseCaches(Z)V const-string v0, "User-Agent" .line 202 sget-object v1, Lcom/singular/sdk/internal/Constants;->HTTP_USER_AGENT:Ljava/lang/String; invoke-virtual {p0, v0, v1}, Ljava/net/URLConnection;->setRequestProperty(Ljava/lang/String;Ljava/lang/String;)V const-string v0, "Content-Type" const-string v1, "application/json" .line 203 invoke-virtual {p0, v0, v1}, Ljava/net/URLConnection;->setRequestProperty(Ljava/lang/String;Ljava/lang/String;)V return-void .end method .method public static setPayloadForRequest(Ljava/net/HttpURLConnection;Ljava/util/Map;Ljava/lang/String;)V .locals 2 if-nez p0, :cond_0 return-void .line 168 :cond_0 :try_start_0 new-instance v0, Lorg/json/JSONObject; invoke-direct {v0}, Lorg/json/JSONObject;->()V if-eqz p1, :cond_1 .line 170 invoke-interface {p1}, Ljava/util/Map;->size()I move-result v1 if-lez v1, :cond_1 .line 171 new-instance v1, Lorg/json/JSONObject; invoke-direct {v1, p1}, Lorg/json/JSONObject;->(Ljava/util/Map;)V .line 172 invoke-virtual {v1}, Lorg/json/JSONObject;->toString()Ljava/lang/String; move-result-object p1 .line 173 invoke-static {p1, p2}, Lcom/singular/sdk/internal/Utils;->sha1Hash(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String; move-result-object p2 const-string v1, "payload" .line 175 invoke-virtual {v0, v1, p1}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject; const-string p1, "signature" .line 176 invoke-virtual {v0, p1, p2}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject; goto :goto_0 :catch_0 move-exception p0 goto :goto_1 :catch_1 move-exception p0 goto :goto_1 .line 179 :cond_1 :goto_0 new-instance p1, Ljava/io/OutputStreamWriter; invoke-virtual {p0}, Ljava/net/URLConnection;->getOutputStream()Ljava/io/OutputStream; move-result-object p0 const-string p2, "UTF-8" invoke-direct {p1, p0, p2}, Ljava/io/OutputStreamWriter;->(Ljava/io/OutputStream;Ljava/lang/String;)V .line 180 invoke-virtual {v0}, Lorg/json/JSONObject;->toString()Ljava/lang/String; move-result-object p0 invoke-virtual {p1, p0}, Ljava/io/Writer;->write(Ljava/lang/String;)V .line 181 invoke-virtual {p1}, Ljava/io/OutputStreamWriter;->close()V :try_end_0 .catch Lorg/json/JSONException; {:try_start_0 .. :try_end_0} :catch_1 .catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_0 goto :goto_2 .line 184 :goto_1 invoke-virtual {p0}, Ljava/lang/Throwable;->printStackTrace()V :goto_2 return-void .end method