PaymentChannelV1ClientState.smali

.class public Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;
.super Lorg/bitcoinj/protocols/channels/PaymentChannelClientState;
.source "PaymentChannelV1ClientState.java"


# static fields
.field private static final log:Lorg/slf4j/Logger;


# instance fields
.field private final expiryTime:J

.field private multisigContract:Lorg/bitcoinj/core/Transaction;

.field private multisigScript:Lorg/bitcoinj/script/Script;

.field private refundFees:Lorg/bitcoinj/core/Coin;

.field private refundTx:Lorg/bitcoinj/core/Transaction;

.field private final totalValue:Lorg/bitcoinj/core/Coin;


# direct methods
.method static constructor <clinit>()V
    .registers 1

    .prologue
    .line 44
    const-class v0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;

    invoke-static {v0}, Lorg/slf4j/LoggerFactory;->getLogger(Ljava/lang/Class;)Lorg/slf4j/Logger;

    move-result-object v0

    sput-object v0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->log:Lorg/slf4j/Logger;

    return-void
.end method

.method constructor <init>(Lorg/bitcoinj/protocols/channels/StoredClientChannel;Lorg/bitcoinj/wallet/Wallet;)V
    .registers 7

    .prologue
    const-wide/16 v2, 0x0

    .line 60
    invoke-direct {p0, p1, p2}, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState;-><init>(Lorg/bitcoinj/protocols/channels/StoredClientChannel;Lorg/bitcoinj/wallet/Wallet;)V

    .line 62
    iget-object v0, p1, Lorg/bitcoinj/protocols/channels/StoredClientChannel;->contract:Lorg/bitcoinj/core/Transaction;

    invoke-static {v0}, Lcom/google/common/base/n;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lorg/bitcoinj/core/Transaction;

    iput-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->multisigContract:Lorg/bitcoinj/core/Transaction;

    .line 63
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->multisigContract:Lorg/bitcoinj/core/Transaction;

    invoke-virtual {v0, v2, v3}, Lorg/bitcoinj/core/Transaction;->getOutput(J)Lorg/bitcoinj/core/TransactionOutput;

    move-result-object v0

    invoke-virtual {v0}, Lorg/bitcoinj/core/TransactionOutput;->getScriptPubKey()Lorg/bitcoinj/script/Script;

    move-result-object v0

    iput-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->multisigScript:Lorg/bitcoinj/script/Script;

    .line 64
    iget-object v0, p1, Lorg/bitcoinj/protocols/channels/StoredClientChannel;->refund:Lorg/bitcoinj/core/Transaction;

    invoke-static {v0}, Lcom/google/common/base/n;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lorg/bitcoinj/core/Transaction;

    iput-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundTx:Lorg/bitcoinj/core/Transaction;

    .line 65
    iget-object v0, p1, Lorg/bitcoinj/protocols/channels/StoredClientChannel;->refundFees:Lorg/bitcoinj/core/Coin;

    invoke-static {v0}, Lcom/google/common/base/n;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lorg/bitcoinj/core/Coin;

    iput-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundFees:Lorg/bitcoinj/core/Coin;

    .line 66
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundTx:Lorg/bitcoinj/core/Transaction;

    invoke-virtual {v0}, Lorg/bitcoinj/core/Transaction;->getLockTime()J

    move-result-wide v0

    iput-wide v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->expiryTime:J

    .line 67
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->multisigContract:Lorg/bitcoinj/core/Transaction;

    invoke-virtual {v0, v2, v3}, Lorg/bitcoinj/core/Transaction;->getOutput(J)Lorg/bitcoinj/core/TransactionOutput;

    move-result-object v0

    invoke-virtual {v0}, Lorg/bitcoinj/core/TransactionOutput;->getValue()Lorg/bitcoinj/core/Coin;

    move-result-object v0

    iput-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->totalValue:Lorg/bitcoinj/core/Coin;

    .line 68
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->stateMachine:Lorg/bitcoinj/protocols/channels/StateMachine;

    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->READY:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-virtual {v0, v1}, Lorg/bitcoinj/protocols/channels/StateMachine;->transition(Ljava/lang/Enum;)V

    .line 69
    invoke-virtual {p0}, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->initWalletListeners()V

    .line 70
    return-void
.end method

