DTLSReliableHandshake.smali
.class Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;
.super Ljava/lang/Object;
.source "DTLSReliableHandshake.java"
# static fields
.field private static final MAX_RECEIVE_AHEAD:I = 0xa
# instance fields
.field private currentInboundFlight:Ljava/util/Hashtable;
.field private handshakeHash:Lorg/spongycastle/crypto/tls/TlsHandshakeHash;
.field private message_seq:I
.field private next_receive_seq:I
.field private outboundFlight:Ljava/util/Vector;
.field private previousInboundFlight:Ljava/util/Hashtable;
.field private final recordLayer:Lorg/spongycastle/crypto/tls/DTLSRecordLayer;
.field private sending:Z
# direct methods
.method constructor <init>(Lorg/spongycastle/crypto/tls/TlsContext;Lorg/spongycastle/crypto/tls/DTLSRecordLayer;)V
.registers 5
.prologue
const/4 v1, 0x0
.line 27
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 19
new-instance v0, Ljava/util/Hashtable;
invoke-direct {v0}, Ljava/util/Hashtable;-><init>()V
iput-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->currentInboundFlight:Ljava/util/Hashtable;
.line 20
const/4 v0, 0x0
iput-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->previousInboundFlight:Ljava/util/Hashtable;
.line 21
new-instance v0, Ljava/util/Vector;
invoke-direct {v0}, Ljava/util/Vector;-><init>()V
iput-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->outboundFlight:Ljava/util/Vector;
.line 22
const/4 v0, 0x1
iput-boolean v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->sending:Z
.line 24
iput v1, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->message_seq:I
iput v1, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->next_receive_seq:I
.line 28
iput-object p2, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->recordLayer:Lorg/spongycastle/crypto/tls/DTLSRecordLayer;
.line 29
new-instance v0, Lorg/spongycastle/crypto/tls/DeferredHash;
invoke-direct {v0}, Lorg/spongycastle/crypto/tls/DeferredHash;-><init>()V
iput-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->handshakeHash:Lorg/spongycastle/crypto/tls/TlsHandshakeHash;
.line 30
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->handshakeHash:Lorg/spongycastle/crypto/tls/TlsHandshakeHash;
invoke-interface {v0, p1}, Lorg/spongycastle/crypto/tls/TlsHandshakeHash;->init(Lorg/spongycastle/crypto/tls/TlsContext;)V
.line 31
return-void
.end method
.method static synthetic access$100(Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;)I
.registers 2
.prologue
.line 11
iget v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->next_receive_seq:I
return v0
.end method
.method static synthetic access$200(Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;)Ljava/util/Hashtable;
.registers 2
.prologue
.line 11
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->currentInboundFlight:Ljava/util/Hashtable;
return-object v0
.end method
.method static synthetic access$300(Ljava/util/Hashtable;)Z
.registers 2
.prologue
.line 11
invoke-static {p0}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->checkAll(Ljava/util/Hashtable;)Z
move-result v0
return v0
.end method
.method static synthetic access$400(Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;)V
.registers 1
.prologue
.line 11
invoke-direct {p0}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->resendOutboundFlight()V
return-void
.end method
.method static synthetic access$500(Ljava/util/Hashtable;)V
.registers 1
.prologue
.line 11
invoke-static {p0}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->resetAll(Ljava/util/Hashtable;)V
return-void
.end method
.method private static checkAll(Ljava/util/Hashtable;)Z
.registers 3
.prologue
.line 391
invoke-virtual {p0}, Ljava/util/Hashtable;->elements()Ljava/util/Enumeration;
move-result-object v1
.line 392
:cond_4
invoke-interface {v1}, Ljava/util/Enumeration;->hasMoreElements()Z
move-result v0
if-eqz v0, :cond_18
.line 394
invoke-interface {v1}, Ljava/util/Enumeration;->nextElement()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/spongycastle/crypto/tls/DTLSReassembler;
invoke-virtual {v0}, Lorg/spongycastle/crypto/tls/DTLSReassembler;->getBodyIfComplete()[B
move-result-object v0
if-nez v0, :cond_4
.line 396
const/4 v0, 0x0
.line 399
:goto_17
return v0
:cond_18
const/4 v0, 0x1
goto :goto_17
.end method
.method private checkInboundFlight()V
.registers 3
.prologue
.line 303
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->currentInboundFlight:Ljava/util/Hashtable;
invoke-virtual {v0}, Ljava/util/Hashtable;->keys()Ljava/util/Enumeration;
move-result-object v1
.line 304
:goto_6
invoke-interface {v1}, Ljava/util/Enumeration;->hasMoreElements()Z
move-result v0
if-eqz v0, :cond_16
.line 306
invoke-interface {v1}, Ljava/util/Enumeration;->nextElement()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/Integer;
.line 307
invoke-virtual {v0}, Ljava/lang/Integer;->intValue()I
goto :goto_6
.line 312
:cond_16
return-void
.end method
.method private prepareInboundFlight()V
.registers 2
.prologue
.line 316
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->currentInboundFlight:Ljava/util/Hashtable;
invoke-static {v0}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->resetAll(Ljava/util/Hashtable;)V
.line 317
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->currentInboundFlight:Ljava/util/Hashtable;
iput-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->previousInboundFlight:Ljava/util/Hashtable;
.line 318
new-instance v0, Ljava/util/Hashtable;
invoke-direct {v0}, Ljava/util/Hashtable;-><init>()V
iput-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->currentInboundFlight:Ljava/util/Hashtable;
.line 319
return-void
.end method
.method private resendOutboundFlight()V
.registers 3
.prologue
.line 324
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->recordLayer:Lorg/spongycastle/crypto/tls/DTLSRecordLayer;
invoke-virtual {v0}, Lorg/spongycastle/crypto/tls/DTLSRecordLayer;->resetWriteEpoch()V
.line 325
const/4 v0, 0x0
move v1, v0
:goto_7
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->outboundFlight:Ljava/util/Vector;
invoke-virtual {v0}, Ljava/util/Vector;->size()I
move-result v0
if-ge v1, v0, :cond_1e
.line 327
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->outboundFlight:Ljava/util/Vector;
invoke-virtual {v0, v1}, Ljava/util/Vector;->elementAt(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;
invoke-direct {p0, v0}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->writeMessage(Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;)V
.line 325
add-int/lit8 v0, v1, 0x1
move v1, v0
goto :goto_7
.line 329
:cond_1e
return-void
.end method
.method private static resetAll(Ljava/util/Hashtable;)V
.registers 3
.prologue
.line 404
invoke-virtual {p0}, Ljava/util/Hashtable;->elements()Ljava/util/Enumeration;
move-result-object v1
.line 405
:goto_4
invoke-interface {v1}, Ljava/util/Enumeration;->hasMoreElements()Z
move-result v0
if-eqz v0, :cond_14
.line 407
invoke-interface {v1}, Ljava/util/Enumeration;->nextElement()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/spongycastle/crypto/tls/DTLSReassembler;
invoke-virtual {v0}, Lorg/spongycastle/crypto/tls/DTLSReassembler;->reset()V
goto :goto_4
.line 409
:cond_14
return-void
.end method
.method private updateHandshakeMessagesDigest(Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;)Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;
.registers 8
.prologue
const/16 v5, 0xc
const/4 v4, 0x0
.line 334
invoke-virtual {p1}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;->getType()S
move-result v0
if-eqz v0, :cond_38
.line 336
invoke-virtual {p1}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;->getBody()[B
move-result-object v0
.line 337
new-array v1, v5, [B
.line 338
invoke-virtual {p1}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;->getType()S
move-result v2
invoke-static {v2, v1, v4}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeUint8(S[BI)V
.line 339
array-length v2, v0
const/4 v3, 0x1
invoke-static {v2, v1, v3}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeUint24(I[BI)V
.line 340
invoke-virtual {p1}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;->getSeq()I
move-result v2
const/4 v3, 0x4
invoke-static {v2, v1, v3}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeUint16(I[BI)V
.line 341
const/4 v2, 0x6
invoke-static {v4, v1, v2}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeUint24(I[BI)V
.line 342
array-length v2, v0
const/16 v3, 0x9
invoke-static {v2, v1, v3}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeUint24(I[BI)V
.line 343
iget-object v2, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->handshakeHash:Lorg/spongycastle/crypto/tls/TlsHandshakeHash;
invoke-interface {v2, v1, v4, v5}, Lorg/spongycastle/crypto/tls/TlsHandshakeHash;->update([BII)V
.line 344
iget-object v1, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->handshakeHash:Lorg/spongycastle/crypto/tls/TlsHandshakeHash;
array-length v2, v0
invoke-interface {v1, v0, v4, v2}, Lorg/spongycastle/crypto/tls/TlsHandshakeHash;->update([BII)V
.line 346
:cond_38
return-object p1
.end method
.method private writeHandshakeFragment(Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;II)V
.registers 6
.prologue
.line 378
new-instance v0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$RecordLayerBuffer;
add-int/lit8 v1, p3, 0xc
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$RecordLayerBuffer;-><init>(I)V
.line 379
invoke-virtual {p1}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;->getType()S
move-result v1
invoke-static {v1, v0}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeUint8(SLjava/io/OutputStream;)V
.line 380
invoke-virtual {p1}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;->getBody()[B
move-result-object v1
array-length v1, v1
invoke-static {v1, v0}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeUint24(ILjava/io/OutputStream;)V
.line 381
invoke-virtual {p1}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;->getSeq()I
move-result v1
invoke-static {v1, v0}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeUint16(ILjava/io/OutputStream;)V
.line 382
invoke-static {p2, v0}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeUint24(ILjava/io/OutputStream;)V
.line 383
invoke-static {p3, v0}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeUint24(ILjava/io/OutputStream;)V
.line 384
invoke-virtual {p1}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;->getBody()[B
move-result-object v1
invoke-virtual {v0, v1, p2, p3}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$RecordLayerBuffer;->write([BII)V
.line 386
iget-object v1, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->recordLayer:Lorg/spongycastle/crypto/tls/DTLSRecordLayer;
invoke-virtual {v0, v1}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$RecordLayerBuffer;->sendToRecordLayer(Lorg/spongycastle/crypto/tls/DTLSRecordLayer;)V
.line 387
return-void
.end method
.method private writeMessage(Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;)V
.registers 6
.prologue
.line 352
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->recordLayer:Lorg/spongycastle/crypto/tls/DTLSRecordLayer;
invoke-virtual {v0}, Lorg/spongycastle/crypto/tls/DTLSRecordLayer;->getSendLimit()I
move-result v0
.line 353
add-int/lit8 v1, v0, -0xc
.line 356
if-gtz v1, :cond_12
.line 359
new-instance v0, Lorg/spongycastle/crypto/tls/TlsFatalAlert;
const/16 v1, 0x50
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/tls/TlsFatalAlert;-><init>(S)V
throw v0
.line 362
:cond_12
invoke-virtual {p1}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;->getBody()[B
move-result-object v0
array-length v2, v0
.line 365
const/4 v0, 0x0
.line 368
:cond_18
sub-int v3, v2, v0
invoke-static {v3, v1}, Ljava/lang/Math;->min(II)I
move-result v3
.line 369
invoke-direct {p0, p1, v0, v3}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->writeHandshakeFragment(Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;II)V
.line 370
add-int/2addr v0, v3
.line 372
if-lt v0, v2, :cond_18
.line 373
return-void
.end method
# virtual methods
.method finish()V
.registers 3
.prologue
.line 222
const/4 v0, 0x0
.line 223
iget-boolean v1, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->sending:Z
if-nez v1, :cond_e
.line 225
invoke-direct {p0}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->checkInboundFlight()V
.line 290
:cond_8
:goto_8
iget-object v1, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->recordLayer:Lorg/spongycastle/crypto/tls/DTLSRecordLayer;
invoke-virtual {v1, v0}, Lorg/spongycastle/crypto/tls/DTLSRecordLayer;->handshakeSuccessful(Lorg/spongycastle/crypto/tls/DTLSHandshakeRetransmit;)V
.line 291
return-void
.line 227
:cond_e
iget-object v1, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->currentInboundFlight:Ljava/util/Hashtable;
if-eqz v1, :cond_8
.line 235
new-instance v0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$1;
invoke-direct {v0, p0}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$1;-><init>(Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;)V
goto :goto_8
.end method
.method getHandshakeHash()Lorg/spongycastle/crypto/tls/TlsHandshakeHash;
.registers 2
.prologue
.line 40
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->handshakeHash:Lorg/spongycastle/crypto/tls/TlsHandshakeHash;
return-object v0
.end method
.method notifyHelloComplete()V
.registers 2
.prologue
.line 35
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->handshakeHash:Lorg/spongycastle/crypto/tls/TlsHandshakeHash;
invoke-interface {v0}, Lorg/spongycastle/crypto/tls/TlsHandshakeHash;->notifyPRFDetermined()Lorg/spongycastle/crypto/tls/TlsHandshakeHash;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->handshakeHash:Lorg/spongycastle/crypto/tls/TlsHandshakeHash;
.line 36
return-void
.end method
.method prepareToFinish()Lorg/spongycastle/crypto/tls/TlsHandshakeHash;
.registers 3
.prologue
.line 45
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->handshakeHash:Lorg/spongycastle/crypto/tls/TlsHandshakeHash;
.line 46
iget-object v1, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->handshakeHash:Lorg/spongycastle/crypto/tls/TlsHandshakeHash;
invoke-interface {v1}, Lorg/spongycastle/crypto/tls/TlsHandshakeHash;->stopTracking()Lorg/spongycastle/crypto/tls/TlsHandshakeHash;
move-result-object v1
iput-object v1, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->handshakeHash:Lorg/spongycastle/crypto/tls/TlsHandshakeHash;
.line 47
return-object v0
.end method
.method receiveMessage()Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;
.registers 14
.prologue
const v12, 0xea60
const/16 v11, 0xc
const/4 v1, 0x0
const/4 v3, 0x0
.line 85
iget-boolean v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->sending:Z
if-eqz v0, :cond_10
.line 87
iput-boolean v1, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->sending:Z
.line 88
invoke-direct {p0}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->prepareInboundFlight()V
.line 93
:cond_10
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->currentInboundFlight:Ljava/util/Hashtable;
iget v1, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->next_receive_seq:I
invoke-static {v1}, Lorg/spongycastle/util/Integers;->valueOf(I)Ljava/lang/Integer;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/util/Hashtable;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/spongycastle/crypto/tls/DTLSReassembler;
.line 94
if-eqz v0, :cond_3c
.line 96
invoke-virtual {v0}, Lorg/spongycastle/crypto/tls/DTLSReassembler;->getBodyIfComplete()[B
move-result-object v1
.line 97
if-eqz v1, :cond_3c
.line 99
iput-object v3, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->previousInboundFlight:Ljava/util/Hashtable;
.line 100
new-instance v2, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;
iget v4, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->next_receive_seq:I
add-int/lit8 v5, v4, 0x1
iput v5, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->next_receive_seq:I
invoke-virtual {v0}, Lorg/spongycastle/crypto/tls/DTLSReassembler;->getMsgType()S
move-result v0
invoke-direct {v2, v4, v0, v1, v3}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;-><init>(IS[BLorg/spongycastle/crypto/tls/DTLSReliableHandshake$1;)V
invoke-direct {p0, v2}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->updateHandshakeMessagesDigest(Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;)Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;
move-result-object v0
.line 198
:goto_3b
return-object v0
.line 108
:cond_3c
const/16 v0, 0x3e8
.line 112
:goto_3e
iget-object v1, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->recordLayer:Lorg/spongycastle/crypto/tls/DTLSRecordLayer;
invoke-virtual {v1}, Lorg/spongycastle/crypto/tls/DTLSRecordLayer;->getReceiveLimit()I
move-result v8
.line 113
if-eqz v3, :cond_49
array-length v1, v3
if-ge v1, v8, :cond_108
.line 115
:cond_49
new-array v3, v8, [B
move v7, v0
.line 124
:cond_4c
:goto_4c
:try_start_4c
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->recordLayer:Lorg/spongycastle/crypto/tls/DTLSRecordLayer;
const/4 v1, 0x0
invoke-virtual {v0, v3, v1, v8, v7}, Lorg/spongycastle/crypto/tls/DTLSRecordLayer;->receive([BIII)I
move-result v0
.line 125
if-ltz v0, :cond_fa
.line 129
if-lt v0, v11, :cond_4c
.line 133
const/16 v1, 0x9
invoke-static {v3, v1}, Lorg/spongycastle/crypto/tls/TlsUtils;->readUint24([BI)I
move-result v6
.line 134
add-int/lit8 v1, v6, 0xc
if-ne v0, v1, :cond_4c
.line 138
const/4 v0, 0x4
invoke-static {v3, v0}, Lorg/spongycastle/crypto/tls/TlsUtils;->readUint16([BI)I
move-result v9
.line 139
iget v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->next_receive_seq:I
add-int/lit8 v0, v0, 0xa
if-gt v9, v0, :cond_4c
.line 143
const/4 v0, 0x0
invoke-static {v3, v0}, Lorg/spongycastle/crypto/tls/TlsUtils;->readUint8([BI)S
move-result v1
.line 144
const/4 v0, 0x1
invoke-static {v3, v0}, Lorg/spongycastle/crypto/tls/TlsUtils;->readUint24([BI)I
move-result v2
.line 145
const/4 v0, 0x6
invoke-static {v3, v0}, Lorg/spongycastle/crypto/tls/TlsUtils;->readUint24([BI)I
move-result v5
.line 146
add-int v0, v5, v6
if-gt v0, v2, :cond_4c
.line 151
iget v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->next_receive_seq:I
if-ge v9, v0, :cond_b5
.line 157
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->previousInboundFlight:Ljava/util/Hashtable;
if-eqz v0, :cond_4c
.line 159
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->previousInboundFlight:Ljava/util/Hashtable;
.line 160
invoke-static {v9}, Lorg/spongycastle/util/Integers;->valueOf(I)Ljava/lang/Integer;
move-result-object v4
.line 159
invoke-virtual {v0, v4}, Ljava/util/Hashtable;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/spongycastle/crypto/tls/DTLSReassembler;
.line 161
if-eqz v0, :cond_10b
.line 163
const/16 v4, 0xc
invoke-virtual/range {v0 .. v6}, Lorg/spongycastle/crypto/tls/DTLSReassembler;->contributeFragment(SI[BIII)V
.line 166
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->previousInboundFlight:Ljava/util/Hashtable;
invoke-static {v0}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->checkAll(Ljava/util/Hashtable;)Z
move-result v0
if-eqz v0, :cond_10b
.line 168
invoke-direct {p0}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->resendOutboundFlight()V
.line 174
shl-int/lit8 v0, v7, 0x1
const v1, 0xea60
invoke-static {v0, v1}, Ljava/lang/Math;->min(II)I
:try_end_ad
.catch Ljava/io/IOException; {:try_start_4c .. :try_end_ad} :catch_f9
move-result v0
.line 176
:try_start_ae
iget-object v1, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->previousInboundFlight:Ljava/util/Hashtable;
invoke-static {v1}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->resetAll(Ljava/util/Hashtable;)V
:try_end_b3
.catch Ljava/io/IOException; {:try_start_ae .. :try_end_b3} :catch_105
:goto_b3
move v7, v0
.line 179
goto :goto_4c
.line 183
:cond_b5
:try_start_b5
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->currentInboundFlight:Ljava/util/Hashtable;
invoke-static {v9}, Lorg/spongycastle/util/Integers;->valueOf(I)Ljava/lang/Integer;
move-result-object v4
invoke-virtual {v0, v4}, Ljava/util/Hashtable;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/spongycastle/crypto/tls/DTLSReassembler;
.line 184
if-nez v0, :cond_d1
.line 186
new-instance v0, Lorg/spongycastle/crypto/tls/DTLSReassembler;
invoke-direct {v0, v1, v2}, Lorg/spongycastle/crypto/tls/DTLSReassembler;-><init>(SI)V
.line 187
iget-object v4, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->currentInboundFlight:Ljava/util/Hashtable;
invoke-static {v9}, Lorg/spongycastle/util/Integers;->valueOf(I)Ljava/lang/Integer;
move-result-object v10
invoke-virtual {v4, v10, v0}, Ljava/util/Hashtable;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 190
:cond_d1
const/16 v4, 0xc
invoke-virtual/range {v0 .. v6}, Lorg/spongycastle/crypto/tls/DTLSReassembler;->contributeFragment(SI[BIII)V
.line 192
iget v1, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->next_receive_seq:I
if-ne v9, v1, :cond_4c
.line 194
invoke-virtual {v0}, Lorg/spongycastle/crypto/tls/DTLSReassembler;->getBodyIfComplete()[B
move-result-object v1
.line 195
if-eqz v1, :cond_4c
.line 197
const/4 v2, 0x0
iput-object v2, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->previousInboundFlight:Ljava/util/Hashtable;
.line 198
new-instance v2, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;
iget v4, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->next_receive_seq:I
add-int/lit8 v5, v4, 0x1
iput v5, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->next_receive_seq:I
.line 199
invoke-virtual {v0}, Lorg/spongycastle/crypto/tls/DTLSReassembler;->getMsgType()S
move-result v0
const/4 v5, 0x0
invoke-direct {v2, v4, v0, v1, v5}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;-><init>(IS[BLorg/spongycastle/crypto/tls/DTLSReliableHandshake$1;)V
.line 198
invoke-direct {p0, v2}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->updateHandshakeMessagesDigest(Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;)Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;
:try_end_f6
.catch Ljava/io/IOException; {:try_start_b5 .. :try_end_f6} :catch_f9
move-result-object v0
goto/16 :goto_3b
:catch_f9
move-exception v0
.line 210
:cond_fa
:goto_fa
invoke-direct {p0}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->resendOutboundFlight()V
.line 216
shl-int/lit8 v0, v7, 0x1
invoke-static {v0, v12}, Ljava/lang/Math;->min(II)I
move-result v0
goto/16 :goto_3e
:catch_105
move-exception v1
move v7, v0
goto :goto_fa
:cond_108
move v7, v0
goto/16 :goto_4c
:cond_10b
move v0, v7
goto :goto_b3
.end method
.method receiveMessageBody(S)[B
.registers 4
.prologue
.line 73
invoke-virtual {p0}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->receiveMessage()Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;
move-result-object v0
.line 74
invoke-virtual {v0}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;->getType()S
move-result v1
if-eq v1, p1, :cond_12
.line 76
new-instance v0, Lorg/spongycastle/crypto/tls/TlsFatalAlert;
const/16 v1, 0xa
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/tls/TlsFatalAlert;-><init>(S)V
throw v0
.line 79
:cond_12
invoke-virtual {v0}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;->getBody()[B
move-result-object v0
return-object v0
.end method
.method resetHandshakeMessagesDigest()V
.registers 2
.prologue
.line 295
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->handshakeHash:Lorg/spongycastle/crypto/tls/TlsHandshakeHash;
invoke-interface {v0}, Lorg/spongycastle/crypto/tls/TlsHandshakeHash;->reset()V
.line 296
return-void
.end method
.method sendMessage(S[B)V
.registers 6
.prologue
.line 53
array-length v0, p2
invoke-static {v0}, Lorg/spongycastle/crypto/tls/TlsUtils;->checkUint24(I)V
.line 55
iget-boolean v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->sending:Z
if-nez v0, :cond_13
.line 57
invoke-direct {p0}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->checkInboundFlight()V
.line 58
const/4 v0, 0x1
iput-boolean v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->sending:Z
.line 59
iget-object v0, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->outboundFlight:Ljava/util/Vector;
invoke-virtual {v0}, Ljava/util/Vector;->removeAllElements()V
.line 62
:cond_13
new-instance v0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;
iget v1, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->message_seq:I
add-int/lit8 v2, v1, 0x1
iput v2, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->message_seq:I
const/4 v2, 0x0
invoke-direct {v0, v1, p1, p2, v2}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;-><init>(IS[BLorg/spongycastle/crypto/tls/DTLSReliableHandshake$1;)V
.line 64
iget-object v1, p0, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->outboundFlight:Ljava/util/Vector;
invoke-virtual {v1, v0}, Ljava/util/Vector;->addElement(Ljava/lang/Object;)V
.line 66
invoke-direct {p0, v0}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->writeMessage(Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;)V
.line 67
invoke-direct {p0, v0}, Lorg/spongycastle/crypto/tls/DTLSReliableHandshake;->updateHandshakeMessagesDigest(Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;)Lorg/spongycastle/crypto/tls/DTLSReliableHandshake$Message;
.line 68
return-void
.end method