Files
rr3-apk/smali_classes2/com/ea/nimble/NetworkConnection.smali
Daniel Elliott f3960ee359 Add Discord APKTool decompilation (Smali source for modding)
- 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
2026-02-18 16:13:44 -08:00

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