Skip to content

Commit

Permalink
Fixes 127: duplicated outputs
Browse files Browse the repository at this point in the history
  • Loading branch information
dr-orlovsky committed Feb 10, 2021
1 parent 4cf7277 commit cb0f26b
Showing 1 changed file with 13 additions and 18 deletions.
31 changes: 13 additions & 18 deletions src/stash/anchor.rs
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ use lnpbp::client_side_validation::{
use lnpbp::commit_verify::{CommitVerify, EmbedCommitVerify, TryCommitVerify};
use lnpbp::dbc::{
self, Container, Proof, ScriptEncodeData, ScriptEncodeMethod, SpkContainer,
TxCommitment, TxContainer, TxSupplement, TxoutContainer,
TxCommitment, TxContainer, TxSupplement, TxoutCommitment, TxoutContainer,
};
use lnpbp::lnpbp4::{MessageMap, MultimsgCommitment, TooManyMessagesError};
use lnpbp::strict_encoding::{strategies, Strategy};
Expand Down Expand Up @@ -153,7 +153,7 @@ impl Anchor {
|mut data, (contract_id, node_id)| {
let id = Uint256::from_be_bytes(*contract_id.as_slice());
let vout = id % Uint256::from_u64(num_outs).unwrap();
let vout = vout.low_u64() as usize;
let vout = vout.low_u64() as usize + fee as usize;
data.entry(vout).or_insert(BTreeMap::default()).insert(
*contract_id.as_slice(),
sha256d::Hash::from_inner(*node_id.as_slice()),
Expand Down Expand Up @@ -208,19 +208,13 @@ impl Anchor {
ScriptEncodeMethod::WPubkeyHash
};

let mut container = TxContainer {
tx: tx.clone(),
fee,
protocol_factor: vout as u32,
txout_container: TxoutContainer {
value: tx_out.value,
script_container: SpkContainer {
pubkey,
method,
source,
tag: *LNPBP4_TAG,
tweaking_factor: None,
},
let mut container = TxoutContainer {
value: tx_out.value,
script_container: SpkContainer {
pubkey,
method,
source,
tag: *LNPBP4_TAG,
tweaking_factor: None,
},
tweaking_factor: None,
Expand All @@ -235,11 +229,12 @@ impl Anchor {
.collect();
let mm_digest = sha256::Hash::commit(&mm_buffer);
let commitment =
TxCommitment::embed_commit(&mut container, &mm_digest).unwrap();
TxoutCommitment::embed_commit(&mut container, &mm_digest)
.unwrap();

*tx = commitment.into_inner().clone();
*(&mut tx.output[vout]) = commitment.into_inner().clone();
psbt.outputs
.get_mut(container.vout())
.get_mut(vout)
.map(|output| {
output.proprietary.insert(
ProprietaryKey {
Expand Down

0 comments on commit cb0f26b

Please sign in to comment.