- Imported from https://github.com/supermegamestre/Project-Real-Resurrection-3 - APKTool decompilation (Smali bytecode) for modding and rebuilding APK - Supports both 32-bit (armeabi-v7a) and 64-bit (arm64-v8a) architectures - Includes full Smali source, resources, and native libraries - Ready to rebuild APK after modifications with apktool b command - Added comprehensive README-apktool.md with modding guide This branch complements the JADX branches: - Use JADX (main/discord-community) to UNDERSTAND code (readable Java) - Use APKTool (this branch) to MODIFY and REBUILD APK (editable Smali) Total: 44,417 files, 538.51 MB Smali source code
3890 lines
100 KiB
Smali
3890 lines
100 KiB
Smali
.class Lcom/ea/nimble/NetworkConnection;
|
|
.super Ljava/lang/Object;
|
|
.source "SourceFile"
|
|
|
|
# interfaces
|
|
.implements Lcom/ea/nimble/NetworkConnectionHandle;
|
|
.implements Ljava/lang/Runnable;
|
|
.implements Lcom/ea/nimble/LogSource;
|
|
|
|
|
|
# static fields
|
|
.field private static final MAXIMUM_RAW_DATA_LENGTH:I = 0x100000
|
|
|
|
.field static s_loggingIdCount:I = 0x64
|
|
|
|
|
|
# instance fields
|
|
.field private m_completionCallback:Lcom/ea/nimble/NetworkConnectionCallback;
|
|
|
|
.field private m_connectionStartTimestamp:Ljava/util/Date;
|
|
|
|
.field private m_headerCallback:Lcom/ea/nimble/NetworkConnectionCallback;
|
|
|
|
.field private final m_loggingId:Ljava/lang/String;
|
|
|
|
.field private final m_manager:Lcom/ea/nimble/NetworkImpl;
|
|
|
|
.field private m_otDispatch:Lcom/ea/nimble/IOperationalTelemetryDispatch;
|
|
|
|
.field private m_progressCallback:Lcom/ea/nimble/NetworkConnectionCallback;
|
|
|
|
.field private final m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.field private m_requestDataForLog:Ljava/lang/String;
|
|
|
|
.field private final m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.field private m_responseDataForLog:Ljava/lang/StringBuilder;
|
|
|
|
.field private m_thread:Ljava/lang/Thread;
|
|
|
|
|
|
# direct methods
|
|
.method static constructor <clinit>()V
|
|
.locals 0
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public constructor <init>(Lcom/ea/nimble/NetworkImpl;Lcom/ea/nimble/HttpRequest;)V
|
|
.locals 1
|
|
|
|
const/4 v0, 0x0
|
|
|
|
.line 37
|
|
invoke-direct {p0, p1, p2, v0}, Lcom/ea/nimble/NetworkConnection;-><init>(Lcom/ea/nimble/NetworkImpl;Lcom/ea/nimble/HttpRequest;Lcom/ea/nimble/IOperationalTelemetryDispatch;)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public constructor <init>(Lcom/ea/nimble/NetworkImpl;Lcom/ea/nimble/HttpRequest;Lcom/ea/nimble/IOperationalTelemetryDispatch;)V
|
|
.locals 0
|
|
|
|
.line 42
|
|
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
|
|
|
|
iput-object p1, p0, Lcom/ea/nimble/NetworkConnection;->m_manager:Lcom/ea/nimble/NetworkImpl;
|
|
|
|
const/4 p1, 0x0
|
|
|
|
iput-object p1, p0, Lcom/ea/nimble/NetworkConnection;->m_thread:Ljava/lang/Thread;
|
|
|
|
iput-object p2, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 46
|
|
new-instance p2, Lcom/ea/nimble/HttpResponse;
|
|
|
|
invoke-direct {p2}, Lcom/ea/nimble/HttpResponse;-><init>()V
|
|
|
|
iput-object p2, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
iput-object p1, p0, Lcom/ea/nimble/NetworkConnection;->m_headerCallback:Lcom/ea/nimble/NetworkConnectionCallback;
|
|
|
|
iput-object p1, p0, Lcom/ea/nimble/NetworkConnection;->m_progressCallback:Lcom/ea/nimble/NetworkConnectionCallback;
|
|
|
|
iput-object p1, p0, Lcom/ea/nimble/NetworkConnection;->m_completionCallback:Lcom/ea/nimble/NetworkConnectionCallback;
|
|
|
|
iput-object p1, p0, Lcom/ea/nimble/NetworkConnection;->m_connectionStartTimestamp:Ljava/util/Date;
|
|
|
|
iput-object p3, p0, Lcom/ea/nimble/NetworkConnection;->m_otDispatch:Lcom/ea/nimble/IOperationalTelemetryDispatch;
|
|
|
|
sget p1, Lcom/ea/nimble/NetworkConnection;->s_loggingIdCount:I
|
|
|
|
.line 55
|
|
invoke-static {p1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
iput-object p1, p0, Lcom/ea/nimble/NetworkConnection;->m_loggingId:Ljava/lang/String;
|
|
|
|
sget p1, Lcom/ea/nimble/NetworkConnection;->s_loggingIdCount:I
|
|
|
|
add-int/lit8 p2, p1, 0x1
|
|
|
|
sput p2, Lcom/ea/nimble/NetworkConnection;->s_loggingIdCount:I
|
|
|
|
const/16 p2, 0x3e8
|
|
|
|
if-lt p1, p2, :cond_0
|
|
|
|
const/16 p1, 0x64
|
|
|
|
sput p1, Lcom/ea/nimble/NetworkConnection;->s_loggingIdCount:I
|
|
|
|
:cond_0
|
|
return-void
|
|
.end method
|
|
|
|
.method private beautifyJSONString(Ljava/lang/String;)Ljava/lang/String;
|
|
.locals 3
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 726
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGFUNCS(Ljava/lang/String;)V
|
|
|
|
if-nez p1, :cond_0
|
|
|
|
return-object p1
|
|
|
|
.line 738
|
|
:cond_0
|
|
:try_start_0
|
|
new-instance v0, Lorg/json/JSONTokener;
|
|
|
|
invoke-direct {v0, p1}, Lorg/json/JSONTokener;-><init>(Ljava/lang/String;)V
|
|
|
|
invoke-virtual {v0}, Lorg/json/JSONTokener;->nextValue()Ljava/lang/Object;
|
|
|
|
move-result-object v0
|
|
|
|
.line 740
|
|
instance-of v1, v0, Lorg/json/JSONObject;
|
|
|
|
const/4 v2, 0x4
|
|
|
|
if-eqz v1, :cond_1
|
|
|
|
.line 742
|
|
check-cast v0, Lorg/json/JSONObject;
|
|
|
|
invoke-virtual {v0, v2}, Lorg/json/JSONObject;->toString(I)Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
|
|
goto :goto_0
|
|
|
|
.line 744
|
|
:cond_1
|
|
instance-of v1, v0, Lorg/json/JSONArray;
|
|
|
|
if-eqz v1, :cond_2
|
|
|
|
.line 746
|
|
check-cast v0, Lorg/json/JSONArray;
|
|
|
|
invoke-virtual {v0, v2}, Lorg/json/JSONArray;->toString(I)Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
:try_end_0
|
|
.catch Lorg/json/JSONException; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
goto :goto_0
|
|
|
|
:cond_2
|
|
const/4 v0, 0x0
|
|
|
|
:goto_0
|
|
if-eqz v0, :cond_3
|
|
|
|
move-object p1, v0
|
|
|
|
:catch_0
|
|
:cond_3
|
|
return-object p1
|
|
.end method
|
|
|
|
.method private downloadToBuffer(Ljava/io/InputStream;)V
|
|
.locals 8
|
|
.annotation system Ldalvik/annotation/Throws;
|
|
value = {
|
|
Ljava/io/IOException;
|
|
}
|
|
.end annotation
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 560
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGFUNCS(Ljava/lang/String;)V
|
|
|
|
.line 565
|
|
invoke-direct {p0}, Lcom/ea/nimble/NetworkConnection;->prepareResponseLog()V
|
|
|
|
:goto_0
|
|
:try_start_0
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 570
|
|
iget-object v0, v0, Lcom/ea/nimble/HttpResponse;->data:Lcom/ea/nimble/ByteBufferIOStream;
|
|
|
|
invoke-virtual {v0}, Lcom/ea/nimble/ByteBufferIOStream;->prepareSegment()[B
|
|
|
|
move-result-object v0
|
|
|
|
const/4 v1, 0x0
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
const-string v0, "Error preparing segment"
|
|
|
|
new-array v1, v1, [Ljava/lang/Object;
|
|
|
|
.line 573
|
|
invoke-static {p0, v0, v1}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
goto :goto_3
|
|
|
|
:catchall_0
|
|
move-exception v0
|
|
|
|
goto :goto_4
|
|
|
|
.line 579
|
|
:cond_0
|
|
array-length v2, v0
|
|
|
|
sub-int/2addr v2, v1
|
|
|
|
invoke-virtual {p1, v0, v1, v2}, Ljava/io/InputStream;->read([BII)I
|
|
|
|
move-result v2
|
|
|
|
.line 580
|
|
invoke-static {}, Ljava/lang/Thread;->interrupted()Z
|
|
|
|
move-result v3
|
|
|
|
if-nez v3, :cond_5
|
|
|
|
if-gez v2, :cond_1
|
|
|
|
goto :goto_2
|
|
|
|
:cond_1
|
|
if-nez v2, :cond_2
|
|
|
|
.line 590
|
|
invoke-static {}, Ljava/lang/Thread;->yield()V
|
|
|
|
goto :goto_1
|
|
|
|
.line 594
|
|
:cond_2
|
|
invoke-direct {p0, v0, v1, v2}, Lcom/ea/nimble/NetworkConnection;->prepareResponseLog([BII)V
|
|
|
|
add-int/2addr v1, v2
|
|
|
|
iget-object v3, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 596
|
|
iget-wide v4, v3, Lcom/ea/nimble/HttpResponse;->downloadedContentLength:J
|
|
|
|
int-to-long v6, v2
|
|
|
|
add-long/2addr v4, v6
|
|
|
|
iput-wide v4, v3, Lcom/ea/nimble/HttpResponse;->downloadedContentLength:J
|
|
|
|
.line 597
|
|
:goto_1
|
|
array-length v3, v0
|
|
|
|
if-lt v1, v3, :cond_0
|
|
|
|
:goto_2
|
|
iget-object v3, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 598
|
|
iget-object v3, v3, Lcom/ea/nimble/HttpResponse;->data:Lcom/ea/nimble/ByteBufferIOStream;
|
|
|
|
invoke-virtual {v3, v0, v1}, Lcom/ea/nimble/ByteBufferIOStream;->appendSegmentToBuffer([BI)V
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_progressCallback:Lcom/ea/nimble/NetworkConnectionCallback;
|
|
|
|
if-eqz v0, :cond_3
|
|
|
|
.line 601
|
|
invoke-interface {v0, p0}, Lcom/ea/nimble/NetworkConnectionCallback;->callback(Lcom/ea/nimble/NetworkConnectionHandle;)V
|
|
:try_end_0
|
|
.catchall {:try_start_0 .. :try_end_0} :catchall_0
|
|
|
|
:cond_3
|
|
if-ltz v2, :cond_4
|
|
|
|
goto :goto_0
|
|
|
|
.line 607
|
|
:cond_4
|
|
:goto_3
|
|
invoke-virtual {p1}, Ljava/io/InputStream;->close()V
|
|
|
|
return-void
|
|
|
|
.line 582
|
|
:cond_5
|
|
:try_start_1
|
|
new-instance v0, Ljava/io/InterruptedIOException;
|
|
|
|
invoke-direct {v0}, Ljava/io/InterruptedIOException;-><init>()V
|
|
|
|
throw v0
|
|
:try_end_1
|
|
.catchall {:try_start_1 .. :try_end_1} :catchall_0
|
|
|
|
.line 607
|
|
:goto_4
|
|
invoke-virtual {p1}, Ljava/io/InputStream;->close()V
|
|
|
|
.line 608
|
|
throw v0
|
|
.end method
|
|
|
|
.method private downloadToFile(Ljava/io/InputStream;)V
|
|
.locals 14
|
|
.annotation system Ldalvik/annotation/Throws;
|
|
value = {
|
|
Ljava/io/IOException;
|
|
}
|
|
.end annotation
|
|
|
|
const-string v0, "Failed to delete file "
|
|
|
|
const-string v1, "NetworkConnection"
|
|
|
|
.line 463
|
|
invoke-static {v1}, Lcom/ea/nimble/Log$Helper;->LOGFUNCS(Ljava/lang/String;)V
|
|
|
|
if-nez p1, :cond_0
|
|
|
|
return-void
|
|
|
|
.line 470
|
|
:cond_0
|
|
new-instance v1, Ljava/io/File;
|
|
|
|
iget-object v2, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
iget-object v2, v2, Lcom/ea/nimble/HttpRequest;->targetFilePath:Ljava/lang/String;
|
|
|
|
invoke-direct {v1, v2}, Ljava/io/File;-><init>(Ljava/lang/String;)V
|
|
|
|
.line 471
|
|
invoke-static {}, Lcom/ea/nimble/ApplicationEnvironment;->getComponent()Lcom/ea/nimble/IApplicationEnvironment;
|
|
|
|
move-result-object v2
|
|
|
|
invoke-interface {v2}, Lcom/ea/nimble/IApplicationEnvironment;->getCachePath()Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
.line 472
|
|
new-instance v3, Ljava/io/File;
|
|
|
|
new-instance v4, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
sget-object v2, Ljava/io/File;->separator:Ljava/lang/String;
|
|
|
|
invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v1}, Ljava/io/File;->getName()Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
invoke-direct {v3, v2}, Ljava/io/File;-><init>(Ljava/lang/String;)V
|
|
|
|
.line 474
|
|
new-instance v2, Ljava/io/FileOutputStream;
|
|
|
|
invoke-direct {v2, v3}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V
|
|
|
|
const/high16 v4, 0x10000
|
|
|
|
new-array v4, v4, [B
|
|
|
|
.line 479
|
|
new-instance v5, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v6, "Started File Download for "
|
|
|
|
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v5, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v5
|
|
|
|
const/4 v6, 0x0
|
|
|
|
new-array v7, v6, [Ljava/lang/Object;
|
|
|
|
invoke-static {p0, v5, v7}, Lcom/ea/nimble/Log$Helper;->LOGI(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
.line 483
|
|
:cond_1
|
|
:goto_0
|
|
:try_start_0
|
|
invoke-virtual {p1, v4}, Ljava/io/InputStream;->read([B)I
|
|
|
|
move-result v5
|
|
|
|
if-ltz v5, :cond_3
|
|
|
|
if-nez v5, :cond_2
|
|
|
|
.line 487
|
|
invoke-static {}, Ljava/lang/Thread;->yield()V
|
|
|
|
goto :goto_0
|
|
|
|
:catchall_0
|
|
move-exception v0
|
|
|
|
goto/16 :goto_4
|
|
|
|
.line 491
|
|
:cond_2
|
|
invoke-virtual {v2, v4, v6, v5}, Ljava/io/FileOutputStream;->write([BII)V
|
|
|
|
iget-object v7, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 492
|
|
iget-wide v8, v7, Lcom/ea/nimble/HttpResponse;->downloadedContentLength:J
|
|
|
|
int-to-long v10, v5
|
|
|
|
add-long/2addr v8, v10
|
|
|
|
iput-wide v8, v7, Lcom/ea/nimble/HttpResponse;->downloadedContentLength:J
|
|
|
|
iget-object v5, p0, Lcom/ea/nimble/NetworkConnection;->m_progressCallback:Lcom/ea/nimble/NetworkConnectionCallback;
|
|
|
|
if-eqz v5, :cond_1
|
|
|
|
.line 495
|
|
invoke-interface {v5, p0}, Lcom/ea/nimble/NetworkConnectionCallback;->callback(Lcom/ea/nimble/NetworkConnectionHandle;)V
|
|
:try_end_0
|
|
.catchall {:try_start_0 .. :try_end_0} :catchall_0
|
|
|
|
goto :goto_0
|
|
|
|
.line 501
|
|
:cond_3
|
|
invoke-virtual {p1}, Ljava/io/InputStream;->close()V
|
|
|
|
.line 502
|
|
invoke-virtual {v2}, Ljava/io/FileOutputStream;->close()V
|
|
|
|
.line 505
|
|
invoke-virtual {v1}, Ljava/io/File;->exists()Z
|
|
|
|
move-result p1
|
|
|
|
if-eqz p1, :cond_4
|
|
|
|
.line 507
|
|
invoke-virtual {v1}, Ljava/io/File;->delete()Z
|
|
|
|
move-result p1
|
|
|
|
if-nez p1, :cond_4
|
|
|
|
.line 509
|
|
new-instance p1, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v2, "Failed to delete existed target file "
|
|
|
|
invoke-virtual {p1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
new-array v2, v6, [Ljava/lang/Object;
|
|
|
|
invoke-static {p0, p1, v2}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
.line 512
|
|
:cond_4
|
|
invoke-virtual {v3, v1}, Ljava/io/File;->renameTo(Ljava/io/File;)Z
|
|
|
|
move-result p1
|
|
|
|
if-nez p1, :cond_b
|
|
|
|
.line 514
|
|
new-instance p1, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v2, "Failed to move temp file "
|
|
|
|
invoke-virtual {p1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
const-string v2, " to target file "
|
|
|
|
invoke-virtual {p1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
new-array v2, v6, [Ljava/lang/Object;
|
|
|
|
invoke-static {p0, p1, v2}, Lcom/ea/nimble/Log$Helper;->LOGI(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
.line 515
|
|
new-instance p1, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v2, "Using fallback, and copying file instead "
|
|
|
|
invoke-virtual {p1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
const-string v2, "to target file "
|
|
|
|
invoke-virtual {p1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
new-array v2, v6, [Ljava/lang/Object;
|
|
|
|
invoke-static {p0, p1, v2}, Lcom/ea/nimble/Log$Helper;->LOGI(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
.line 516
|
|
invoke-virtual {v1}, Ljava/io/File;->exists()Z
|
|
|
|
move-result p1
|
|
|
|
if-nez p1, :cond_5
|
|
|
|
.line 518
|
|
invoke-virtual {v1}, Ljava/io/File;->createNewFile()Z
|
|
|
|
move-result p1
|
|
|
|
if-nez p1, :cond_5
|
|
|
|
.line 520
|
|
new-instance p1, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v2, "Could not create target file "
|
|
|
|
invoke-virtual {p1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
new-array v2, v6, [Ljava/lang/Object;
|
|
|
|
invoke-static {p0, p1, v2}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
:cond_5
|
|
const/4 p1, 0x0
|
|
|
|
.line 529
|
|
:try_start_1
|
|
new-instance v2, Ljava/io/FileInputStream;
|
|
|
|
invoke-direct {v2, v3}, Ljava/io/FileInputStream;-><init>(Ljava/io/File;)V
|
|
|
|
invoke-virtual {v2}, Ljava/io/FileInputStream;->getChannel()Ljava/nio/channels/FileChannel;
|
|
|
|
move-result-object v2
|
|
:try_end_1
|
|
.catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_1
|
|
.catchall {:try_start_1 .. :try_end_1} :catchall_2
|
|
|
|
.line 530
|
|
:try_start_2
|
|
new-instance v4, Ljava/io/FileOutputStream;
|
|
|
|
invoke-direct {v4, v1}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V
|
|
|
|
invoke-virtual {v4}, Ljava/io/FileOutputStream;->getChannel()Ljava/nio/channels/FileChannel;
|
|
|
|
move-result-object p1
|
|
|
|
const-wide/16 v9, 0x0
|
|
|
|
.line 531
|
|
invoke-virtual {v2}, Ljava/nio/channels/FileChannel;->size()J
|
|
|
|
move-result-wide v11
|
|
|
|
move-object v7, p1
|
|
|
|
move-object v8, v2
|
|
|
|
invoke-virtual/range {v7 .. v12}, Ljava/nio/channels/FileChannel;->transferFrom(Ljava/nio/channels/ReadableByteChannel;JJ)J
|
|
:try_end_2
|
|
.catch Ljava/lang/Exception; {:try_start_2 .. :try_end_2} :catch_0
|
|
.catchall {:try_start_2 .. :try_end_2} :catchall_1
|
|
|
|
.line 541
|
|
invoke-virtual {v2}, Ljava/nio/channels/spi/AbstractInterruptibleChannel;->close()V
|
|
|
|
.line 545
|
|
invoke-virtual {p1}, Ljava/nio/channels/spi/AbstractInterruptibleChannel;->close()V
|
|
|
|
.line 547
|
|
invoke-virtual {v3}, Ljava/io/File;->exists()Z
|
|
|
|
move-result p1
|
|
|
|
if-eqz p1, :cond_b
|
|
|
|
.line 549
|
|
invoke-virtual {v3}, Ljava/io/File;->delete()Z
|
|
|
|
move-result p1
|
|
|
|
if-nez p1, :cond_b
|
|
|
|
.line 551
|
|
new-instance p1, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
new-array v0, v6, [Ljava/lang/Object;
|
|
|
|
invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGW(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
goto/16 :goto_3
|
|
|
|
:catchall_1
|
|
move-exception v1
|
|
|
|
move-object v13, v1
|
|
|
|
move-object v1, p1
|
|
|
|
move-object p1, v2
|
|
|
|
move-object v2, v13
|
|
|
|
goto :goto_2
|
|
|
|
:catch_0
|
|
move-exception v1
|
|
|
|
move-object v13, v1
|
|
|
|
move-object v1, p1
|
|
|
|
move-object p1, v2
|
|
|
|
move-object v2, v13
|
|
|
|
goto :goto_1
|
|
|
|
:catchall_2
|
|
move-exception v1
|
|
|
|
move-object v2, v1
|
|
|
|
move-object v1, p1
|
|
|
|
goto :goto_2
|
|
|
|
:catch_1
|
|
move-exception v1
|
|
|
|
move-object v2, v1
|
|
|
|
move-object v1, p1
|
|
|
|
.line 535
|
|
:goto_1
|
|
:try_start_3
|
|
new-instance v4, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v5, "ERROR while copying file, "
|
|
|
|
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
new-array v4, v6, [Ljava/lang/Object;
|
|
|
|
invoke-static {p0, v2, v4}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
:try_end_3
|
|
.catchall {:try_start_3 .. :try_end_3} :catchall_3
|
|
|
|
if-eqz p1, :cond_6
|
|
|
|
.line 541
|
|
invoke-virtual {p1}, Ljava/nio/channels/spi/AbstractInterruptibleChannel;->close()V
|
|
|
|
:cond_6
|
|
if-eqz v1, :cond_7
|
|
|
|
.line 545
|
|
invoke-virtual {v1}, Ljava/nio/channels/spi/AbstractInterruptibleChannel;->close()V
|
|
|
|
.line 547
|
|
:cond_7
|
|
invoke-virtual {v3}, Ljava/io/File;->exists()Z
|
|
|
|
move-result p1
|
|
|
|
if-eqz p1, :cond_b
|
|
|
|
.line 549
|
|
invoke-virtual {v3}, Ljava/io/File;->delete()Z
|
|
|
|
move-result p1
|
|
|
|
if-nez p1, :cond_b
|
|
|
|
.line 551
|
|
new-instance p1, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
new-array v0, v6, [Ljava/lang/Object;
|
|
|
|
invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGW(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
goto :goto_3
|
|
|
|
:catchall_3
|
|
move-exception v2
|
|
|
|
:goto_2
|
|
if-eqz p1, :cond_8
|
|
|
|
.line 541
|
|
invoke-virtual {p1}, Ljava/nio/channels/spi/AbstractInterruptibleChannel;->close()V
|
|
|
|
:cond_8
|
|
if-eqz v1, :cond_9
|
|
|
|
.line 545
|
|
invoke-virtual {v1}, Ljava/nio/channels/spi/AbstractInterruptibleChannel;->close()V
|
|
|
|
.line 547
|
|
:cond_9
|
|
invoke-virtual {v3}, Ljava/io/File;->exists()Z
|
|
|
|
move-result p1
|
|
|
|
if-eqz p1, :cond_a
|
|
|
|
.line 549
|
|
invoke-virtual {v3}, Ljava/io/File;->delete()Z
|
|
|
|
move-result p1
|
|
|
|
if-nez p1, :cond_a
|
|
|
|
.line 551
|
|
new-instance p1, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
new-array v0, v6, [Ljava/lang/Object;
|
|
|
|
invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGW(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
.line 554
|
|
:cond_a
|
|
throw v2
|
|
|
|
:cond_b
|
|
:goto_3
|
|
return-void
|
|
|
|
.line 501
|
|
:goto_4
|
|
invoke-virtual {p1}, Ljava/io/InputStream;->close()V
|
|
|
|
.line 502
|
|
invoke-virtual {v2}, Ljava/io/FileOutputStream;->close()V
|
|
|
|
.line 503
|
|
throw v0
|
|
.end method
|
|
|
|
.method private finish()V
|
|
.locals 2
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 614
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGFUNCS(Ljava/lang/String;)V
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
const/4 v1, 0x1
|
|
|
|
.line 615
|
|
iput-boolean v1, v0, Lcom/ea/nimble/HttpResponse;->isCompleted:Z
|
|
|
|
.line 618
|
|
invoke-virtual {p0}, Lcom/ea/nimble/NetworkConnection;->logOperationalTelemetryResponse()V
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_completionCallback:Lcom/ea/nimble/NetworkConnectionCallback;
|
|
|
|
if-eqz v0, :cond_0
|
|
|
|
.line 623
|
|
invoke-interface {v0, p0}, Lcom/ea/nimble/NetworkConnectionCallback;->callback(Lcom/ea/nimble/NetworkConnectionHandle;)V
|
|
|
|
.line 625
|
|
:cond_0
|
|
monitor-enter p0
|
|
|
|
.line 627
|
|
:try_start_0
|
|
invoke-virtual {p0}, Ljava/lang/Object;->notifyAll()V
|
|
|
|
.line 628
|
|
monitor-exit p0
|
|
:try_end_0
|
|
.catchall {:try_start_0 .. :try_end_0} :catchall_0
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_manager:Lcom/ea/nimble/NetworkImpl;
|
|
|
|
.line 630
|
|
invoke-virtual {v0, p0}, Lcom/ea/nimble/NetworkImpl;->removeConnection(Lcom/ea/nimble/NetworkConnection;)V
|
|
|
|
return-void
|
|
|
|
:catchall_0
|
|
move-exception v0
|
|
|
|
.line 628
|
|
:try_start_1
|
|
monitor-exit p0
|
|
:try_end_1
|
|
.catchall {:try_start_1 .. :try_end_1} :catchall_0
|
|
|
|
throw v0
|
|
.end method
|
|
|
|
.method private generateHttpHeaderAndBodyLogString(Ljava/lang/StringBuilder;ZLjava/util/Map;Ljava/lang/String;)V
|
|
.locals 9
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(",
|
|
"Ljava/lang/StringBuilder;",
|
|
"Z",
|
|
"Ljava/util/Map<",
|
|
"Ljava/lang/String;",
|
|
"Ljava/lang/String;",
|
|
">;",
|
|
"Ljava/lang/String;",
|
|
")V"
|
|
}
|
|
.end annotation
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 847
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGFUNCS(Ljava/lang/String;)V
|
|
|
|
if-eqz p2, :cond_0
|
|
|
|
const-string v0, "RESP"
|
|
|
|
goto :goto_0
|
|
|
|
:cond_0
|
|
const-string v0, "REQ"
|
|
|
|
:goto_0
|
|
const/16 v1, 0xa
|
|
|
|
const/4 v2, 0x0
|
|
|
|
if-eqz p3, :cond_9
|
|
|
|
.line 852
|
|
invoke-interface {p3}, Ljava/util/Map;->size()I
|
|
|
|
move-result v3
|
|
|
|
if-lez v3, :cond_9
|
|
|
|
.line 854
|
|
invoke-interface {p3}, Ljava/util/Map;->entrySet()Ljava/util/Set;
|
|
|
|
move-result-object v3
|
|
|
|
invoke-interface {v3}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
|
|
|
|
move-result-object v3
|
|
|
|
move v4, v2
|
|
|
|
:cond_1
|
|
:goto_1
|
|
invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z
|
|
|
|
move-result v5
|
|
|
|
if-eqz v5, :cond_8
|
|
|
|
invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;
|
|
|
|
move-result-object v5
|
|
|
|
check-cast v5, Ljava/util/Map$Entry;
|
|
|
|
.line 856
|
|
invoke-interface {v5}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
|
|
|
|
move-result-object v6
|
|
|
|
check-cast v6, Ljava/lang/String;
|
|
|
|
const-string v7, "(null)"
|
|
|
|
if-nez v6, :cond_4
|
|
|
|
if-eqz p2, :cond_2
|
|
|
|
goto :goto_2
|
|
|
|
.line 875
|
|
:cond_2
|
|
invoke-interface {p3, v6}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
move-result-object v5
|
|
|
|
check-cast v5, Ljava/lang/String;
|
|
|
|
if-eqz v5, :cond_3
|
|
|
|
move-object v7, v5
|
|
|
|
:cond_3
|
|
const-string v5, "Network request contains a null key with value %s"
|
|
|
|
new-array v6, v2, [Ljava/lang/Object;
|
|
|
|
.line 877
|
|
invoke-static {v5, v7, v6}, Lcom/ea/nimble/Log$Helper;->LOGW(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
goto :goto_1
|
|
|
|
:cond_4
|
|
:goto_2
|
|
if-eqz v6, :cond_5
|
|
|
|
goto :goto_3
|
|
|
|
:cond_5
|
|
move-object v6, v7
|
|
|
|
.line 862
|
|
:goto_3
|
|
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
const-string v8, " HEADER: "
|
|
|
|
invoke-virtual {p1, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
.line 863
|
|
invoke-interface {v5}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
|
|
|
|
move-result-object v5
|
|
|
|
check-cast v5, Ljava/lang/String;
|
|
|
|
if-eqz v5, :cond_6
|
|
|
|
move-object v7, v5
|
|
|
|
:cond_6
|
|
const-string v5, " VALUE: "
|
|
|
|
.line 865
|
|
invoke-virtual {p1, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1, v1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
|
|
|
|
const-string v5, "Content-Type"
|
|
|
|
.line 866
|
|
invoke-virtual {v6, v5}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
|
|
|
|
move-result v5
|
|
|
|
if-eqz v5, :cond_1
|
|
|
|
const-string v5, "application/json"
|
|
|
|
invoke-virtual {v7, v5}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
|
|
|
|
move-result v5
|
|
|
|
if-nez v5, :cond_7
|
|
|
|
const-string v5, "text/json"
|
|
|
|
invoke-virtual {v7, v5}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
|
|
|
|
move-result v5
|
|
|
|
if-eqz v5, :cond_1
|
|
|
|
:cond_7
|
|
const/4 v4, 0x1
|
|
|
|
goto :goto_1
|
|
|
|
:cond_8
|
|
move v2, v4
|
|
|
|
:cond_9
|
|
if-eqz p4, :cond_b
|
|
|
|
.line 884
|
|
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
const-string p2, " BODY:\n"
|
|
|
|
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
if-eqz v2, :cond_a
|
|
|
|
.line 888
|
|
invoke-direct {p0, p4}, Lcom/ea/nimble/NetworkConnection;->beautifyJSONString(Ljava/lang/String;)Ljava/lang/String;
|
|
|
|
move-result-object p4
|
|
|
|
.line 894
|
|
:cond_a
|
|
invoke-virtual {p1, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1, v1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
|
|
|
|
:cond_b
|
|
return-void
|
|
.end method
|
|
|
|
.method private httpRecv(Ljava/net/HttpURLConnection;)V
|
|
.locals 10
|
|
.annotation system Ldalvik/annotation/Throws;
|
|
value = {
|
|
Ljava/io/IOException;,
|
|
Lcom/ea/nimble/Error;
|
|
}
|
|
.end annotation
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 325
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGFUNCS(Ljava/lang/String;)V
|
|
|
|
const/4 v0, 0x1
|
|
|
|
const/4 v1, 0x0
|
|
|
|
.line 336
|
|
:try_start_0
|
|
invoke-virtual {p1}, Ljava/net/URLConnection;->getInputStream()Ljava/io/InputStream;
|
|
|
|
move-result-object v2
|
|
:try_end_0
|
|
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
move v3, v1
|
|
|
|
goto :goto_0
|
|
|
|
.line 343
|
|
:catch_0
|
|
:try_start_1
|
|
invoke-virtual {p1}, Ljava/net/HttpURLConnection;->getErrorStream()Ljava/io/InputStream;
|
|
|
|
move-result-object v2
|
|
:try_end_1
|
|
.catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_1
|
|
|
|
move v3, v0
|
|
|
|
:goto_0
|
|
:try_start_2
|
|
iget-object v4, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 355
|
|
invoke-virtual {p1}, Ljava/net/URLConnection;->getURL()Ljava/net/URL;
|
|
|
|
move-result-object v5
|
|
|
|
iput-object v5, v4, Lcom/ea/nimble/HttpResponse;->url:Ljava/net/URL;
|
|
|
|
iget-object v4, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 357
|
|
invoke-virtual {p1}, Ljava/net/HttpURLConnection;->getResponseCode()I
|
|
|
|
move-result v5
|
|
|
|
iput v5, v4, Lcom/ea/nimble/HttpResponse;->statusCode:I
|
|
|
|
iget-object v4, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 358
|
|
invoke-virtual {p1}, Ljava/net/URLConnection;->getContentLength()I
|
|
|
|
move-result v5
|
|
|
|
int-to-long v5, v5
|
|
|
|
iput-wide v5, v4, Lcom/ea/nimble/HttpResponse;->expectedContentLength:J
|
|
|
|
iget-object v4, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 359
|
|
invoke-virtual {p1}, Ljava/net/URLConnection;->getLastModified()J
|
|
|
|
move-result-wide v5
|
|
|
|
iput-wide v5, v4, Lcom/ea/nimble/HttpResponse;->lastModified:J
|
|
|
|
.line 361
|
|
invoke-virtual {p1}, Ljava/net/URLConnection;->getHeaderFields()Ljava/util/Map;
|
|
|
|
move-result-object p1
|
|
|
|
invoke-interface {p1}, Ljava/util/Map;->entrySet()Ljava/util/Set;
|
|
|
|
move-result-object p1
|
|
|
|
invoke-interface {p1}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
|
|
|
|
move-result-object p1
|
|
|
|
:goto_1
|
|
invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z
|
|
|
|
move-result v4
|
|
|
|
if-eqz v4, :cond_0
|
|
|
|
invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
|
|
|
|
move-result-object v4
|
|
|
|
check-cast v4, Ljava/util/Map$Entry;
|
|
|
|
iget-object v5, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 363
|
|
iget-object v5, v5, Lcom/ea/nimble/HttpResponse;->headers:Ljava/util/HashMap;
|
|
|
|
invoke-interface {v4}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
|
|
|
|
move-result-object v6
|
|
|
|
check-cast v6, Ljava/lang/String;
|
|
|
|
const-string v7, ", "
|
|
|
|
invoke-interface {v4}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
|
|
|
|
move-result-object v4
|
|
|
|
check-cast v4, Ljava/lang/Iterable;
|
|
|
|
invoke-static {v7, v4}, Landroid/text/TextUtils;->join(Ljava/lang/CharSequence;Ljava/lang/Iterable;)Ljava/lang/String;
|
|
|
|
move-result-object v4
|
|
|
|
invoke-virtual {v5, v6, v4}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
goto :goto_1
|
|
|
|
:catchall_0
|
|
move-exception p1
|
|
|
|
goto/16 :goto_b
|
|
|
|
:cond_0
|
|
iget-object p1, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 366
|
|
iget-wide v4, p1, Lcom/ea/nimble/HttpResponse;->expectedContentLength:J
|
|
|
|
const-wide/32 v6, 0x100000
|
|
|
|
cmp-long p1, v4, v6
|
|
|
|
if-lez p1, :cond_1
|
|
|
|
move p1, v0
|
|
|
|
goto :goto_2
|
|
|
|
:cond_1
|
|
move p1, v1
|
|
|
|
:goto_2
|
|
iget-object v4, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 367
|
|
iget-object v4, v4, Lcom/ea/nimble/HttpRequest;->targetFilePath:Ljava/lang/String;
|
|
|
|
invoke-static {v4}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z
|
|
|
|
move-result v4
|
|
|
|
iget-object v5, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 368
|
|
invoke-virtual {v5}, Lcom/ea/nimble/HttpRequest;->getMethod()Lcom/ea/nimble/IHttpRequest$Method;
|
|
|
|
move-result-object v5
|
|
|
|
sget-object v6, Lcom/ea/nimble/IHttpRequest$Method;->HEAD:Lcom/ea/nimble/IHttpRequest$Method;
|
|
|
|
if-ne v5, v6, :cond_2
|
|
|
|
move v5, v0
|
|
|
|
goto :goto_3
|
|
|
|
:cond_2
|
|
move v5, v1
|
|
|
|
:goto_3
|
|
iget-object v6, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 372
|
|
iget v7, v6, Lcom/ea/nimble/HttpResponse;->statusCode:I
|
|
:try_end_2
|
|
.catchall {:try_start_2 .. :try_end_2} :catchall_0
|
|
|
|
const/16 v8, 0xc8
|
|
|
|
if-eq v7, v8, :cond_4
|
|
|
|
const/16 v8, 0xce
|
|
|
|
if-ne v7, v8, :cond_3
|
|
|
|
goto :goto_4
|
|
|
|
:cond_3
|
|
move v7, v1
|
|
|
|
goto :goto_5
|
|
|
|
:cond_4
|
|
:goto_4
|
|
move v7, v0
|
|
|
|
:goto_5
|
|
if-nez v3, :cond_5
|
|
|
|
if-eqz v2, :cond_5
|
|
|
|
if-eqz v7, :cond_5
|
|
|
|
goto :goto_6
|
|
|
|
:cond_5
|
|
move v0, v1
|
|
|
|
:goto_6
|
|
const-string v1, "Request "
|
|
|
|
if-eqz p1, :cond_8
|
|
|
|
if-nez v5, :cond_8
|
|
|
|
if-eqz v4, :cond_7
|
|
|
|
if-eqz v0, :cond_6
|
|
|
|
goto :goto_7
|
|
|
|
.line 383
|
|
:cond_6
|
|
:try_start_3
|
|
new-instance p1, Lcom/ea/nimble/Error;
|
|
|
|
sget-object v0, Lcom/ea/nimble/Error$Code;->NETWORK_OVERSIZE_DATA:Lcom/ea/nimble/Error$Code;
|
|
|
|
const-string v1, "HTTP error for file download with an oversized error response."
|
|
|
|
invoke-direct {p1, v0, v1}, Lcom/ea/nimble/Error;-><init>(Lcom/ea/nimble/Error$Code;Ljava/lang/String;)V
|
|
|
|
throw p1
|
|
|
|
.line 379
|
|
:cond_7
|
|
new-instance p1, Lcom/ea/nimble/Error;
|
|
|
|
sget-object v0, Lcom/ea/nimble/Error$Code;->NETWORK_OVERSIZE_DATA:Lcom/ea/nimble/Error$Code;
|
|
|
|
new-instance v3, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v3, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
const-string v1, " is oversize, please provide a local file path to download it as file."
|
|
|
|
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-direct {p1, v0, v1}, Lcom/ea/nimble/Error;-><init>(Lcom/ea/nimble/Error$Code;Ljava/lang/String;)V
|
|
|
|
throw p1
|
|
|
|
:cond_8
|
|
:goto_7
|
|
const-wide/16 v8, 0x0
|
|
|
|
.line 388
|
|
iput-wide v8, v6, Lcom/ea/nimble/HttpResponse;->downloadedContentLength:J
|
|
|
|
iget-object p1, p0, Lcom/ea/nimble/NetworkConnection;->m_headerCallback:Lcom/ea/nimble/NetworkConnectionCallback;
|
|
|
|
if-eqz p1, :cond_9
|
|
|
|
.line 392
|
|
invoke-interface {p1, p0}, Lcom/ea/nimble/NetworkConnectionCallback;->callback(Lcom/ea/nimble/NetworkConnectionHandle;)V
|
|
|
|
:cond_9
|
|
if-eqz v5, :cond_a
|
|
|
|
goto :goto_a
|
|
|
|
:cond_a
|
|
const/4 p1, 0x0
|
|
|
|
if-eqz v4, :cond_b
|
|
|
|
if-eqz v0, :cond_b
|
|
|
|
.line 401
|
|
invoke-direct {p0, v2}, Lcom/ea/nimble/NetworkConnection;->downloadToFile(Ljava/io/InputStream;)V
|
|
|
|
move-object v2, p1
|
|
|
|
goto :goto_a
|
|
|
|
:cond_b
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 407
|
|
iget-wide v4, v0, Lcom/ea/nimble/HttpResponse;->expectedContentLength:J
|
|
|
|
cmp-long v6, v4, v8
|
|
|
|
if-eqz v6, :cond_e
|
|
|
|
.line 409
|
|
iget-object v6, v0, Lcom/ea/nimble/HttpResponse;->data:Lcom/ea/nimble/ByteBufferIOStream;
|
|
|
|
if-nez v6, :cond_c
|
|
|
|
.line 411
|
|
new-instance v6, Lcom/ea/nimble/ByteBufferIOStream;
|
|
|
|
long-to-int v4, v4
|
|
|
|
invoke-direct {v6, v4}, Lcom/ea/nimble/ByteBufferIOStream;-><init>(I)V
|
|
|
|
iput-object v6, v0, Lcom/ea/nimble/HttpResponse;->data:Lcom/ea/nimble/ByteBufferIOStream;
|
|
|
|
goto :goto_8
|
|
|
|
.line 415
|
|
:cond_c
|
|
invoke-virtual {v6}, Lcom/ea/nimble/ByteBufferIOStream;->clear()V
|
|
|
|
:goto_8
|
|
if-eqz v2, :cond_d
|
|
|
|
.line 420
|
|
invoke-direct {p0, v2}, Lcom/ea/nimble/NetworkConnection;->downloadToBuffer(Ljava/io/InputStream;)V
|
|
|
|
move-object v2, p1
|
|
|
|
goto :goto_9
|
|
|
|
.line 425
|
|
:cond_d
|
|
new-instance p1, Lcom/ea/nimble/Error;
|
|
|
|
sget-object v0, Lcom/ea/nimble/Error$Code;->SYSTEM_UNEXPECTED:Lcom/ea/nimble/Error$Code;
|
|
|
|
new-instance v3, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v3, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
const-string v1, " failed because no stream available to read expected response data."
|
|
|
|
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-direct {p1, v0, v1}, Lcom/ea/nimble/Error;-><init>(Lcom/ea/nimble/Error$Code;Ljava/lang/String;)V
|
|
|
|
throw p1
|
|
:try_end_3
|
|
.catchall {:try_start_3 .. :try_end_3} :catchall_0
|
|
|
|
:cond_e
|
|
:goto_9
|
|
if-eqz v7, :cond_11
|
|
|
|
if-nez v3, :cond_10
|
|
|
|
:goto_a
|
|
if-eqz v2, :cond_f
|
|
|
|
.line 455
|
|
invoke-virtual {v2}, Ljava/io/InputStream;->close()V
|
|
|
|
.line 457
|
|
:cond_f
|
|
invoke-direct {p0}, Lcom/ea/nimble/NetworkConnection;->logCommunication()V
|
|
|
|
return-void
|
|
|
|
.line 434
|
|
:cond_10
|
|
:try_start_4
|
|
new-instance p1, Lcom/ea/nimble/Error;
|
|
|
|
sget-object v0, Lcom/ea/nimble/Error$Code;->SYSTEM_UNEXPECTED:Lcom/ea/nimble/Error$Code;
|
|
|
|
new-instance v3, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v3, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
const-string v1, " failed because response is from error stream even the status code("
|
|
|
|
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
iget-object v1, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
iget v1, v1, Lcom/ea/nimble/HttpResponse;->statusCode:I
|
|
|
|
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
|
|
|
|
const-string v1, "). In some cases, you may ignore this and treat it as success."
|
|
|
|
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-direct {p1, v0, v1}, Lcom/ea/nimble/Error;-><init>(Lcom/ea/nimble/Error$Code;Ljava/lang/String;)V
|
|
|
|
throw p1
|
|
|
|
:cond_11
|
|
if-eqz v3, :cond_12
|
|
|
|
.line 442
|
|
new-instance p1, Lcom/ea/nimble/HttpError;
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
iget v0, v0, Lcom/ea/nimble/HttpResponse;->statusCode:I
|
|
|
|
new-instance v3, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v3, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
const-string v1, " failed for HTTP error."
|
|
|
|
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-direct {p1, v0, v1}, Lcom/ea/nimble/HttpError;-><init>(ILjava/lang/String;)V
|
|
|
|
throw p1
|
|
|
|
.line 446
|
|
:cond_12
|
|
new-instance p1, Lcom/ea/nimble/HttpError;
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
iget v0, v0, Lcom/ea/nimble/HttpResponse;->statusCode:I
|
|
|
|
new-instance v3, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v3, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
const-string v1, " failed for HTTP error even the response data is from normal response stream."
|
|
|
|
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-direct {p1, v0, v1}, Lcom/ea/nimble/HttpError;-><init>(ILjava/lang/String;)V
|
|
|
|
throw p1
|
|
:try_end_4
|
|
.catchall {:try_start_4 .. :try_end_4} :catchall_0
|
|
|
|
:goto_b
|
|
if-eqz v2, :cond_13
|
|
|
|
.line 455
|
|
invoke-virtual {v2}, Ljava/io/InputStream;->close()V
|
|
|
|
.line 457
|
|
:cond_13
|
|
invoke-direct {p0}, Lcom/ea/nimble/NetworkConnection;->logCommunication()V
|
|
|
|
.line 458
|
|
throw p1
|
|
|
|
:catch_1
|
|
move-exception p1
|
|
|
|
.line 347
|
|
new-instance v0, Lcom/ea/nimble/Error;
|
|
|
|
sget-object v1, Lcom/ea/nimble/Error$Code;->NETWORK_CONNECTION_ERROR:Lcom/ea/nimble/Error$Code;
|
|
|
|
const-string v2, "Fail to get either input stream or error stream from HTTP connection."
|
|
|
|
invoke-direct {v0, v1, v2, p1}, Lcom/ea/nimble/Error;-><init>(Lcom/ea/nimble/Error$Code;Ljava/lang/String;Ljava/lang/Throwable;)V
|
|
|
|
throw v0
|
|
.end method
|
|
|
|
.method private httpSend(Ljava/net/HttpURLConnection;)V
|
|
.locals 3
|
|
.annotation system Ldalvik/annotation/Throws;
|
|
value = {
|
|
Ljava/io/IOException;
|
|
}
|
|
.end annotation
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 272
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGFUNCS(Ljava/lang/String;)V
|
|
|
|
.line 274
|
|
new-instance v0, Ljava/util/Date;
|
|
|
|
invoke-direct {v0}, Ljava/util/Date;-><init>()V
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_connectionStartTimestamp:Ljava/util/Date;
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 277
|
|
iget-object v0, v0, Lcom/ea/nimble/HttpRequest;->headers:Ljava/util/HashMap;
|
|
|
|
if-eqz v0, :cond_0
|
|
|
|
.line 279
|
|
invoke-virtual {v0}, Ljava/util/HashMap;->keySet()Ljava/util/Set;
|
|
|
|
move-result-object v0
|
|
|
|
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
|
|
|
|
move-result-object v0
|
|
|
|
:goto_0
|
|
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
|
|
|
|
move-result v1
|
|
|
|
if-eqz v1, :cond_0
|
|
|
|
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
|
|
|
|
move-result-object v1
|
|
|
|
check-cast v1, Ljava/lang/String;
|
|
|
|
iget-object v2, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 281
|
|
iget-object v2, v2, Lcom/ea/nimble/HttpRequest;->headers:Ljava/util/HashMap;
|
|
|
|
invoke-virtual {v2, v1}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
move-result-object v2
|
|
|
|
check-cast v2, Ljava/lang/String;
|
|
|
|
invoke-virtual {p1, v1, v2}, Ljava/net/URLConnection;->setRequestProperty(Ljava/lang/String;Ljava/lang/String;)V
|
|
|
|
goto :goto_0
|
|
|
|
.line 285
|
|
:cond_0
|
|
invoke-direct {p0}, Lcom/ea/nimble/NetworkConnection;->logRequest()V
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 287
|
|
iget-object v0, v0, Lcom/ea/nimble/HttpRequest;->data:Ljava/io/ByteArrayOutputStream;
|
|
|
|
invoke-virtual {v0}, Ljava/io/ByteArrayOutputStream;->toByteArray()[B
|
|
|
|
move-result-object v0
|
|
|
|
if-eqz v0, :cond_4
|
|
|
|
.line 288
|
|
array-length v1, v0
|
|
|
|
if-gtz v1, :cond_1
|
|
|
|
goto :goto_4
|
|
|
|
:cond_1
|
|
const/4 v1, 0x1
|
|
|
|
.line 294
|
|
invoke-virtual {p1, v1}, Ljava/net/URLConnection;->setDoOutput(Z)V
|
|
|
|
.line 295
|
|
array-length v1, v0
|
|
|
|
invoke-virtual {p1, v1}, Ljava/net/HttpURLConnection;->setFixedLengthStreamingMode(I)V
|
|
|
|
const/4 v1, 0x0
|
|
|
|
.line 301
|
|
:try_start_0
|
|
invoke-virtual {p1}, Ljava/net/URLConnection;->getOutputStream()Ljava/io/OutputStream;
|
|
|
|
move-result-object v1
|
|
|
|
.line 305
|
|
invoke-virtual {v1, v0}, Ljava/io/OutputStream;->write([B)V
|
|
:try_end_0
|
|
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
|
|
.catchall {:try_start_0 .. :try_end_0} :catchall_0
|
|
|
|
.line 318
|
|
:goto_1
|
|
invoke-virtual {v1}, Ljava/io/OutputStream;->close()V
|
|
|
|
goto :goto_2
|
|
|
|
:catchall_0
|
|
move-exception p1
|
|
|
|
goto :goto_3
|
|
|
|
:catch_0
|
|
move-exception p1
|
|
|
|
.line 309
|
|
:try_start_1
|
|
new-instance v0, Ljava/io/StringWriter;
|
|
|
|
invoke-direct {v0}, Ljava/io/StringWriter;-><init>()V
|
|
|
|
.line 310
|
|
new-instance v2, Ljava/io/PrintWriter;
|
|
|
|
invoke-direct {v2, v0}, Ljava/io/PrintWriter;-><init>(Ljava/io/Writer;)V
|
|
|
|
invoke-virtual {p1, v2}, Ljava/lang/Throwable;->printStackTrace(Ljava/io/PrintWriter;)V
|
|
|
|
.line 311
|
|
invoke-virtual {v0}, Ljava/io/StringWriter;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
.line 312
|
|
new-instance v0, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v2, "Exception in network connection:"
|
|
|
|
invoke-virtual {v0, v2}, 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 p1
|
|
|
|
const/4 v0, 0x0
|
|
|
|
new-array v0, v0, [Ljava/lang/Object;
|
|
|
|
invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
:try_end_1
|
|
.catchall {:try_start_1 .. :try_end_1} :catchall_0
|
|
|
|
if-eqz v1, :cond_2
|
|
|
|
goto :goto_1
|
|
|
|
:cond_2
|
|
:goto_2
|
|
return-void
|
|
|
|
:goto_3
|
|
if-eqz v1, :cond_3
|
|
|
|
.line 318
|
|
invoke-virtual {v1}, Ljava/io/OutputStream;->close()V
|
|
|
|
.line 320
|
|
:cond_3
|
|
throw p1
|
|
|
|
:cond_4
|
|
:goto_4
|
|
return-void
|
|
.end method
|
|
|
|
.method private logCommunication()V
|
|
.locals 7
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 774
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGFUNCS(Ljava/lang/String;)V
|
|
|
|
.line 775
|
|
invoke-static {}, Lcom/ea/nimble/Log;->getComponent()Lcom/ea/nimble/ILog;
|
|
|
|
move-result-object v0
|
|
|
|
invoke-interface {v0}, Lcom/ea/nimble/ILog;->getThresholdLevel()I
|
|
|
|
move-result v0
|
|
|
|
const/16 v1, 0x64
|
|
|
|
if-le v0, v1, :cond_0
|
|
|
|
return-void
|
|
|
|
:cond_0
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_requestDataForLog:Ljava/lang/String;
|
|
|
|
if-nez v0, :cond_1
|
|
|
|
.line 786
|
|
invoke-direct {p0}, Lcom/ea/nimble/NetworkConnection;->prepareRequestLog()Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_requestDataForLog:Ljava/lang/String;
|
|
|
|
:cond_1
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_requestDataForLog:Ljava/lang/String;
|
|
|
|
.line 788
|
|
invoke-virtual {v0}, Ljava/lang/String;->length()I
|
|
|
|
move-result v0
|
|
|
|
const/16 v1, 0x1000
|
|
|
|
add-int/2addr v1, v0
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 790
|
|
iget-object v0, v0, Lcom/ea/nimble/HttpRequest;->targetFilePath:Ljava/lang/String;
|
|
|
|
const/4 v2, 0x0
|
|
|
|
const/4 v3, 0x1
|
|
|
|
if-eqz v0, :cond_2
|
|
|
|
move v0, v3
|
|
|
|
goto :goto_0
|
|
|
|
:cond_2
|
|
move v0, v2
|
|
|
|
:goto_0
|
|
iget-object v4, p0, Lcom/ea/nimble/NetworkConnection;->m_responseDataForLog:Ljava/lang/StringBuilder;
|
|
|
|
if-eqz v4, :cond_3
|
|
|
|
.line 792
|
|
invoke-virtual {v4}, Ljava/lang/StringBuilder;->length()I
|
|
|
|
move-result v4
|
|
|
|
if-lez v4, :cond_3
|
|
|
|
:try_start_0
|
|
iget-object v4, p0, Lcom/ea/nimble/NetworkConnection;->m_responseDataForLog:Ljava/lang/StringBuilder;
|
|
|
|
.line 796
|
|
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v4
|
|
:try_end_0
|
|
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
goto :goto_1
|
|
|
|
:catch_0
|
|
const-string v4, "<-- UNREADABLE -->"
|
|
|
|
goto :goto_1
|
|
|
|
:cond_3
|
|
if-eqz v0, :cond_4
|
|
|
|
const-string v4, "<-- FILE -->"
|
|
|
|
goto :goto_1
|
|
|
|
:cond_4
|
|
const-string v4, "<-- EMPTY -->"
|
|
|
|
.line 814
|
|
:goto_1
|
|
invoke-virtual {v4}, Ljava/lang/String;->length()I
|
|
|
|
move-result v5
|
|
|
|
add-int/2addr v1, v5
|
|
|
|
.line 816
|
|
new-instance v5, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v5, v1}, Ljava/lang/StringBuilder;-><init>(I)V
|
|
|
|
iget-object v1, p0, Lcom/ea/nimble/NetworkConnection;->m_loggingId:Ljava/lang/String;
|
|
|
|
filled-new-array {v1}, [Ljava/lang/Object;
|
|
|
|
move-result-object v1
|
|
|
|
const-string v6, "%n>>>> CONNECTION ID %s FINISH >>>> REQUEST >>>>%n"
|
|
|
|
.line 817
|
|
invoke-static {v6, v1}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-virtual {v5, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
iget-object v1, p0, Lcom/ea/nimble/NetworkConnection;->m_requestDataForLog:Ljava/lang/String;
|
|
|
|
.line 818
|
|
invoke-virtual {v5, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
const-string v1, "<<<< REQUEST <<<<<<<< -- >>>>>>>> RESPONSE >>>>\n"
|
|
|
|
.line 819
|
|
invoke-virtual {v5, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
const-string v1, "RESP URL: "
|
|
|
|
.line 820
|
|
invoke-virtual {v5, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
iget-object v1, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
iget-object v1, v1, Lcom/ea/nimble/HttpResponse;->url:Ljava/net/URL;
|
|
|
|
invoke-virtual {v1}, Ljava/net/URL;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-virtual {v5, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
const/16 v1, 0xa
|
|
|
|
invoke-virtual {v5, v1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
|
|
|
|
const-string v6, "RESP STATUS: "
|
|
|
|
.line 821
|
|
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
iget-object v6, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
iget v6, v6, Lcom/ea/nimble/HttpResponse;->statusCode:I
|
|
|
|
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v5, v1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
|
|
|
|
iget-object v1, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 822
|
|
invoke-virtual {v1}, Lcom/ea/nimble/HttpResponse;->getError()Ljava/lang/Exception;
|
|
|
|
move-result-object v1
|
|
|
|
const-string v6, "\n"
|
|
|
|
if-eqz v1, :cond_6
|
|
|
|
const-string v1, "RESP ERROR: "
|
|
|
|
.line 824
|
|
invoke-virtual {v5, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
iget-object v1, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 825
|
|
invoke-virtual {v1}, Lcom/ea/nimble/HttpResponse;->getError()Ljava/lang/Exception;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-virtual {v1}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
if-eqz v1, :cond_5
|
|
|
|
iget-object v1, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 827
|
|
invoke-virtual {v1}, Lcom/ea/nimble/HttpResponse;->getError()Ljava/lang/Exception;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-virtual {v1}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-virtual {v5, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
goto :goto_2
|
|
|
|
:cond_5
|
|
const-string v1, "<-- UNKNOWN -->\n"
|
|
|
|
.line 831
|
|
invoke-virtual {v5, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
:cond_6
|
|
:goto_2
|
|
if-eqz v0, :cond_7
|
|
|
|
const-string v0, "RESP FILE: "
|
|
|
|
.line 836
|
|
invoke-virtual {v5, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
iget-object v0, v0, Lcom/ea/nimble/HttpRequest;->targetFilePath:Ljava/lang/String;
|
|
|
|
invoke-virtual {v5, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
:cond_7
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 839
|
|
iget-object v0, v0, Lcom/ea/nimble/HttpResponse;->headers:Ljava/util/HashMap;
|
|
|
|
invoke-direct {p0, v5, v3, v0, v4}, Lcom/ea/nimble/NetworkConnection;->generateHttpHeaderAndBodyLogString(Ljava/lang/StringBuilder;ZLjava/util/Map;Ljava/lang/String;)V
|
|
|
|
const-string v0, "<<<< RESPONSE <<<< CONNECTION FINISH <<<<<<<<<<"
|
|
|
|
.line 841
|
|
invoke-virtual {v5, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
.line 842
|
|
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
|
|
new-array v1, v2, [Ljava/lang/Object;
|
|
|
|
invoke-static {p0, v0, v1}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method private logRequest()V
|
|
.locals 2
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 759
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGFUNCS(Ljava/lang/String;)V
|
|
|
|
.line 760
|
|
invoke-static {}, Lcom/ea/nimble/Log;->getComponent()Lcom/ea/nimble/ILog;
|
|
|
|
move-result-object v0
|
|
|
|
invoke-interface {v0}, Lcom/ea/nimble/ILog;->getThresholdLevel()I
|
|
|
|
move-result v0
|
|
|
|
const/16 v1, 0x64
|
|
|
|
if-le v0, v1, :cond_0
|
|
|
|
return-void
|
|
|
|
.line 767
|
|
:cond_0
|
|
invoke-direct {p0}, Lcom/ea/nimble/NetworkConnection;->prepareRequestLog()Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_requestDataForLog:Ljava/lang/String;
|
|
|
|
iget-object v1, p0, Lcom/ea/nimble/NetworkConnection;->m_loggingId:Ljava/lang/String;
|
|
|
|
filled-new-array {v1, v0}, [Ljava/lang/Object;
|
|
|
|
move-result-object v0
|
|
|
|
const-string v1, "\n>>>> CONNECTION ID %s BEGIN >>>>>>>>>>>>>>>>>>\n%s<<<< CONNECTION BEGIN <<<<<<<<<<<<<<<<<<<<<<<<<\n"
|
|
|
|
.line 769
|
|
invoke-static {p0, v1, v0}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method private multiplyStringNTimes(Ljava/lang/String;I)Ljava/lang/String;
|
|
.locals 2
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 715
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGFUNCS(Ljava/lang/String;)V
|
|
|
|
.line 716
|
|
new-instance v0, Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1}, Ljava/lang/String;->length()I
|
|
|
|
move-result v1
|
|
|
|
mul-int/2addr v1, p2
|
|
|
|
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(I)V
|
|
|
|
const/4 v1, 0x0
|
|
|
|
:goto_0
|
|
if-ge v1, p2, :cond_0
|
|
|
|
.line 719
|
|
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
add-int/lit8 v1, v1, 0x1
|
|
|
|
goto :goto_0
|
|
|
|
.line 721
|
|
:cond_0
|
|
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
return-object p1
|
|
.end method
|
|
|
|
.method private prepareRequestLog()Ljava/lang/String;
|
|
.locals 4
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 649
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGFUNCS(Ljava/lang/String;)V
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 652
|
|
iget-object v0, v0, Lcom/ea/nimble/HttpRequest;->data:Ljava/io/ByteArrayOutputStream;
|
|
|
|
const/16 v1, 0x800
|
|
|
|
if-eqz v0, :cond_0
|
|
|
|
invoke-virtual {v0}, Ljava/io/ByteArrayOutputStream;->size()I
|
|
|
|
move-result v0
|
|
|
|
if-lez v0, :cond_0
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 654
|
|
iget-object v0, v0, Lcom/ea/nimble/HttpRequest;->data:Ljava/io/ByteArrayOutputStream;
|
|
|
|
invoke-virtual {v0}, Ljava/io/ByteArrayOutputStream;->size()I
|
|
|
|
move-result v0
|
|
|
|
add-int/2addr v1, v0
|
|
|
|
:try_start_0
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 657
|
|
iget-object v0, v0, Lcom/ea/nimble/HttpRequest;->data:Ljava/io/ByteArrayOutputStream;
|
|
|
|
const-string v2, "UTF-8"
|
|
|
|
invoke-virtual {v0, v2}, Ljava/io/ByteArrayOutputStream;->toString(Ljava/lang/String;)Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
:try_end_0
|
|
.catch Ljava/io/UnsupportedEncodingException; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
goto :goto_1
|
|
|
|
:catch_0
|
|
const-string v0, "<-- UNREADABLE -->"
|
|
|
|
goto :goto_1
|
|
|
|
:cond_0
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 664
|
|
invoke-virtual {v0}, Lcom/ea/nimble/HttpRequest;->getMethod()Lcom/ea/nimble/IHttpRequest$Method;
|
|
|
|
move-result-object v0
|
|
|
|
sget-object v2, Lcom/ea/nimble/IHttpRequest$Method;->POST:Lcom/ea/nimble/IHttpRequest$Method;
|
|
|
|
if-eq v0, v2, :cond_2
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
invoke-virtual {v0}, Lcom/ea/nimble/HttpRequest;->getMethod()Lcom/ea/nimble/IHttpRequest$Method;
|
|
|
|
move-result-object v0
|
|
|
|
sget-object v2, Lcom/ea/nimble/IHttpRequest$Method;->PUT:Lcom/ea/nimble/IHttpRequest$Method;
|
|
|
|
if-ne v0, v2, :cond_1
|
|
|
|
goto :goto_0
|
|
|
|
:cond_1
|
|
const/4 v0, 0x0
|
|
|
|
goto :goto_1
|
|
|
|
:cond_2
|
|
:goto_0
|
|
const-string v0, "<-- EMPTY -->"
|
|
|
|
.line 673
|
|
:goto_1
|
|
new-instance v2, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v2, v1}, Ljava/lang/StringBuilder;-><init>(I)V
|
|
|
|
const-string v1, "REQUEST: "
|
|
|
|
.line 674
|
|
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
iget-object v1, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
iget-object v1, v1, Lcom/ea/nimble/HttpRequest;->method:Lcom/ea/nimble/IHttpRequest$Method;
|
|
|
|
invoke-virtual {v1}, Lcom/ea/nimble/IHttpRequest$Method;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
const/16 v1, 0x20
|
|
|
|
.line 675
|
|
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
|
|
|
|
iget-object v1, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
iget-object v1, v1, Lcom/ea/nimble/HttpRequest;->url:Ljava/net/URL;
|
|
|
|
invoke-virtual {v1}, Ljava/net/URL;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
const/16 v1, 0xa
|
|
|
|
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
|
|
|
|
iget-object v1, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 676
|
|
iget-object v1, v1, Lcom/ea/nimble/HttpRequest;->headers:Ljava/util/HashMap;
|
|
|
|
const/4 v3, 0x0
|
|
|
|
invoke-direct {p0, v2, v3, v1, v0}, Lcom/ea/nimble/NetworkConnection;->generateHttpHeaderAndBodyLogString(Ljava/lang/StringBuilder;ZLjava/util/Map;Ljava/lang/String;)V
|
|
|
|
.line 678
|
|
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
.method private prepareResponseLog()V
|
|
.locals 4
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 683
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGFUNCS(Ljava/lang/String;)V
|
|
|
|
.line 684
|
|
invoke-static {}, Lcom/ea/nimble/Log;->getComponent()Lcom/ea/nimble/ILog;
|
|
|
|
move-result-object v0
|
|
|
|
invoke-interface {v0}, Lcom/ea/nimble/ILog;->getThresholdLevel()I
|
|
|
|
move-result v0
|
|
|
|
const/16 v1, 0x64
|
|
|
|
if-le v0, v1, :cond_0
|
|
|
|
return-void
|
|
|
|
:cond_0
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 691
|
|
iget-wide v0, v0, Lcom/ea/nimble/HttpResponse;->expectedContentLength:J
|
|
|
|
const-wide/16 v2, 0x0
|
|
|
|
cmp-long v2, v0, v2
|
|
|
|
if-lez v2, :cond_1
|
|
|
|
long-to-int v0, v0
|
|
|
|
goto :goto_0
|
|
|
|
:cond_1
|
|
const/16 v0, 0x1000
|
|
|
|
.line 692
|
|
:goto_0
|
|
new-instance v1, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v1, v0}, Ljava/lang/StringBuilder;-><init>(I)V
|
|
|
|
iput-object v1, p0, Lcom/ea/nimble/NetworkConnection;->m_responseDataForLog:Ljava/lang/StringBuilder;
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method private prepareResponseLog([BII)V
|
|
.locals 2
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 697
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGFUNCS(Ljava/lang/String;)V
|
|
|
|
.line 698
|
|
invoke-static {}, Lcom/ea/nimble/Log;->getComponent()Lcom/ea/nimble/ILog;
|
|
|
|
move-result-object v0
|
|
|
|
invoke-interface {v0}, Lcom/ea/nimble/ILog;->getThresholdLevel()I
|
|
|
|
move-result v0
|
|
|
|
const/16 v1, 0x64
|
|
|
|
if-gt v0, v1, :cond_1
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_responseDataForLog:Ljava/lang/StringBuilder;
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
goto :goto_0
|
|
|
|
.line 709
|
|
:cond_0
|
|
new-instance v0, Ljava/lang/String;
|
|
|
|
sget-object v1, Ljava/nio/charset/StandardCharsets;->UTF_8:Ljava/nio/charset/Charset;
|
|
|
|
invoke-direct {v0, p1, p2, p3, v1}, Ljava/lang/String;-><init>([BIILjava/nio/charset/Charset;)V
|
|
|
|
iget-object p1, p0, Lcom/ea/nimble/NetworkConnection;->m_responseDataForLog:Ljava/lang/StringBuilder;
|
|
|
|
.line 710
|
|
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
:cond_1
|
|
:goto_0
|
|
return-void
|
|
.end method
|
|
|
|
|
|
# virtual methods
|
|
.method public cancel()V
|
|
.locals 4
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 148
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNCS(Ljava/lang/String;)V
|
|
|
|
.line 150
|
|
monitor-enter p0
|
|
|
|
:try_start_0
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_thread:Ljava/lang/Thread;
|
|
|
|
if-eqz v0, :cond_0
|
|
|
|
.line 154
|
|
invoke-virtual {v0}, Ljava/lang/Thread;->interrupt()V
|
|
|
|
goto :goto_0
|
|
|
|
:catchall_0
|
|
move-exception v0
|
|
|
|
goto :goto_1
|
|
|
|
.line 158
|
|
:cond_0
|
|
new-instance v0, Lcom/ea/nimble/Error;
|
|
|
|
sget-object v1, Lcom/ea/nimble/Error$Code;->NETWORK_OPERATION_CANCELLED:Lcom/ea/nimble/Error$Code;
|
|
|
|
new-instance v2, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v3, "Network connection "
|
|
|
|
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v2, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
const-string v3, " is cancelled"
|
|
|
|
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-direct {v0, v1, v2}, Lcom/ea/nimble/Error;-><init>(Lcom/ea/nimble/Error$Code;Ljava/lang/String;)V
|
|
|
|
invoke-virtual {p0, v0}, Lcom/ea/nimble/NetworkConnection;->finishWithError(Ljava/lang/Exception;)V
|
|
|
|
.line 160
|
|
:goto_0
|
|
monitor-exit p0
|
|
|
|
return-void
|
|
|
|
:goto_1
|
|
monitor-exit p0
|
|
:try_end_0
|
|
.catchall {:try_start_0 .. :try_end_0} :catchall_0
|
|
|
|
throw v0
|
|
.end method
|
|
|
|
.method public cancelForAppSuspend()V
|
|
.locals 0
|
|
|
|
.line 165
|
|
invoke-virtual {p0}, Lcom/ea/nimble/NetworkConnection;->cancel()V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public finishWithError(Ljava/lang/Exception;)V
|
|
.locals 3
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 635
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGFUNCS(Ljava/lang/String;)V
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 636
|
|
iget-boolean v0, v0, Lcom/ea/nimble/HttpResponse;->isCompleted:Z
|
|
|
|
if-eqz v0, :cond_0
|
|
|
|
.line 639
|
|
invoke-virtual {p0}, Ljava/lang/Object;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
|
|
invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
filled-new-array {v0, p1}, [Ljava/lang/Object;
|
|
|
|
move-result-object p1
|
|
|
|
const-string v0, "Finished connection %s skipped an error %s"
|
|
|
|
invoke-static {p0, v0, p1}, Lcom/ea/nimble/Log$Helper;->LOGI(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return-void
|
|
|
|
:cond_0
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_loggingId:Ljava/lang/String;
|
|
|
|
.line 642
|
|
invoke-virtual {p0}, Ljava/lang/Object;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
filled-new-array {v0, v1, v2}, [Ljava/lang/Object;
|
|
|
|
move-result-object v0
|
|
|
|
const-string v1, "Running connection number %s with name %s failed for error %s"
|
|
|
|
invoke-static {p0, v1, v0}, Lcom/ea/nimble/Log$Helper;->LOGW(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 643
|
|
iput-object p1, v0, Lcom/ea/nimble/HttpResponse;->error:Ljava/lang/Exception;
|
|
|
|
.line 644
|
|
invoke-direct {p0}, Lcom/ea/nimble/NetworkConnection;->finish()V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public getCompletionCallback()Lcom/ea/nimble/NetworkConnectionCallback;
|
|
.locals 1
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 114
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNCS(Ljava/lang/String;)V
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_completionCallback:Lcom/ea/nimble/NetworkConnectionCallback;
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public getHeaderCallback()Lcom/ea/nimble/NetworkConnectionCallback;
|
|
.locals 1
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 86
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNCS(Ljava/lang/String;)V
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_headerCallback:Lcom/ea/nimble/NetworkConnectionCallback;
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public getLogSourceTitle()Ljava/lang/String;
|
|
.locals 1
|
|
|
|
const-string v0, "Network"
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public getProgressCallback()Lcom/ea/nimble/NetworkConnectionCallback;
|
|
.locals 1
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 100
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNCS(Ljava/lang/String;)V
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_progressCallback:Lcom/ea/nimble/NetworkConnectionCallback;
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public getRequest()Lcom/ea/nimble/HttpRequest;
|
|
.locals 1
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 72
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNCS(Ljava/lang/String;)V
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public bridge synthetic getRequest()Lcom/ea/nimble/IHttpRequest;
|
|
.locals 1
|
|
|
|
.line 33
|
|
invoke-virtual {p0}, Lcom/ea/nimble/NetworkConnection;->getRequest()Lcom/ea/nimble/HttpRequest;
|
|
|
|
move-result-object v0
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public getResponse()Lcom/ea/nimble/HttpResponse;
|
|
.locals 1
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 79
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNCS(Ljava/lang/String;)V
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public bridge synthetic getResponse()Lcom/ea/nimble/IHttpResponse;
|
|
.locals 1
|
|
|
|
.line 33
|
|
invoke-virtual {p0}, Lcom/ea/nimble/NetworkConnection;->getResponse()Lcom/ea/nimble/HttpResponse;
|
|
|
|
move-result-object v0
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public logOperationalTelemetryResponse()V
|
|
.locals 17
|
|
|
|
move-object/from16 v0, p0
|
|
|
|
const-string v1, "NetworkConnection"
|
|
|
|
.line 900
|
|
invoke-static {v1}, Lcom/ea/nimble/Log$Helper;->LOGFUNCS(Ljava/lang/String;)V
|
|
|
|
iget-object v1, v0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
const/4 v2, 0x0
|
|
|
|
if-eqz v1, :cond_0
|
|
|
|
.line 901
|
|
iget-object v1, v1, Lcom/ea/nimble/HttpRequest;->url:Ljava/net/URL;
|
|
|
|
if-nez v1, :cond_1
|
|
|
|
:cond_0
|
|
move v3, v2
|
|
|
|
goto/16 :goto_6
|
|
|
|
:cond_1
|
|
iget-object v1, v0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
if-nez v1, :cond_2
|
|
|
|
const-string v1, "Empty response object for OT logging."
|
|
|
|
new-array v2, v2, [Ljava/lang/Object;
|
|
|
|
.line 911
|
|
invoke-static {v0, v1, v2}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return-void
|
|
|
|
.line 918
|
|
:cond_2
|
|
invoke-static {}, Lcom/ea/nimble/BaseCore;->getInstance()Lcom/ea/nimble/BaseCore;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-virtual {v1}, Lcom/ea/nimble/BaseCore;->isActive()Z
|
|
|
|
move-result v1
|
|
|
|
if-nez v1, :cond_3
|
|
|
|
const-string v1, "BaseCore not active for operational telemetry logging."
|
|
|
|
new-array v2, v2, [Ljava/lang/Object;
|
|
|
|
.line 920
|
|
invoke-static {v0, v1, v2}, Lcom/ea/nimble/Log$Helper;->LOGV(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return-void
|
|
|
|
:cond_3
|
|
iget-object v1, v0, Lcom/ea/nimble/NetworkConnection;->m_otDispatch:Lcom/ea/nimble/IOperationalTelemetryDispatch;
|
|
|
|
if-nez v1, :cond_4
|
|
|
|
.line 927
|
|
invoke-static {}, Lcom/ea/nimble/OperationalTelemetryDispatch;->getComponent()Lcom/ea/nimble/IOperationalTelemetryDispatch;
|
|
|
|
move-result-object v1
|
|
|
|
iput-object v1, v0, Lcom/ea/nimble/NetworkConnection;->m_otDispatch:Lcom/ea/nimble/IOperationalTelemetryDispatch;
|
|
|
|
if-nez v1, :cond_4
|
|
|
|
const-string v1, "OperationalTelemetry Component not active for operational telemetry logging."
|
|
|
|
new-array v2, v2, [Ljava/lang/Object;
|
|
|
|
.line 930
|
|
invoke-static {v0, v1, v2}, Lcom/ea/nimble/Log$Helper;->LOGV(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return-void
|
|
|
|
.line 936
|
|
:cond_4
|
|
new-instance v1, Lorg/json/JSONObject;
|
|
|
|
invoke-direct {v1}, Lorg/json/JSONObject;-><init>()V
|
|
|
|
iget-object v3, v0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 938
|
|
iget-object v3, v3, Lcom/ea/nimble/HttpRequest;->url:Ljava/net/URL;
|
|
|
|
invoke-virtual {v3}, Ljava/net/URL;->getProtocol()Ljava/lang/String;
|
|
|
|
move-result-object v3
|
|
|
|
iget-object v4, v0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 939
|
|
iget-object v4, v4, Lcom/ea/nimble/HttpRequest;->url:Ljava/net/URL;
|
|
|
|
invoke-virtual {v4}, Ljava/net/URL;->getPath()Ljava/lang/String;
|
|
|
|
move-result-object v4
|
|
|
|
iget-object v5, v0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 940
|
|
iget-object v5, v5, Lcom/ea/nimble/HttpRequest;->url:Ljava/net/URL;
|
|
|
|
invoke-virtual {v5}, Ljava/net/URL;->getQuery()Ljava/lang/String;
|
|
|
|
move-result-object v5
|
|
|
|
iget-object v6, v0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 941
|
|
iget-object v6, v6, Lcom/ea/nimble/HttpRequest;->url:Ljava/net/URL;
|
|
|
|
invoke-virtual {v6}, Ljava/net/URL;->getHost()Ljava/lang/String;
|
|
|
|
move-result-object v6
|
|
|
|
iget-object v7, v0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 942
|
|
iget v7, v7, Lcom/ea/nimble/HttpResponse;->statusCode:I
|
|
|
|
invoke-static {v7}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
|
|
|
|
move-result-object v7
|
|
|
|
iget-object v8, v0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 943
|
|
iget-object v8, v8, Lcom/ea/nimble/HttpRequest;->url:Ljava/net/URL;
|
|
|
|
invoke-virtual {v8}, Ljava/net/URL;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v8
|
|
|
|
iget-object v9, v0, Lcom/ea/nimble/NetworkConnection;->m_connectionStartTimestamp:Ljava/util/Date;
|
|
|
|
if-eqz v9, :cond_5
|
|
|
|
.line 949
|
|
new-instance v9, Ljava/util/Date;
|
|
|
|
invoke-direct {v9}, Ljava/util/Date;-><init>()V
|
|
|
|
.line 950
|
|
invoke-virtual {v9}, Ljava/util/Date;->getTime()J
|
|
|
|
move-result-wide v9
|
|
|
|
iget-object v11, v0, Lcom/ea/nimble/NetworkConnection;->m_connectionStartTimestamp:Ljava/util/Date;
|
|
|
|
invoke-virtual {v11}, Ljava/util/Date;->getTime()J
|
|
|
|
move-result-wide v11
|
|
|
|
sub-long/2addr v9, v11
|
|
|
|
.line 951
|
|
invoke-static {v9, v10}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
|
|
|
|
move-result-object v9
|
|
|
|
goto :goto_0
|
|
|
|
:cond_5
|
|
const-string v9, "0"
|
|
|
|
:goto_0
|
|
iget-object v10, v0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 956
|
|
invoke-virtual {v10}, Lcom/ea/nimble/HttpResponse;->getError()Ljava/lang/Exception;
|
|
|
|
move-result-object v10
|
|
|
|
const-string v11, " to eventDict."
|
|
|
|
const-string v12, "Failed to add "
|
|
|
|
const-string v13, ""
|
|
|
|
if-eqz v10, :cond_8
|
|
|
|
.line 959
|
|
instance-of v14, v10, Lcom/ea/nimble/Error;
|
|
|
|
const-string v15, "NIMBLE_ERROR_DOMAIN"
|
|
|
|
if-eqz v14, :cond_7
|
|
|
|
.line 961
|
|
check-cast v10, Lcom/ea/nimble/Error;
|
|
|
|
.line 962
|
|
invoke-virtual {v10}, Lcom/ea/nimble/Error;->getCode()I
|
|
|
|
move-result v14
|
|
|
|
.line 963
|
|
invoke-virtual {v10}, Lcom/ea/nimble/Error;->getDomain()Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
.line 969
|
|
:try_start_0
|
|
invoke-virtual {v1, v15, v2}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
|
|
|
|
const-string v15, "NIMBLE_ERROR_CODE"
|
|
|
|
.line 971
|
|
invoke-static {v14}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
invoke-virtual {v1, v15, v2}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
|
|
:try_end_0
|
|
.catch Lorg/json/JSONException; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
move-object/from16 v16, v13
|
|
|
|
goto :goto_1
|
|
|
|
.line 975
|
|
:catch_0
|
|
new-instance v2, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
invoke-virtual {v2, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v2, v15}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v2, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
move-object/from16 v16, v13
|
|
|
|
const/4 v15, 0x0
|
|
|
|
new-array v13, v15, [Ljava/lang/Object;
|
|
|
|
invoke-static {v0, v2, v13}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
.line 979
|
|
:goto_1
|
|
invoke-virtual {v10}, Lcom/ea/nimble/Error;->getDomain()Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
const-string v10, "NimbleError"
|
|
|
|
invoke-virtual {v2, v10}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
|
|
|
|
move-result v2
|
|
|
|
if-eqz v2, :cond_6
|
|
|
|
sget-object v2, Lcom/ea/nimble/Error$Code;->NETWORK_TIMEOUT:Lcom/ea/nimble/Error$Code;
|
|
|
|
invoke-virtual {v2}, Lcom/ea/nimble/Error$Code;->intValue()I
|
|
|
|
move-result v2
|
|
|
|
if-ne v14, v2, :cond_6
|
|
|
|
const/4 v2, 0x1
|
|
|
|
goto :goto_2
|
|
|
|
:cond_6
|
|
const/4 v2, 0x0
|
|
|
|
:goto_2
|
|
move v15, v2
|
|
|
|
goto :goto_4
|
|
|
|
:cond_7
|
|
move-object/from16 v16, v13
|
|
|
|
.line 988
|
|
:try_start_1
|
|
invoke-virtual {v10}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
|
|
|
|
move-result-object v2
|
|
|
|
invoke-virtual {v2}, Ljava/lang/Class;->getName()Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
invoke-virtual {v1, v15, v2}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
|
|
:try_end_1
|
|
.catch Lorg/json/JSONException; {:try_start_1 .. :try_end_1} :catch_1
|
|
|
|
goto :goto_3
|
|
|
|
:catch_1
|
|
const-string v2, "Failed to add NIMBLE_ERROR_DOMAIN to eventDict."
|
|
|
|
const/4 v10, 0x0
|
|
|
|
new-array v13, v10, [Ljava/lang/Object;
|
|
|
|
.line 992
|
|
invoke-static {v0, v2, v13}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
goto :goto_3
|
|
|
|
:cond_8
|
|
move-object/from16 v16, v13
|
|
|
|
:goto_3
|
|
const/4 v15, 0x0
|
|
|
|
:goto_4
|
|
:try_start_2
|
|
const-string v13, "CONNECTIONID"
|
|
:try_end_2
|
|
.catch Lorg/json/JSONException; {:try_start_2 .. :try_end_2} :catch_2
|
|
|
|
:try_start_3
|
|
iget-object v2, v0, Lcom/ea/nimble/NetworkConnection;->m_loggingId:Ljava/lang/String;
|
|
|
|
.line 1001
|
|
invoke-virtual {v1, v13, v2}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
|
|
|
|
const-string v13, "URL_ABSOLUTE"
|
|
|
|
.line 1003
|
|
invoke-virtual {v1, v13, v8}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
|
|
|
|
const-string v13, "URL_PROTOCOL"
|
|
|
|
.line 1005
|
|
invoke-virtual {v1, v13, v3}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
|
|
|
|
const-string v13, "URL_PATH"
|
|
|
|
.line 1007
|
|
invoke-virtual {v1, v13, v4}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
|
|
|
|
const-string v13, "URL_QUERY"
|
|
|
|
.line 1009
|
|
invoke-virtual {v1, v13, v5}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
|
|
|
|
const-string v13, "URL_HOST"
|
|
|
|
.line 1011
|
|
invoke-virtual {v1, v13, v6}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
|
|
|
|
const-string v13, "RESPONSE_TIME_MS"
|
|
|
|
.line 1013
|
|
invoke-virtual {v1, v13, v9}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
|
|
|
|
const-string v13, "HTTP_STATUS_CODE"
|
|
|
|
.line 1015
|
|
invoke-virtual {v1, v13, v7}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
|
|
|
|
const-string v13, "REQUEST_TIMED_OUT"
|
|
|
|
.line 1017
|
|
invoke-static {v15}, Ljava/lang/String;->valueOf(Z)Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
invoke-virtual {v1, v13, v2}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
|
|
:try_end_3
|
|
.catch Lorg/json/JSONException; {:try_start_3 .. :try_end_3} :catch_3
|
|
|
|
goto :goto_5
|
|
|
|
:catch_2
|
|
move-object/from16 v13, v16
|
|
|
|
.line 1021
|
|
:catch_3
|
|
new-instance v2, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
invoke-virtual {v2, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v2, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v2, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
const/4 v3, 0x0
|
|
|
|
new-array v3, v3, [Ljava/lang/Object;
|
|
|
|
invoke-static {v0, v2, v3}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
:goto_5
|
|
iget-object v2, v0, Lcom/ea/nimble/NetworkConnection;->m_otDispatch:Lcom/ea/nimble/IOperationalTelemetryDispatch;
|
|
|
|
const-string v3, "com.ea.nimble.network"
|
|
|
|
.line 1024
|
|
invoke-virtual {v1}, Lorg/json/JSONObject;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-interface {v2, v3, v1}, Lcom/ea/nimble/IOperationalTelemetryDispatch;->logEvent(Ljava/lang/String;Ljava/lang/String;)V
|
|
|
|
return-void
|
|
|
|
:goto_6
|
|
const-string v1, "Empty request object and/or request URL for OT logging."
|
|
|
|
new-array v2, v3, [Ljava/lang/Object;
|
|
|
|
.line 903
|
|
invoke-static {v0, v1, v2}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public run()V
|
|
.locals 7
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 171
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNCS(Ljava/lang/String;)V
|
|
|
|
const/4 v0, 0x0
|
|
|
|
:try_start_0
|
|
iget-object v1, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 174
|
|
iget-boolean v1, v1, Lcom/ea/nimble/HttpResponse;->isCompleted:Z
|
|
:try_end_0
|
|
.catch Ljava/lang/ClassCastException; {:try_start_0 .. :try_end_0} :catch_6
|
|
.catch Ljava/net/SocketTimeoutException; {:try_start_0 .. :try_end_0} :catch_5
|
|
.catch Ljava/io/InterruptedIOException; {:try_start_0 .. :try_end_0} :catch_4
|
|
.catch Ljava/net/UnknownHostException; {:try_start_0 .. :try_end_0} :catch_3
|
|
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_2
|
|
.catch Lcom/ea/nimble/Error; {:try_start_0 .. :try_end_0} :catch_1
|
|
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
|
|
.catchall {:try_start_0 .. :try_end_0} :catchall_2
|
|
|
|
if-eqz v1, :cond_0
|
|
|
|
.line 261
|
|
monitor-enter p0
|
|
|
|
:try_start_1
|
|
iput-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_thread:Ljava/lang/Thread;
|
|
|
|
.line 264
|
|
monitor-exit p0
|
|
|
|
return-void
|
|
|
|
:catchall_0
|
|
move-exception v0
|
|
|
|
monitor-exit p0
|
|
:try_end_1
|
|
.catchall {:try_start_1 .. :try_end_1} :catchall_0
|
|
|
|
throw v0
|
|
|
|
.line 178
|
|
:cond_0
|
|
:try_start_2
|
|
invoke-static {}, Ljava/lang/Thread;->interrupted()Z
|
|
|
|
move-result v1
|
|
|
|
if-nez v1, :cond_3
|
|
|
|
.line 183
|
|
monitor-enter p0
|
|
:try_end_2
|
|
.catch Ljava/lang/ClassCastException; {:try_start_2 .. :try_end_2} :catch_6
|
|
.catch Ljava/net/SocketTimeoutException; {:try_start_2 .. :try_end_2} :catch_5
|
|
.catch Ljava/io/InterruptedIOException; {:try_start_2 .. :try_end_2} :catch_4
|
|
.catch Ljava/net/UnknownHostException; {:try_start_2 .. :try_end_2} :catch_3
|
|
.catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_2
|
|
.catch Lcom/ea/nimble/Error; {:try_start_2 .. :try_end_2} :catch_1
|
|
.catch Ljava/lang/Exception; {:try_start_2 .. :try_end_2} :catch_0
|
|
.catchall {:try_start_2 .. :try_end_2} :catchall_2
|
|
|
|
.line 185
|
|
:try_start_3
|
|
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
|
|
|
|
move-result-object v1
|
|
|
|
iput-object v1, p0, Lcom/ea/nimble/NetworkConnection;->m_thread:Ljava/lang/Thread;
|
|
|
|
.line 186
|
|
monitor-exit p0
|
|
:try_end_3
|
|
.catchall {:try_start_3 .. :try_end_3} :catchall_3
|
|
|
|
:try_start_4
|
|
iget-object v1, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 187
|
|
invoke-virtual {v1}, Lcom/ea/nimble/HttpRequest;->getUrl()Ljava/net/URL;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-virtual {v1}, Ljava/net/URL;->openConnection()Ljava/net/URLConnection;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-static {v1}, Lcom/google/firebase/perf/network/FirebasePerfUrlConnection;->instrument(Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
move-result-object v1
|
|
|
|
check-cast v1, Ljava/net/URLConnection;
|
|
|
|
check-cast v1, Ljava/net/HttpURLConnection;
|
|
|
|
iget-object v2, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 188
|
|
iget-object v2, v2, Lcom/ea/nimble/HttpRequest;->method:Lcom/ea/nimble/IHttpRequest$Method;
|
|
|
|
invoke-virtual {v2}, Lcom/ea/nimble/IHttpRequest$Method;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
invoke-virtual {v1, v2}, Ljava/net/HttpURLConnection;->setRequestMethod(Ljava/lang/String;)V
|
|
|
|
iget-object v2, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 189
|
|
iget-wide v2, v2, Lcom/ea/nimble/HttpRequest;->timeout:D
|
|
|
|
const-wide v4, 0x408f400000000000L # 1000.0
|
|
|
|
mul-double/2addr v2, v4
|
|
|
|
double-to-int v2, v2
|
|
|
|
invoke-virtual {v1, v2}, Ljava/net/URLConnection;->setConnectTimeout(I)V
|
|
|
|
iget-object v2, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
.line 193
|
|
iget-wide v2, v2, Lcom/ea/nimble/HttpRequest;->timeout:D
|
|
|
|
mul-double/2addr v2, v4
|
|
|
|
double-to-int v2, v2
|
|
|
|
invoke-virtual {v1, v2}, Ljava/net/URLConnection;->setReadTimeout(I)V
|
|
|
|
const-string v2, "Connection"
|
|
|
|
const-string v3, "close"
|
|
|
|
.line 204
|
|
invoke-virtual {v1, v2, v3}, Ljava/net/URLConnection;->setRequestProperty(Ljava/lang/String;Ljava/lang/String;)V
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_requestDataForLog:Ljava/lang/String;
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_responseDataForLog:Ljava/lang/StringBuilder;
|
|
|
|
.line 209
|
|
invoke-static {}, Ljava/lang/Thread;->interrupted()Z
|
|
|
|
move-result v2
|
|
|
|
if-nez v2, :cond_2
|
|
|
|
.line 213
|
|
invoke-direct {p0, v1}, Lcom/ea/nimble/NetworkConnection;->httpSend(Ljava/net/HttpURLConnection;)V
|
|
|
|
.line 214
|
|
invoke-static {}, Ljava/lang/Thread;->interrupted()Z
|
|
|
|
move-result v2
|
|
|
|
if-nez v2, :cond_1
|
|
|
|
.line 218
|
|
invoke-direct {p0, v1}, Lcom/ea/nimble/NetworkConnection;->httpRecv(Ljava/net/HttpURLConnection;)V
|
|
|
|
.line 219
|
|
invoke-direct {p0}, Lcom/ea/nimble/NetworkConnection;->finish()V
|
|
:try_end_4
|
|
.catch Ljava/lang/ClassCastException; {:try_start_4 .. :try_end_4} :catch_6
|
|
.catch Ljava/net/SocketTimeoutException; {:try_start_4 .. :try_end_4} :catch_5
|
|
.catch Ljava/io/InterruptedIOException; {:try_start_4 .. :try_end_4} :catch_4
|
|
.catch Ljava/net/UnknownHostException; {:try_start_4 .. :try_end_4} :catch_3
|
|
.catch Ljava/io/IOException; {:try_start_4 .. :try_end_4} :catch_2
|
|
.catch Lcom/ea/nimble/Error; {:try_start_4 .. :try_end_4} :catch_1
|
|
.catch Ljava/lang/Exception; {:try_start_4 .. :try_end_4} :catch_0
|
|
.catchall {:try_start_4 .. :try_end_4} :catchall_2
|
|
|
|
.line 261
|
|
monitor-enter p0
|
|
|
|
:try_start_5
|
|
iput-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_thread:Ljava/lang/Thread;
|
|
|
|
.line 264
|
|
monitor-exit p0
|
|
|
|
goto/16 :goto_8
|
|
|
|
:catchall_1
|
|
move-exception v0
|
|
|
|
monitor-exit p0
|
|
:try_end_5
|
|
.catchall {:try_start_5 .. :try_end_5} :catchall_1
|
|
|
|
throw v0
|
|
|
|
:catchall_2
|
|
move-exception v1
|
|
|
|
goto/16 :goto_9
|
|
|
|
:catch_0
|
|
move-exception v1
|
|
|
|
goto :goto_0
|
|
|
|
:catch_1
|
|
move-exception v1
|
|
|
|
goto :goto_1
|
|
|
|
:catch_2
|
|
move-exception v1
|
|
|
|
goto :goto_2
|
|
|
|
:catch_3
|
|
move-exception v1
|
|
|
|
goto :goto_3
|
|
|
|
:catch_4
|
|
move-exception v1
|
|
|
|
goto/16 :goto_5
|
|
|
|
:catch_5
|
|
move-exception v1
|
|
|
|
goto/16 :goto_6
|
|
|
|
:catch_6
|
|
move-exception v1
|
|
|
|
goto/16 :goto_7
|
|
|
|
.line 216
|
|
:cond_1
|
|
:try_start_6
|
|
new-instance v1, Ljava/io/InterruptedIOException;
|
|
|
|
invoke-direct {v1}, Ljava/io/InterruptedIOException;-><init>()V
|
|
|
|
throw v1
|
|
|
|
.line 211
|
|
:cond_2
|
|
new-instance v1, Ljava/io/InterruptedIOException;
|
|
|
|
invoke-direct {v1}, Ljava/io/InterruptedIOException;-><init>()V
|
|
|
|
throw v1
|
|
:try_end_6
|
|
.catch Ljava/lang/ClassCastException; {:try_start_6 .. :try_end_6} :catch_6
|
|
.catch Ljava/net/SocketTimeoutException; {:try_start_6 .. :try_end_6} :catch_5
|
|
.catch Ljava/io/InterruptedIOException; {:try_start_6 .. :try_end_6} :catch_4
|
|
.catch Ljava/net/UnknownHostException; {:try_start_6 .. :try_end_6} :catch_3
|
|
.catch Ljava/io/IOException; {:try_start_6 .. :try_end_6} :catch_2
|
|
.catch Lcom/ea/nimble/Error; {:try_start_6 .. :try_end_6} :catch_1
|
|
.catch Ljava/lang/Exception; {:try_start_6 .. :try_end_6} :catch_0
|
|
.catchall {:try_start_6 .. :try_end_6} :catchall_2
|
|
|
|
:catchall_3
|
|
move-exception v1
|
|
|
|
.line 186
|
|
:try_start_7
|
|
monitor-exit p0
|
|
:try_end_7
|
|
.catchall {:try_start_7 .. :try_end_7} :catchall_3
|
|
|
|
:try_start_8
|
|
throw v1
|
|
|
|
.line 180
|
|
:cond_3
|
|
new-instance v1, Ljava/io/InterruptedIOException;
|
|
|
|
invoke-direct {v1}, Ljava/io/InterruptedIOException;-><init>()V
|
|
|
|
throw v1
|
|
:try_end_8
|
|
.catch Ljava/lang/ClassCastException; {:try_start_8 .. :try_end_8} :catch_6
|
|
.catch Ljava/net/SocketTimeoutException; {:try_start_8 .. :try_end_8} :catch_5
|
|
.catch Ljava/io/InterruptedIOException; {:try_start_8 .. :try_end_8} :catch_4
|
|
.catch Ljava/net/UnknownHostException; {:try_start_8 .. :try_end_8} :catch_3
|
|
.catch Ljava/io/IOException; {:try_start_8 .. :try_end_8} :catch_2
|
|
.catch Lcom/ea/nimble/Error; {:try_start_8 .. :try_end_8} :catch_1
|
|
.catch Ljava/lang/Exception; {:try_start_8 .. :try_end_8} :catch_0
|
|
.catchall {:try_start_8 .. :try_end_8} :catchall_2
|
|
|
|
.line 257
|
|
:goto_0
|
|
:try_start_9
|
|
new-instance v2, Lcom/ea/nimble/Error;
|
|
|
|
sget-object v3, Lcom/ea/nimble/Error$Code;->SYSTEM_UNEXPECTED:Lcom/ea/nimble/Error$Code;
|
|
|
|
const-string v4, "Unexpected error."
|
|
|
|
invoke-direct {v2, v3, v4, v1}, Lcom/ea/nimble/Error;-><init>(Lcom/ea/nimble/Error$Code;Ljava/lang/String;Ljava/lang/Throwable;)V
|
|
|
|
invoke-virtual {p0, v2}, Lcom/ea/nimble/NetworkConnection;->finishWithError(Ljava/lang/Exception;)V
|
|
:try_end_9
|
|
.catchall {:try_start_9 .. :try_end_9} :catchall_2
|
|
|
|
.line 261
|
|
monitor-enter p0
|
|
|
|
:try_start_a
|
|
iput-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_thread:Ljava/lang/Thread;
|
|
|
|
.line 264
|
|
monitor-exit p0
|
|
|
|
goto/16 :goto_8
|
|
|
|
:catchall_4
|
|
move-exception v0
|
|
|
|
monitor-exit p0
|
|
:try_end_a
|
|
.catchall {:try_start_a .. :try_end_a} :catchall_4
|
|
|
|
throw v0
|
|
|
|
.line 253
|
|
:goto_1
|
|
:try_start_b
|
|
invoke-virtual {p0, v1}, Lcom/ea/nimble/NetworkConnection;->finishWithError(Ljava/lang/Exception;)V
|
|
:try_end_b
|
|
.catchall {:try_start_b .. :try_end_b} :catchall_2
|
|
|
|
.line 261
|
|
monitor-enter p0
|
|
|
|
:try_start_c
|
|
iput-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_thread:Ljava/lang/Thread;
|
|
|
|
.line 264
|
|
monitor-exit p0
|
|
|
|
goto/16 :goto_8
|
|
|
|
:catchall_5
|
|
move-exception v0
|
|
|
|
monitor-exit p0
|
|
:try_end_c
|
|
.catchall {:try_start_c .. :try_end_c} :catchall_5
|
|
|
|
throw v0
|
|
|
|
.line 249
|
|
:goto_2
|
|
:try_start_d
|
|
new-instance v2, Lcom/ea/nimble/Error;
|
|
|
|
sget-object v3, Lcom/ea/nimble/Error$Code;->NETWORK_CONNECTION_ERROR:Lcom/ea/nimble/Error$Code;
|
|
|
|
new-instance v4, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v5, "Connection "
|
|
|
|
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v4, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
const-string v5, " failed with I/O exception"
|
|
|
|
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v4
|
|
|
|
invoke-direct {v2, v3, v4, v1}, Lcom/ea/nimble/Error;-><init>(Lcom/ea/nimble/Error$Code;Ljava/lang/String;Ljava/lang/Throwable;)V
|
|
|
|
invoke-virtual {p0, v2}, Lcom/ea/nimble/NetworkConnection;->finishWithError(Ljava/lang/Exception;)V
|
|
:try_end_d
|
|
.catchall {:try_start_d .. :try_end_d} :catchall_2
|
|
|
|
.line 261
|
|
monitor-enter p0
|
|
|
|
:try_start_e
|
|
iput-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_thread:Ljava/lang/Thread;
|
|
|
|
.line 264
|
|
monitor-exit p0
|
|
|
|
goto/16 :goto_8
|
|
|
|
:catchall_6
|
|
move-exception v0
|
|
|
|
monitor-exit p0
|
|
:try_end_e
|
|
.catchall {:try_start_e .. :try_end_e} :catchall_6
|
|
|
|
throw v0
|
|
|
|
:goto_3
|
|
:try_start_f
|
|
iget-object v2, p0, Lcom/ea/nimble/NetworkConnection;->m_manager:Lcom/ea/nimble/NetworkImpl;
|
|
|
|
.line 236
|
|
invoke-virtual {v2}, Lcom/ea/nimble/NetworkImpl;->getStatus()Lcom/ea/nimble/Network$Status;
|
|
|
|
move-result-object v2
|
|
|
|
.line 238
|
|
sget-object v3, Lcom/ea/nimble/Network$Status;->OK:Lcom/ea/nimble/Network$Status;
|
|
|
|
if-eq v2, v3, :cond_4
|
|
|
|
.line 240
|
|
new-instance v3, Lcom/ea/nimble/Error;
|
|
|
|
sget-object v4, Lcom/ea/nimble/Error$Code;->NETWORK_NO_CONNECTION:Lcom/ea/nimble/Error$Code;
|
|
|
|
new-instance v5, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v6, "No network connection, network status "
|
|
|
|
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v2}, Lcom/ea/nimble/Network$Status;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
invoke-virtual {v5, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
invoke-direct {v3, v4, v2, v1}, Lcom/ea/nimble/Error;-><init>(Lcom/ea/nimble/Error$Code;Ljava/lang/String;Ljava/lang/Throwable;)V
|
|
|
|
invoke-virtual {p0, v3}, Lcom/ea/nimble/NetworkConnection;->finishWithError(Ljava/lang/Exception;)V
|
|
|
|
goto :goto_4
|
|
|
|
.line 244
|
|
:cond_4
|
|
new-instance v2, Lcom/ea/nimble/Error;
|
|
|
|
sget-object v3, Lcom/ea/nimble/Error$Code;->NETWORK_UNREACHABLE:Lcom/ea/nimble/Error$Code;
|
|
|
|
new-instance v4, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v5, "Request "
|
|
|
|
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v4, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
const-string v5, " failed for unreachable host"
|
|
|
|
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v4
|
|
|
|
invoke-direct {v2, v3, v4, v1}, Lcom/ea/nimble/Error;-><init>(Lcom/ea/nimble/Error$Code;Ljava/lang/String;Ljava/lang/Throwable;)V
|
|
|
|
invoke-virtual {p0, v2}, Lcom/ea/nimble/NetworkConnection;->finishWithError(Ljava/lang/Exception;)V
|
|
:try_end_f
|
|
.catchall {:try_start_f .. :try_end_f} :catchall_2
|
|
|
|
.line 261
|
|
:goto_4
|
|
monitor-enter p0
|
|
|
|
:try_start_10
|
|
iput-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_thread:Ljava/lang/Thread;
|
|
|
|
.line 264
|
|
monitor-exit p0
|
|
|
|
goto/16 :goto_8
|
|
|
|
:catchall_7
|
|
move-exception v0
|
|
|
|
monitor-exit p0
|
|
:try_end_10
|
|
.catchall {:try_start_10 .. :try_end_10} :catchall_7
|
|
|
|
throw v0
|
|
|
|
.line 232
|
|
:goto_5
|
|
:try_start_11
|
|
new-instance v2, Lcom/ea/nimble/Error;
|
|
|
|
sget-object v3, Lcom/ea/nimble/Error$Code;->NETWORK_OPERATION_CANCELLED:Lcom/ea/nimble/Error$Code;
|
|
|
|
new-instance v4, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v5, "Connection "
|
|
|
|
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v4, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
const-string v5, " is cancelled"
|
|
|
|
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v4
|
|
|
|
invoke-direct {v2, v3, v4, v1}, Lcom/ea/nimble/Error;-><init>(Lcom/ea/nimble/Error$Code;Ljava/lang/String;Ljava/lang/Throwable;)V
|
|
|
|
invoke-virtual {p0, v2}, Lcom/ea/nimble/NetworkConnection;->finishWithError(Ljava/lang/Exception;)V
|
|
:try_end_11
|
|
.catchall {:try_start_11 .. :try_end_11} :catchall_2
|
|
|
|
.line 261
|
|
monitor-enter p0
|
|
|
|
:try_start_12
|
|
iput-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_thread:Ljava/lang/Thread;
|
|
|
|
.line 264
|
|
monitor-exit p0
|
|
|
|
goto :goto_8
|
|
|
|
:catchall_8
|
|
move-exception v0
|
|
|
|
monitor-exit p0
|
|
:try_end_12
|
|
.catchall {:try_start_12 .. :try_end_12} :catchall_8
|
|
|
|
throw v0
|
|
|
|
.line 228
|
|
:goto_6
|
|
:try_start_13
|
|
new-instance v2, Lcom/ea/nimble/Error;
|
|
|
|
sget-object v3, Lcom/ea/nimble/Error$Code;->NETWORK_TIMEOUT:Lcom/ea/nimble/Error$Code;
|
|
|
|
new-instance v4, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v5, "Connection "
|
|
|
|
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v4, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
const-string v5, " timed out"
|
|
|
|
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v4
|
|
|
|
invoke-direct {v2, v3, v4, v1}, Lcom/ea/nimble/Error;-><init>(Lcom/ea/nimble/Error$Code;Ljava/lang/String;Ljava/lang/Throwable;)V
|
|
|
|
invoke-virtual {p0, v2}, Lcom/ea/nimble/NetworkConnection;->finishWithError(Ljava/lang/Exception;)V
|
|
:try_end_13
|
|
.catchall {:try_start_13 .. :try_end_13} :catchall_2
|
|
|
|
.line 261
|
|
monitor-enter p0
|
|
|
|
:try_start_14
|
|
iput-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_thread:Ljava/lang/Thread;
|
|
|
|
.line 264
|
|
monitor-exit p0
|
|
|
|
goto :goto_8
|
|
|
|
:catchall_9
|
|
move-exception v0
|
|
|
|
monitor-exit p0
|
|
:try_end_14
|
|
.catchall {:try_start_14 .. :try_end_14} :catchall_9
|
|
|
|
throw v0
|
|
|
|
.line 224
|
|
:goto_7
|
|
:try_start_15
|
|
new-instance v2, Lcom/ea/nimble/Error;
|
|
|
|
sget-object v3, Lcom/ea/nimble/Error$Code;->NETWORK_UNSUPPORTED_CONNECTION_TYPE:Lcom/ea/nimble/Error$Code;
|
|
|
|
new-instance v4, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v5, "Request "
|
|
|
|
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v4, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
const-string v5, " failed for unsupported connection type"
|
|
|
|
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
iget-object v5, p0, Lcom/ea/nimble/NetworkConnection;->m_request:Lcom/ea/nimble/HttpRequest;
|
|
|
|
invoke-virtual {v5}, Lcom/ea/nimble/HttpRequest;->getUrl()Ljava/net/URL;
|
|
|
|
move-result-object v5
|
|
|
|
invoke-virtual {v5}, Ljava/net/URL;->getProtocol()Ljava/lang/String;
|
|
|
|
move-result-object v5
|
|
|
|
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v4
|
|
|
|
invoke-direct {v2, v3, v4, v1}, Lcom/ea/nimble/Error;-><init>(Lcom/ea/nimble/Error$Code;Ljava/lang/String;Ljava/lang/Throwable;)V
|
|
|
|
invoke-virtual {p0, v2}, Lcom/ea/nimble/NetworkConnection;->finishWithError(Ljava/lang/Exception;)V
|
|
:try_end_15
|
|
.catchall {:try_start_15 .. :try_end_15} :catchall_2
|
|
|
|
.line 261
|
|
monitor-enter p0
|
|
|
|
:try_start_16
|
|
iput-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_thread:Ljava/lang/Thread;
|
|
|
|
.line 264
|
|
monitor-exit p0
|
|
|
|
:goto_8
|
|
return-void
|
|
|
|
:catchall_a
|
|
move-exception v0
|
|
|
|
monitor-exit p0
|
|
:try_end_16
|
|
.catchall {:try_start_16 .. :try_end_16} :catchall_a
|
|
|
|
throw v0
|
|
|
|
.line 261
|
|
:goto_9
|
|
monitor-enter p0
|
|
|
|
:try_start_17
|
|
iput-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_thread:Ljava/lang/Thread;
|
|
|
|
.line 264
|
|
monitor-exit p0
|
|
:try_end_17
|
|
.catchall {:try_start_17 .. :try_end_17} :catchall_b
|
|
|
|
.line 265
|
|
throw v1
|
|
|
|
:catchall_b
|
|
move-exception v0
|
|
|
|
.line 264
|
|
:try_start_18
|
|
monitor-exit p0
|
|
:try_end_18
|
|
.catchall {:try_start_18 .. :try_end_18} :catchall_b
|
|
|
|
throw v0
|
|
.end method
|
|
|
|
.method public setCompletionCallback(Lcom/ea/nimble/NetworkConnectionCallback;)V
|
|
.locals 1
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 121
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNCS(Ljava/lang/String;)V
|
|
|
|
iput-object p1, p0, Lcom/ea/nimble/NetworkConnection;->m_completionCallback:Lcom/ea/nimble/NetworkConnectionCallback;
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public setHeaderCallback(Lcom/ea/nimble/NetworkConnectionCallback;)V
|
|
.locals 1
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 93
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNCS(Ljava/lang/String;)V
|
|
|
|
iput-object p1, p0, Lcom/ea/nimble/NetworkConnection;->m_headerCallback:Lcom/ea/nimble/NetworkConnectionCallback;
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public setProgressCallback(Lcom/ea/nimble/NetworkConnectionCallback;)V
|
|
.locals 1
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 107
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNCS(Ljava/lang/String;)V
|
|
|
|
iput-object p1, p0, Lcom/ea/nimble/NetworkConnection;->m_progressCallback:Lcom/ea/nimble/NetworkConnectionCallback;
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public waitOn()V
|
|
.locals 1
|
|
|
|
const-string v0, "NetworkConnection"
|
|
|
|
.line 128
|
|
invoke-static {v0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNCS(Ljava/lang/String;)V
|
|
|
|
.line 129
|
|
monitor-enter p0
|
|
|
|
:catch_0
|
|
:goto_0
|
|
:try_start_0
|
|
iget-object v0, p0, Lcom/ea/nimble/NetworkConnection;->m_response:Lcom/ea/nimble/HttpResponse;
|
|
|
|
.line 131
|
|
iget-boolean v0, v0, Lcom/ea/nimble/HttpResponse;->isCompleted:Z
|
|
:try_end_0
|
|
.catchall {:try_start_0 .. :try_end_0} :catchall_0
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
.line 135
|
|
:try_start_1
|
|
invoke-virtual {p0}, Ljava/lang/Object;->wait()V
|
|
:try_end_1
|
|
.catch Ljava/lang/InterruptedException; {:try_start_1 .. :try_end_1} :catch_0
|
|
.catchall {:try_start_1 .. :try_end_1} :catchall_0
|
|
|
|
goto :goto_0
|
|
|
|
:catchall_0
|
|
move-exception v0
|
|
|
|
goto :goto_1
|
|
|
|
.line 142
|
|
:cond_0
|
|
:try_start_2
|
|
monitor-exit p0
|
|
|
|
return-void
|
|
|
|
:goto_1
|
|
monitor-exit p0
|
|
:try_end_2
|
|
.catchall {:try_start_2 .. :try_end_2} :catchall_0
|
|
|
|
throw v0
|
|
.end method
|