.method public constructor <init>(Lorg/bitcoinj/wallet/Wallet;Lorg/bitcoinj/core/ECKey;Lorg/bitcoinj/core/ECKey;Lorg/bitcoinj/core/Coin;J)V
    .registers 10

    .prologue
    .line 88
    invoke-direct/range {p0 .. p6}, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState;-><init>(Lorg/bitcoinj/wallet/Wallet;Lorg/bitcoinj/core/ECKey;Lorg/bitcoinj/core/ECKey;Lorg/bitcoinj/core/Coin;J)V

    .line 89
    invoke-virtual {p4}, Lorg/bitcoinj/core/Coin;->signum()I

    move-result v0

    if-lez v0, :cond_22

    const/4 v0, 0x1

    :goto_a
    invoke-static {v0}, Lcom/google/common/base/n;->checkArgument(Z)V

    .line 90
    invoke-virtual {p0}, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->initWalletListeners()V

    .line 91
    invoke-static {p4}, Lcom/google/common/base/n;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lorg/bitcoinj/core/Coin;

    iput-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->totalValue:Lorg/bitcoinj/core/Coin;

    .line 92
    iput-wide p5, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->expiryTime:J

    .line 93
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->stateMachine:Lorg/bitcoinj/protocols/channels/StateMachine;

    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->NEW:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-virtual {v0, v1}, Lorg/bitcoinj/protocols/channels/StateMachine;->transition(Ljava/lang/Enum;)V

    .line 94
    return-void

    .line 89
    :cond_22
    const/4 v0, 0x0

    goto :goto_a
.end method


