module Data.Bitcoin.PaymentChannel.Internal.Refund where
import Data.Bitcoin.PaymentChannel.Internal.Types
import Data.Bitcoin.PaymentChannel.Internal.State
import Data.Bitcoin.PaymentChannel.Internal.Script
import Data.Bitcoin.PaymentChannel.Internal.Payment
import Data.Bitcoin.PaymentChannel.Internal.Util
import qualified Network.Haskoin.Transaction as HT
import qualified Network.Haskoin.Crypto as HC
import qualified Network.Haskoin.Script as HS
getUnsignedRefundTx :: PaymentChannelState -> BitcoinAmount -> HT.Tx
getUnsignedRefundTx st txFee =
let
(baseTx,_) = getPaymentTxForSigning st 0
refundOut = HT.TxOut
(fromIntegral . toInteger $ pcsChannelTotalValue st - txFee)
(pcsClientChangeScriptPubKey st)
txInput0 = head $ HT.txIn baseTx
in
baseTx {
HT.txOut = [refundOut],
HT.txLockTime = toWord32 (pcsLockTime st),
HT.txIn = [ txInput0 { HT.txInSequence = maxBound-1 } ]
}
getRefundTxHashForSigning ::
PaymentChannelState
-> BitcoinAmount
-> HC.Hash256
getRefundTxHashForSigning pcs@(CPaymentChannelState cp _ _ _ _) newValueLeft =
HS.txSigHash tx (getRedeemScript cp) 0 (HS.SigAll False)
where tx = getUnsignedRefundTx pcs newValueLeft
refundTxAddSignature ::
PaymentChannelState
-> BitcoinAmount
-> HC.Signature
-> FinalTx
refundTxAddSignature pcs@(CPaymentChannelState cp _ _ _ _) txFee clientRawSig =
let
inputScript = getInputScript cp $ refundTxScriptSig clientRawSig
in
replaceScriptInput (serialize inputScript) $ getUnsignedRefundTx pcs txFee