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