# virtual methods
.method declared-synchronized doStoreChannelInWallet(Lorg/bitcoinj/core/Sha256Hash;)V
    .registers 15

    .prologue
    const/4 v1, 0x1

    .line 265
    monitor-enter p0

    :try_start_2
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->wallet:Lorg/bitcoinj/wallet/Wallet;

    .line 266
    invoke-virtual {v0}, Lorg/bitcoinj/wallet/Wallet;->getExtensions()Ljava/util/Map;

    move-result-object v0

    sget-object v2, Lorg/bitcoinj/protocols/channels/StoredPaymentChannelClientStates;->EXTENSION_ID:Ljava/lang/String;

    invoke-interface {v0, v2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lorg/bitcoinj/protocols/channels/StoredPaymentChannelClientStates;

    .line 267
    const-string v2, "You have not added the StoredPaymentChannelClientStates extension to the wallet."

    invoke-static {v0, v2}, Lcom/google/common/base/n;->checkNotNull(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 268
    iget-object v2, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->multisigContract:Lorg/bitcoinj/core/Transaction;

    invoke-virtual {v2}, Lorg/bitcoinj/core/Transaction;->getHash()Lorg/bitcoinj/core/Sha256Hash;

    move-result-object v2

    invoke-virtual {v0, p1, v2}, Lorg/bitcoinj/protocols/channels/StoredPaymentChannelClientStates;->getChannel(Lorg/bitcoinj/core/Sha256Hash;Lorg/bitcoinj/core/Sha256Hash;)Lorg/bitcoinj/protocols/channels/StoredClientChannel;

    move-result-object v2

    if-nez v2, :cond_46

    :goto_21
    invoke-static {v1}, Lcom/google/common/base/n;->checkState(Z)V

    .line 269
    new-instance v1, Lorg/bitcoinj/protocols/channels/StoredClientChannel;

    invoke-virtual {p0}, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->getMajorVersion()I

    move-result v2

    iget-object v4, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->multisigContract:Lorg/bitcoinj/core/Transaction;

    iget-object v5, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundTx:Lorg/bitcoinj/core/Transaction;

    iget-object v6, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->myKey:Lorg/bitcoinj/core/ECKey;

    iget-object v7, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->serverKey:Lorg/bitcoinj/core/ECKey;

    iget-object v8, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->valueToMe:Lorg/bitcoinj/core/Coin;

    iget-object v9, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundFees:Lorg/bitcoinj/core/Coin;

    const-wide/16 v10, 0x0

    const/4 v12, 0x1

    move-object v3, p1

    invoke-direct/range {v1 .. v12}, Lorg/bitcoinj/protocols/channels/StoredClientChannel;-><init>(ILorg/bitcoinj/core/Sha256Hash;Lorg/bitcoinj/core/Transaction;Lorg/bitcoinj/core/Transaction;Lorg/bitcoinj/core/ECKey;Lorg/bitcoinj/core/ECKey;Lorg/bitcoinj/core/Coin;Lorg/bitcoinj/core/Coin;JZ)V

    iput-object v1, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->storedChannel:Lorg/bitcoinj/protocols/channels/StoredClientChannel;

    .line 270
    iget-object v1, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->storedChannel:Lorg/bitcoinj/protocols/channels/StoredClientChannel;

    invoke-virtual {v0, v1}, Lorg/bitcoinj/protocols/channels/StoredPaymentChannelClientStates;->putChannel(Lorg/bitcoinj/protocols/channels/StoredClientChannel;)V
    :try_end_44
    .catchall {:try_start_2 .. :try_end_44} :catchall_48

    .line 271
    monitor-exit p0

    return-void

    .line 268
    :cond_46
    const/4 v1, 0x0

    goto :goto_21

    .line 265
    :catchall_48
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method public declared-synchronized getCompletedRefundTransaction()Lorg/bitcoinj/core/Transaction;
    .registers 3

    .prologue
    .line 289
    monitor-enter p0

    :try_start_1
    invoke-virtual {p0}, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->getState()Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    move-result-object v0

    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->WAITING_FOR_SIGNED_REFUND:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-virtual {v0, v1}, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->compareTo(Ljava/lang/Enum;)I

    move-result v0

    if-lez v0, :cond_15

    const/4 v0, 0x1

    :goto_e
    invoke-static {v0}, Lcom/google/common/base/n;->checkState(Z)V

    .line 290
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundTx:Lorg/bitcoinj/core/Transaction;
    :try_end_13
    .catchall {:try_start_1 .. :try_end_13} :catchall_17

    monitor-exit p0

    return-object v0

    .line 289
    :cond_15
    const/4 v0, 0x0

    goto :goto_e

    :catchall_17
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method public declared-synchronized getContract()Lorg/bitcoinj/core/Transaction;
    .registers 3

    .prologue
    .line 184
    monitor-enter p0

    :try_start_1
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->multisigContract:Lorg/bitcoinj/core/Transaction;

    if-eqz v0, :cond_1e

    const/4 v0, 0x1

    :goto_6
    invoke-static {v0}, Lcom/google/common/base/n;->checkState(Z)V

    .line 185
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->stateMachine:Lorg/bitcoinj/protocols/channels/StateMachine;

    invoke-virtual {v0}, Lorg/bitcoinj/protocols/channels/StateMachine;->getState()Ljava/lang/Enum;

    move-result-object v0

    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->PROVIDE_MULTISIG_CONTRACT_TO_SERVER:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    if-ne v0, v1, :cond_1a

    .line 186
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->stateMachine:Lorg/bitcoinj/protocols/channels/StateMachine;

    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->READY:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-virtual {v0, v1}, Lorg/bitcoinj/protocols/channels/StateMachine;->transition(Ljava/lang/Enum;)V

    .line 188
    :cond_1a
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->multisigContract:Lorg/bitcoinj/core/Transaction;
    :try_end_1c
    .catchall {:try_start_1 .. :try_end_1c} :catchall_20

    monitor-exit p0

    return-object v0

    .line 184
    :cond_1e
    const/4 v0, 0x0

    goto :goto_6

    :catchall_20
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method protected declared-synchronized getContractInternal()Lorg/bitcoinj/core/Transaction;
    .registers 2

    .prologue
    .line 193
    monitor-enter p0

    :try_start_1
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->multisigContract:Lorg/bitcoinj/core/Transaction;
    :try_end_3
    .catchall {:try_start_1 .. :try_end_3} :catchall_5

    monitor-exit p0

    return-object v0

    :catchall_5
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method protected declared-synchronized getContractScript()Lorg/bitcoinj/script/Script;
    .registers 2

    .prologue
    .line 197
    monitor-enter p0

    :try_start_1
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->multisigScript:Lorg/bitcoinj/script/Script;
    :try_end_3
    .catchall {:try_start_1 .. :try_end_3} :catchall_5

    monitor-exit p0

    return-object v0

    :catchall_5
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method protected getExpiryTime()J
    .registers 3

    .prologue
    .line 260
    iget-wide v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->expiryTime:J

    return-wide v0
.end method

.method public declared-synchronized getIncompleteRefundTransaction()Lorg/bitcoinj/core/Transaction;
    .registers 3

    .prologue
    .line 211
    monitor-enter p0

    :try_start_1
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundTx:Lorg/bitcoinj/core/Transaction;

    if-eqz v0, :cond_1e

    const/4 v0, 0x1

    :goto_6
    invoke-static {v0}, Lcom/google/common/base/n;->checkState(Z)V

    .line 212
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->stateMachine:Lorg/bitcoinj/protocols/channels/StateMachine;

    invoke-virtual {v0}, Lorg/bitcoinj/protocols/channels/StateMachine;->getState()Ljava/lang/Enum;

    move-result-object v0

    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->INITIATED:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    if-ne v0, v1, :cond_1a

    .line 213
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->stateMachine:Lorg/bitcoinj/protocols/channels/StateMachine;

    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->WAITING_FOR_SIGNED_REFUND:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-virtual {v0, v1}, Lorg/bitcoinj/protocols/channels/StateMachine;->transition(Ljava/lang/Enum;)V

    .line 215
    :cond_1a
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundTx:Lorg/bitcoinj/core/Transaction;
    :try_end_1c
    .catchall {:try_start_1 .. :try_end_1c} :catchall_20

    monitor-exit p0

    return-object v0

    .line 211
    :cond_1e
    const/4 v0, 0x0

    goto :goto_6

    :catchall_20
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method public getMajorVersion()I
    .registers 2

    .prologue
    .line 112
    const/4 v0, 0x1

    return v0
.end method

.method getRefundTransaction()Lorg/bitcoinj/core/Transaction;
    .registers 2

    .prologue
    .line 280
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundTx:Lorg/bitcoinj/core/Transaction;

    return-object v0
.end method

.method public declared-synchronized getRefundTxFees()Lorg/bitcoinj/core/Coin;
    .registers 3

    .prologue
    .line 275
    monitor-enter p0

    :try_start_1
    invoke-virtual {p0}, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->getState()Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    move-result-object v0

    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->NEW:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-virtual {v0, v1}, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->compareTo(Ljava/lang/Enum;)I

    move-result v0

    if-lez v0, :cond_15

    const/4 v0, 0x1

    :goto_e
    invoke-static {v0}, Lcom/google/common/base/n;->checkState(Z)V

    .line 276
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundFees:Lorg/bitcoinj/core/Coin;
    :try_end_13
    .catchall {:try_start_1 .. :try_end_13} :catchall_17

    monitor-exit p0

    return-object v0

    .line 275
    :cond_15
    const/4 v0, 0x0

    goto :goto_e

    :catchall_17
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method protected getSignedScript()Lorg/bitcoinj/script/Script;
    .registers 2

    .prologue
    .line 202
    invoke-virtual {p0}, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->getContractScript()Lorg/bitcoinj/script/Script;

    move-result-object v0

    return-object v0
.end method

.method protected getStateTransitions()Lcom/google/common/collect/cf;
    .registers 4
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "()",
            "Lcom/google/common/collect/cf",
            "<",
            "Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;",
            "Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;",
            ">;"
        }
    .end annotation

    .prologue
    .line 98
    const-class v0, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-static {v0}, Lcom/google/common/collect/MultimapBuilder;->k(Ljava/lang/Class;)Lcom/google/common/collect/ch;

    move-result-object v0

    invoke-virtual {v0}, Lcom/google/common/collect/ch;->xG()Lcom/google/common/collect/cg;

    move-result-object v0

    invoke-virtual {v0}, Lcom/google/common/collect/cg;->xF()Lcom/google/common/collect/bb;

    move-result-object v0

    .line 99
    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->UNINITIALISED:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    sget-object v2, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->NEW:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-interface {v0, v1, v2}, Lcom/google/common/collect/cf;->put(Ljava/lang/Object;Ljava/lang/Object;)Z

    .line 100
    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->UNINITIALISED:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    sget-object v2, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->READY:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-interface {v0, v1, v2}, Lcom/google/common/collect/cf;->put(Ljava/lang/Object;Ljava/lang/Object;)Z

    .line 101
    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->NEW:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    sget-object v2, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->INITIATED:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-interface {v0, v1, v2}, Lcom/google/common/collect/cf;->put(Ljava/lang/Object;Ljava/lang/Object;)Z

    .line 102
    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->INITIATED:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    sget-object v2, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->WAITING_FOR_SIGNED_REFUND:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-interface {v0, v1, v2}, Lcom/google/common/collect/cf;->put(Ljava/lang/Object;Ljava/lang/Object;)Z

    .line 103
    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->WAITING_FOR_SIGNED_REFUND:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    sget-object v2, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->SAVE_STATE_IN_WALLET:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-interface {v0, v1, v2}, Lcom/google/common/collect/cf;->put(Ljava/lang/Object;Ljava/lang/Object;)Z

    .line 104
    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->SAVE_STATE_IN_WALLET:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    sget-object v2, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->PROVIDE_MULTISIG_CONTRACT_TO_SERVER:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-interface {v0, v1, v2}, Lcom/google/common/collect/cf;->put(Ljava/lang/Object;Ljava/lang/Object;)Z

    .line 105
    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->PROVIDE_MULTISIG_CONTRACT_TO_SERVER:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    sget-object v2, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->READY:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-interface {v0, v1, v2}, Lcom/google/common/collect/cf;->put(Ljava/lang/Object;Ljava/lang/Object;)Z

    .line 106
    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->READY:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    sget-object v2, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->EXPIRED:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-interface {v0, v1, v2}, Lcom/google/common/collect/cf;->put(Ljava/lang/Object;Ljava/lang/Object;)Z

    .line 107
    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->READY:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    sget-object v2, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->CLOSED:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-interface {v0, v1, v2}, Lcom/google/common/collect/cf;->put(Ljava/lang/Object;Ljava/lang/Object;)Z

    .line 108
    return-object v0
.end method

.method public getTotalValue()Lorg/bitcoinj/core/Coin;
    .registers 2

    .prologue
    .line 298
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->totalValue:Lorg/bitcoinj/core/Coin;

    return-object v0
.end method

.method protected declared-synchronized getValueToMe()Lorg/bitcoinj/core/Coin;
    .registers 2

    .prologue
    .line 256
    monitor-enter p0

    :try_start_1
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->valueToMe:Lorg/bitcoinj/core/Coin;
    :try_end_3
    .catchall {:try_start_1 .. :try_end_3} :catchall_5

    monitor-exit p0

    return-object v0

    :catchall_5
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method public declared-synchronized initiate(Lorg/spongycastle/crypto/params/KeyParameter;)V
    .registers 8

    .prologue
    .line 129
    monitor-enter p0

    :try_start_1
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->wallet:Lorg/bitcoinj/wallet/Wallet;

    invoke-virtual {v0}, Lorg/bitcoinj/wallet/Wallet;->getParams()Lorg/bitcoinj/core/NetworkParameters;

    move-result-object v0

    .line 130
    new-instance v1, Lorg/bitcoinj/core/Transaction;

    invoke-direct {v1, v0}, Lorg/bitcoinj/core/Transaction;-><init>(Lorg/bitcoinj/core/NetworkParameters;)V

    .line 133
    const/4 v2, 0x2

    new-array v2, v2, [Lorg/bitcoinj/core/ECKey;

    const/4 v3, 0x0

    iget-object v4, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->myKey:Lorg/bitcoinj/core/ECKey;

    aput-object v4, v2, v3

    const/4 v3, 0x1

    iget-object v4, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->serverKey:Lorg/bitcoinj/core/ECKey;

    aput-object v4, v2, v3

    invoke-static {v2}, Lcom/google/common/collect/Lists;->newArrayList([Ljava/lang/Object;)Ljava/util/ArrayList;

    move-result-object v2

    .line 137
    iget-object v3, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->totalValue:Lorg/bitcoinj/core/Coin;

    const/4 v4, 0x2

    invoke-static {v4, v2}, Lorg/bitcoinj/script/ScriptBuilder;->createMultiSigOutputScript(ILjava/util/List;)Lorg/bitcoinj/script/Script;

    move-result-object v2

    invoke-virtual {v1, v3, v2}, Lorg/bitcoinj/core/Transaction;->addOutput(Lorg/bitcoinj/core/Coin;Lorg/bitcoinj/script/Script;)Lorg/bitcoinj/core/TransactionOutput;

    move-result-object v2

    .line 138
    invoke-virtual {v2}, Lorg/bitcoinj/core/TransactionOutput;->isDust()Z

    move-result v3

    if-eqz v3, :cond_39

    .line 139
    new-instance v0, Lorg/bitcoinj/protocols/channels/ValueOutOfRangeException;

    const-string v1, "totalValue too small to use"

    invoke-direct {v0, v1}, Lorg/bitcoinj/protocols/channels/ValueOutOfRangeException;-><init>(Ljava/lang/String;)V

    throw v0
    :try_end_36
    .catchall {:try_start_1 .. :try_end_36} :catchall_36

    .line 129
    :catchall_36
    move-exception v0

    monitor-exit p0

    throw v0

    .line 140
    :cond_39
    :try_start_39
    invoke-static {v1}, Lorg/bitcoinj/wallet/SendRequest;->forTx(Lorg/bitcoinj/core/Transaction;)Lorg/bitcoinj/wallet/SendRequest;

    move-result-object v1

    .line 141
    invoke-static {}, Lorg/bitcoinj/wallet/AllowUnconfirmedCoinSelector;->get()Lorg/bitcoinj/wallet/AllowUnconfirmedCoinSelector;

    move-result-object v3

    iput-object v3, v1, Lorg/bitcoinj/wallet/SendRequest;->coinSelector:Lorg/bitcoinj/wallet/CoinSelector;

    .line 142
    invoke-virtual {p0, v1}, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->editContractSendRequest(Lorg/bitcoinj/wallet/SendRequest;)V

    .line 143
    const/4 v3, 0x0

    iput-boolean v3, v1, Lorg/bitcoinj/wallet/SendRequest;->shuffleOutputs:Z

    .line 144
    iput-object p1, v1, Lorg/bitcoinj/wallet/SendRequest;->aesKey:Lorg/spongycastle/crypto/params/KeyParameter;

    .line 145
    iget-object v3, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->wallet:Lorg/bitcoinj/wallet/Wallet;

    invoke-virtual {v3, v1}, Lorg/bitcoinj/wallet/Wallet;->completeTx(Lorg/bitcoinj/wallet/SendRequest;)V

    .line 146
    iget-object v3, v1, Lorg/bitcoinj/wallet/SendRequest;->tx:Lorg/bitcoinj/core/Transaction;

    invoke-virtual {v3}, Lorg/bitcoinj/core/Transaction;->getFee()Lorg/bitcoinj/core/Coin;

    move-result-object v3

    .line 147
    iget-object v1, v1, Lorg/bitcoinj/wallet/SendRequest;->tx:Lorg/bitcoinj/core/Transaction;

    iput-object v1, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->multisigContract:Lorg/bitcoinj/core/Transaction;

    .line 154
    new-instance v1, Lorg/bitcoinj/core/Transaction;

    invoke-direct {v1, v0}, Lorg/bitcoinj/core/Transaction;-><init>(Lorg/bitcoinj/core/NetworkParameters;)V

    iput-object v1, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundTx:Lorg/bitcoinj/core/Transaction;

    .line 157
    iget-object v1, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundTx:Lorg/bitcoinj/core/Transaction;

    invoke-virtual {v1, v2}, Lorg/bitcoinj/core/Transaction;->addInput(Lorg/bitcoinj/core/TransactionOutput;)Lorg/bitcoinj/core/TransactionInput;

    move-result-object v1

    const-wide v4, 0xfffffffeL

    invoke-virtual {v1, v4, v5}, Lorg/bitcoinj/core/TransactionInput;->setSequenceNumber(J)V

    .line 158
    iget-object v1, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundTx:Lorg/bitcoinj/core/Transaction;

    iget-wide v4, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->expiryTime:J

    invoke-virtual {v1, v4, v5}, Lorg/bitcoinj/core/Transaction;->setLockTime(J)V

    .line 159
    invoke-static {}, Lorg/bitcoinj/core/Context;->get()Lorg/bitcoinj/core/Context;

    move-result-object v1

    invoke-virtual {v1}, Lorg/bitcoinj/core/Context;->isEnsureMinRequiredFee()Z

    move-result v1

    if-eqz v1, :cond_d2

    .line 161
    iget-object v1, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->totalValue:Lorg/bitcoinj/core/Coin;

    sget-object v2, Lorg/bitcoinj/core/Transaction;->REFERENCE_DEFAULT_MIN_TX_FEE:Lorg/bitcoinj/core/Coin;

    invoke-virtual {v1, v2}, Lorg/bitcoinj/core/Coin;->subtract(Lorg/bitcoinj/core/Coin;)Lorg/bitcoinj/core/Coin;

    move-result-object v1

    .line 162
    sget-object v2, Lorg/bitcoinj/core/Transaction;->MIN_NONDUST_OUTPUT:Lorg/bitcoinj/core/Coin;

    invoke-virtual {v2, v1}, Lorg/bitcoinj/core/Coin;->compareTo(Lorg/bitcoinj/core/Coin;)I

    move-result v2

    if-lez v2, :cond_98

    .line 163
    new-instance v0, Lorg/bitcoinj/protocols/channels/ValueOutOfRangeException;

    const-string v1, "totalValue too small to use"

    invoke-direct {v0, v1}, Lorg/bitcoinj/protocols/channels/ValueOutOfRangeException;-><init>(Ljava/lang/String;)V

    throw v0

    .line 164
    :cond_98
    iget-object v2, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundTx:Lorg/bitcoinj/core/Transaction;

    iget-object v4, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->myKey:Lorg/bitcoinj/core/ECKey;

    invoke-virtual {v4, v0}, Lorg/bitcoinj/core/ECKey;->toAddress(Lorg/bitcoinj/core/NetworkParameters;)Lorg/bitcoinj/core/Address;

    move-result-object v0

    invoke-virtual {v2, v1, v0}, Lorg/bitcoinj/core/Transaction;->addOutput(Lorg/bitcoinj/core/Coin;Lorg/bitcoinj/core/Address;)Lorg/bitcoinj/core/TransactionOutput;

    .line 165
    sget-object v0, Lorg/bitcoinj/core/Transaction;->REFERENCE_DEFAULT_MIN_TX_FEE:Lorg/bitcoinj/core/Coin;

    invoke-virtual {v3, v0}, Lorg/bitcoinj/core/Coin;->add(Lorg/bitcoinj/core/Coin;)Lorg/bitcoinj/core/Coin;

    move-result-object v0

    iput-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundFees:Lorg/bitcoinj/core/Coin;

    .line 170
    :goto_ab
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundTx:Lorg/bitcoinj/core/Transaction;

    invoke-virtual {v0}, Lorg/bitcoinj/core/Transaction;->getConfidence()Lorg/bitcoinj/core/TransactionConfidence;

    move-result-object v0

    sget-object v1, Lorg/bitcoinj/core/TransactionConfidence$Source;->SELF:Lorg/bitcoinj/core/TransactionConfidence$Source;

    invoke-virtual {v0, v1}, Lorg/bitcoinj/core/TransactionConfidence;->setSource(Lorg/bitcoinj/core/TransactionConfidence$Source;)V

    .line 171
    sget-object v0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->log:Lorg/slf4j/Logger;

    const-string v1, "initiated channel with multi-sig contract {}, refund {}"

    iget-object v2, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->multisigContract:Lorg/bitcoinj/core/Transaction;

    invoke-virtual {v2}, Lorg/bitcoinj/core/Transaction;->getHashAsString()Ljava/lang/String;

    move-result-object v2

    iget-object v3, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundTx:Lorg/bitcoinj/core/Transaction;

    .line 172
    invoke-virtual {v3}, Lorg/bitcoinj/core/Transaction;->getHashAsString()Ljava/lang/String;

    move-result-object v3

    .line 171
    invoke-interface {v0, v1, v2, v3}, Lorg/slf4j/Logger;->info(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V

    .line 173
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->stateMachine:Lorg/bitcoinj/protocols/channels/StateMachine;

    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->INITIATED:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-virtual {v0, v1}, Lorg/bitcoinj/protocols/channels/StateMachine;->transition(Ljava/lang/Enum;)V
    :try_end_d0
    .catchall {:try_start_39 .. :try_end_d0} :catchall_36

    .line 175
    monitor-exit p0

    return-void

    .line 167
    :cond_d2
    :try_start_d2
    iget-object v1, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundTx:Lorg/bitcoinj/core/Transaction;

    iget-object v2, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->totalValue:Lorg/bitcoinj/core/Coin;

    iget-object v4, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->myKey:Lorg/bitcoinj/core/ECKey;

    invoke-virtual {v4, v0}, Lorg/bitcoinj/core/ECKey;->toAddress(Lorg/bitcoinj/core/NetworkParameters;)Lorg/bitcoinj/core/Address;

    move-result-object v0

    invoke-virtual {v1, v2, v0}, Lorg/bitcoinj/core/Transaction;->addOutput(Lorg/bitcoinj/core/Coin;Lorg/bitcoinj/core/Address;)Lorg/bitcoinj/core/TransactionOutput;

    .line 168
    iput-object v3, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundFees:Lorg/bitcoinj/core/Coin;
    :try_end_e1
    .catchall {:try_start_d2 .. :try_end_e1} :catchall_36

    goto :goto_ab
.end method

.method public declared-synchronized provideRefundSignature([BLorg/spongycastle/crypto/params/KeyParameter;)V
    .registers 11

    .prologue
    .line 229
    monitor-enter p0

    :try_start_1
    invoke-static {p1}, Lcom/google/common/base/n;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;

    .line 230
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->stateMachine:Lorg/bitcoinj/protocols/channels/StateMachine;

    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->WAITING_FOR_SIGNED_REFUND:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-virtual {v0, v1}, Lorg/bitcoinj/protocols/channels/StateMachine;->checkState(Ljava/lang/Enum;)V

    .line 231
    const/4 v0, 0x1

    invoke-static {p1, v0}, Lorg/bitcoinj/crypto/TransactionSignature;->decodeFromBitcoin([BZ)Lorg/bitcoinj/crypto/TransactionSignature;

    move-result-object v6

    .line 232
    invoke-virtual {v6}, Lorg/bitcoinj/crypto/TransactionSignature;->sigHashMode()Lorg/bitcoinj/core/Transaction$SigHash;

    move-result-object v0

    sget-object v1, Lorg/bitcoinj/core/Transaction$SigHash;->NONE:Lorg/bitcoinj/core/Transaction$SigHash;

    if-ne v0, v1, :cond_1e

    invoke-virtual {v6}, Lorg/bitcoinj/crypto/TransactionSignature;->anyoneCanPay()Z

    move-result v0

    if-nez v0, :cond_29

    .line 233
    :cond_1e
    new-instance v0, Lorg/bitcoinj/core/VerificationException;

    const-string v1, "Refund signature was not SIGHASH_NONE|SIGHASH_ANYONECANPAY"

    invoke-direct {v0, v1}, Lorg/bitcoinj/core/VerificationException;-><init>(Ljava/lang/String;)V

    throw v0
    :try_end_26
    .catchall {:try_start_1 .. :try_end_26} :catchall_26

    .line 229
    :catchall_26
    move-exception v0

    monitor-exit p0

    throw v0

    .line 235
    :cond_29
    :try_start_29
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->multisigContract:Lorg/bitcoinj/core/Transaction;

    const-wide/16 v2, 0x0

    invoke-virtual {v0, v2, v3}, Lorg/bitcoinj/core/Transaction;->getOutput(J)Lorg/bitcoinj/core/TransactionOutput;
    :try_end_30
    .catchall {:try_start_29 .. :try_end_30} :catchall_26

    move-result-object v7

    .line 237
    :try_start_31
    invoke-virtual {v7}, Lorg/bitcoinj/core/TransactionOutput;->getScriptPubKey()Lorg/bitcoinj/script/Script;

    move-result-object v0

    iput-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->multisigScript:Lorg/bitcoinj/script/Script;
    :try_end_37
    .catch Lorg/bitcoinj/core/ScriptException; {:try_start_31 .. :try_end_37} :catch_7d
    .catchall {:try_start_31 .. :try_end_37} :catchall_26

    .line 241
    :try_start_37
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundTx:Lorg/bitcoinj/core/Transaction;

    const/4 v1, 0x0

    iget-object v2, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->myKey:Lorg/bitcoinj/core/ECKey;

    .line 242
    invoke-virtual {v2, p2}, Lorg/bitcoinj/core/ECKey;->maybeDecrypt(Lorg/spongycastle/crypto/params/KeyParameter;)Lorg/bitcoinj/core/ECKey;

    move-result-object v2

    iget-object v3, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->multisigScript:Lorg/bitcoinj/script/Script;

    sget-object v4, Lorg/bitcoinj/core/Transaction$SigHash;->ALL:Lorg/bitcoinj/core/Transaction$SigHash;

    const/4 v5, 0x0

    invoke-virtual/range {v0 .. v5}, Lorg/bitcoinj/core/Transaction;->calculateSignature(ILorg/bitcoinj/core/ECKey;Lorg/bitcoinj/script/Script;Lorg/bitcoinj/core/Transaction$SigHash;Z)Lorg/bitcoinj/crypto/TransactionSignature;

    move-result-object v0

    .line 245
    const/4 v1, 0x2

    new-array v1, v1, [Lorg/bitcoinj/crypto/TransactionSignature;

    const/4 v2, 0x0

    aput-object v0, v1, v2

    const/4 v0, 0x1

    aput-object v6, v1, v0

    invoke-static {v1}, Lorg/bitcoinj/script/ScriptBuilder;->createMultiSigInputScript([Lorg/bitcoinj/crypto/TransactionSignature;)Lorg/bitcoinj/script/Script;

    move-result-object v0

    .line 246
    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->log:Lorg/slf4j/Logger;

    const-string v2, "Refund scriptSig: {}"

    invoke-interface {v1, v2, v0}, Lorg/slf4j/Logger;->info(Ljava/lang/String;Ljava/lang/Object;)V

    .line 247
    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->log:Lorg/slf4j/Logger;

    const-string v2, "Multi-sig contract scriptPubKey: {}"

    iget-object v3, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->multisigScript:Lorg/bitcoinj/script/Script;

    invoke-interface {v1, v2, v3}, Lorg/slf4j/Logger;->info(Ljava/lang/String;Ljava/lang/Object;)V

    .line 248
    iget-object v1, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->refundTx:Lorg/bitcoinj/core/Transaction;

    const-wide/16 v2, 0x0

    invoke-virtual {v1, v2, v3}, Lorg/bitcoinj/core/Transaction;->getInput(J)Lorg/bitcoinj/core/TransactionInput;

    move-result-object v1

    .line 249
    invoke-virtual {v1, v0}, Lorg/bitcoinj/core/TransactionInput;->setScriptSig(Lorg/bitcoinj/script/Script;)V

    .line 250
    invoke-virtual {v1, v7}, Lorg/bitcoinj/core/TransactionInput;->verify(Lorg/bitcoinj/core/TransactionOutput;)V

    .line 251
    iget-object v0, p0, Lorg/bitcoinj/protocols/channels/PaymentChannelV1ClientState;->stateMachine:Lorg/bitcoinj/protocols/channels/StateMachine;

    sget-object v1, Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;->SAVE_STATE_IN_WALLET:Lorg/bitcoinj/protocols/channels/PaymentChannelClientState$State;

    invoke-virtual {v0, v1}, Lorg/bitcoinj/protocols/channels/StateMachine;->transition(Ljava/lang/Enum;)V
    :try_end_7b
    .catchall {:try_start_37 .. :try_end_7b} :catchall_26

    .line 252
    monitor-exit p0

    return-void

    .line 238
    :catch_7d
    move-exception v0

    .line 239
    :try_start_7e
    new-instance v1, Ljava/lang/RuntimeException;

    invoke-direct {v1, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/Throwable;)V

    throw v1
    :try_end_84
    .catchall {:try_start_7e .. :try_end_84} :catchall_26
.end method