Browse Source

Use dummy multisig for creating lock psbt

bdk-0.11
Philipp Hoenisch 3 years ago
parent
commit
f830a9f521
No known key found for this signature in database GPG Key ID: E5F8E74C672BC666
  1. 25
      cfd_protocol/src/lib.rs

25
cfd_protocol/src/lib.rs

@ -1,8 +1,6 @@
use anyhow::{bail, Context, Result}; use anyhow::{bail, Context, Result};
use bdk::bitcoin::hashes::*;
use bdk::bitcoin::Script;
use bdk::bitcoin::hashes::hex::ToHex; use bdk::bitcoin::hashes::hex::ToHex;
use bdk::bitcoin::hashes::*;
use bdk::bitcoin::util::bip143::SigHashCache; use bdk::bitcoin::util::bip143::SigHashCache;
use bdk::bitcoin::util::psbt::{Global, PartiallySignedTransaction}; use bdk::bitcoin::util::psbt::{Global, PartiallySignedTransaction};
use bdk::bitcoin::{ use bdk::bitcoin::{
@ -23,6 +21,10 @@ use std::collections::HashMap;
/// In satoshi per vbyte. /// In satoshi per vbyte.
const SATS_PER_VBYTE: f64 = 1.0; const SATS_PER_VBYTE: f64 = 1.0;
/// Static script to be used to create lock tx
const DUMMY_2OF2_MULITISIG: &str =
"0020b5aa99ed7e0fa92483eb045ab8b7a59146d4d9f6653f21ba729b4331895a5b46";
pub trait WalletExt { pub trait WalletExt {
fn build_party_params(&self, amount: Amount, identity_pk: PublicKey) -> Result<PartyParams>; fn build_party_params(&self, amount: Amount, identity_pk: PublicKey) -> Result<PartyParams>;
} }
@ -36,7 +38,12 @@ where
builder builder
.ordering(bdk::wallet::tx_builder::TxOrdering::Bip69Lexicographic) .ordering(bdk::wallet::tx_builder::TxOrdering::Bip69Lexicographic)
.fee_rate(FeeRate::from_sat_per_vb(1.0)) .fee_rate(FeeRate::from_sat_per_vb(1.0))
.add_recipient(Script::new(), amount.as_sat()); .add_recipient(
DUMMY_2OF2_MULITISIG
.parse()
.expect("Should be valid script"),
amount.as_sat(),
);
let (lock_psbt, _) = builder.finish()?; let (lock_psbt, _) = builder.finish()?;
let address = self.get_address(AddressIndex::New)?.address; let address = self.get_address(AddressIndex::New)?.address;
Ok(PartyParams { Ok(PartyParams {
@ -786,7 +793,9 @@ impl LockTransaction {
.unsigned_tx .unsigned_tx
.output .output
.into_iter() .into_iter()
.filter(|out| !out.script_pubkey.is_empty()) .filter(|out| {
out.script_pubkey != DUMMY_2OF2_MULITISIG.parse().expect("To be a valid script")
})
.collect::<Vec<_>>(); .collect::<Vec<_>>();
let taker_change = taker_psbt let taker_change = taker_psbt
@ -794,7 +803,9 @@ impl LockTransaction {
.unsigned_tx .unsigned_tx
.output .output
.into_iter() .into_iter()
.filter(|out| !out.script_pubkey.is_empty()) .filter(|out| {
out.script_pubkey != DUMMY_2OF2_MULITISIG.parse().expect("To be a valid script")
})
.collect(); .collect();
let lock_output = TxOut { let lock_output = TxOut {
@ -1323,7 +1334,7 @@ mod tests {
let fee = input_amount - output_amount; let fee = input_amount - output_amount;
let min_relay_fee = spend_tx.get_virtual_size(); let min_relay_fee = spend_tx.get_virtual_size();
if (dbg!(fee) as f64) < dbg!(min_relay_fee) { if (fee as f64) < min_relay_fee {
bail!("min relay fee not met, {} < {}", fee, min_relay_fee) bail!("min relay fee not met, {} < {}", fee, min_relay_fee)
} }

Loading…
Cancel
Save