mirror of
https://github.com/lightningdevkit/rust-lightning.git
synced 2025-01-18 21:34:48 +01:00
Merge pull request #1658 from lightning-signer/2022-08-bitcoin-0-29
Update bitcoin crate to 0.29.0
This commit is contained in:
commit
b414c0641b
@ -20,7 +20,7 @@ stdin_fuzz = []
|
||||
afl = { version = "0.4", optional = true }
|
||||
lightning = { path = "../lightning", features = ["regex"] }
|
||||
lightning-rapid-gossip-sync = { path = "../lightning-rapid-gossip-sync" }
|
||||
bitcoin = { version = "0.28.1", features = ["secp-lowmemory"] }
|
||||
bitcoin = { version = "0.29.0", features = ["secp-lowmemory"] }
|
||||
hex = "0.3"
|
||||
honggfuzz = { version = "0.5", optional = true }
|
||||
libfuzzer-sys = { version = "0.4", optional = true }
|
||||
|
@ -18,11 +18,13 @@
|
||||
//! send-side handling is correct, other peers. We consider it a failure if any action results in a
|
||||
//! channel being force-closed.
|
||||
|
||||
use bitcoin::TxMerkleNode;
|
||||
use bitcoin::blockdata::block::BlockHeader;
|
||||
use bitcoin::blockdata::constants::genesis_block;
|
||||
use bitcoin::blockdata::transaction::{Transaction, TxOut};
|
||||
use bitcoin::blockdata::script::{Builder, Script};
|
||||
use bitcoin::blockdata::opcodes;
|
||||
use bitcoin::blockdata::locktime::PackedLockTime;
|
||||
use bitcoin::network::constants::Network;
|
||||
|
||||
use bitcoin::hashes::Hash as TraitImport;
|
||||
@ -53,7 +55,7 @@ use lightning::routing::router::{Route, RouteHop};
|
||||
use utils::test_logger::{self, Output};
|
||||
use utils::test_persister::TestPersister;
|
||||
|
||||
use bitcoin::secp256k1::{PublicKey,SecretKey};
|
||||
use bitcoin::secp256k1::{PublicKey, SecretKey, Scalar};
|
||||
use bitcoin::secp256k1::ecdh::SharedSecret;
|
||||
use bitcoin::secp256k1::ecdsa::RecoverableSignature;
|
||||
use bitcoin::secp256k1::Secp256k1;
|
||||
@ -166,10 +168,10 @@ impl KeysInterface for KeyProvider {
|
||||
Ok(SecretKey::from_slice(&[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, self.node_id]).unwrap())
|
||||
}
|
||||
|
||||
fn ecdh(&self, recipient: Recipient, other_key: &PublicKey, tweak: Option<&[u8; 32]>) -> Result<SharedSecret, ()> {
|
||||
fn ecdh(&self, recipient: Recipient, other_key: &PublicKey, tweak: Option<&Scalar>) -> Result<SharedSecret, ()> {
|
||||
let mut node_secret = self.get_node_secret(recipient)?;
|
||||
if let Some(tweak) = tweak {
|
||||
node_secret.mul_assign(tweak).map_err(|_| ())?;
|
||||
node_secret = node_secret.mul_tweak(tweak).unwrap();
|
||||
}
|
||||
Ok(SharedSecret::new(other_key, &node_secret))
|
||||
}
|
||||
@ -447,7 +449,7 @@ pub fn do_test<Out: Output>(data: &[u8], underlying_out: Out) {
|
||||
let events = $source.get_and_clear_pending_events();
|
||||
assert_eq!(events.len(), 1);
|
||||
if let events::Event::FundingGenerationReady { ref temporary_channel_id, ref channel_value_satoshis, ref output_script, .. } = events[0] {
|
||||
let tx = Transaction { version: $chan_id, lock_time: 0, input: Vec::new(), output: vec![TxOut {
|
||||
let tx = Transaction { version: $chan_id, lock_time: PackedLockTime::ZERO, input: Vec::new(), output: vec![TxOut {
|
||||
value: *channel_value_satoshis, script_pubkey: output_script.clone(),
|
||||
}]};
|
||||
funding_output = OutPoint { txid: tx.txid(), index: 0 };
|
||||
@ -481,11 +483,11 @@ pub fn do_test<Out: Output>(data: &[u8], underlying_out: Out) {
|
||||
macro_rules! confirm_txn {
|
||||
($node: expr) => { {
|
||||
let chain_hash = genesis_block(Network::Bitcoin).block_hash();
|
||||
let mut header = BlockHeader { version: 0x20000000, prev_blockhash: chain_hash, merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let mut header = BlockHeader { version: 0x20000000, prev_blockhash: chain_hash, merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
let txdata: Vec<_> = channel_txn.iter().enumerate().map(|(i, tx)| (i + 1, tx)).collect();
|
||||
$node.transactions_confirmed(&header, &txdata, 1);
|
||||
for _ in 2..100 {
|
||||
header = BlockHeader { version: 0x20000000, prev_blockhash: header.block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
header = BlockHeader { version: 0x20000000, prev_blockhash: header.block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
}
|
||||
$node.best_block_updated(&header, 99);
|
||||
} }
|
||||
|
@ -13,13 +13,15 @@
|
||||
//! or payments to send/ways to handle events generated.
|
||||
//! This test has been very useful, though due to its complexity good starting inputs are critical.
|
||||
|
||||
use bitcoin::TxMerkleNode;
|
||||
use bitcoin::blockdata::block::BlockHeader;
|
||||
use bitcoin::blockdata::constants::genesis_block;
|
||||
use bitcoin::blockdata::transaction::{Transaction, TxOut};
|
||||
use bitcoin::blockdata::script::{Builder, Script};
|
||||
use bitcoin::blockdata::opcodes;
|
||||
use bitcoin::blockdata::locktime::PackedLockTime;
|
||||
use bitcoin::consensus::encode::deserialize;
|
||||
use bitcoin::network::constants::Network;
|
||||
use bitcoin::blockdata::constants::genesis_block;
|
||||
|
||||
use bitcoin::hashes::Hash as TraitImport;
|
||||
use bitcoin::hashes::HashEngine as TraitImportEngine;
|
||||
@ -50,7 +52,7 @@ use lightning::util::ser::ReadableArgs;
|
||||
use utils::test_logger;
|
||||
use utils::test_persister::TestPersister;
|
||||
|
||||
use bitcoin::secp256k1::{PublicKey,SecretKey};
|
||||
use bitcoin::secp256k1::{PublicKey, SecretKey, Scalar};
|
||||
use bitcoin::secp256k1::ecdh::SharedSecret;
|
||||
use bitcoin::secp256k1::ecdsa::RecoverableSignature;
|
||||
use bitcoin::secp256k1::Secp256k1;
|
||||
@ -213,7 +215,7 @@ impl<'a> MoneyLossDetector<'a> {
|
||||
}
|
||||
|
||||
self.blocks_connected += 1;
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: self.header_hashes[self.height].0, merkle_root: Default::default(), time: self.blocks_connected, bits: 42, nonce: 42 };
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: self.header_hashes[self.height].0, merkle_root: TxMerkleNode::all_zeros(), time: self.blocks_connected, bits: 42, nonce: 42 };
|
||||
self.height += 1;
|
||||
self.manager.transactions_confirmed(&header, &txdata, self.height as u32);
|
||||
self.manager.best_block_updated(&header, self.height as u32);
|
||||
@ -230,7 +232,7 @@ impl<'a> MoneyLossDetector<'a> {
|
||||
|
||||
fn disconnect_block(&mut self) {
|
||||
if self.height > 0 && (self.max_height < 6 || self.height >= self.max_height - 6) {
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: self.header_hashes[self.height - 1].0, merkle_root: Default::default(), time: self.header_hashes[self.height].1, bits: 42, nonce: 42 };
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: self.header_hashes[self.height - 1].0, merkle_root: TxMerkleNode::all_zeros(), time: self.header_hashes[self.height].1, bits: 42, nonce: 42 };
|
||||
self.manager.block_disconnected(&header, self.height as u32);
|
||||
self.monitor.block_disconnected(&header, self.height as u32);
|
||||
self.height -= 1;
|
||||
@ -270,10 +272,10 @@ impl KeysInterface for KeyProvider {
|
||||
Ok(self.node_secret.clone())
|
||||
}
|
||||
|
||||
fn ecdh(&self, recipient: Recipient, other_key: &PublicKey, tweak: Option<&[u8; 32]>) -> Result<SharedSecret, ()> {
|
||||
fn ecdh(&self, recipient: Recipient, other_key: &PublicKey, tweak: Option<&Scalar>) -> Result<SharedSecret, ()> {
|
||||
let mut node_secret = self.get_node_secret(recipient)?;
|
||||
if let Some(tweak) = tweak {
|
||||
node_secret.mul_assign(tweak).map_err(|_| ())?;
|
||||
node_secret = node_secret.mul_tweak(tweak).unwrap();
|
||||
}
|
||||
Ok(SharedSecret::new(other_key, &node_secret))
|
||||
}
|
||||
@ -564,7 +566,7 @@ pub fn do_test(data: &[u8], logger: &Arc<dyn Logger>) {
|
||||
},
|
||||
10 => {
|
||||
'outer_loop: for funding_generation in pending_funding_generation.drain(..) {
|
||||
let mut tx = Transaction { version: 0, lock_time: 0, input: Vec::new(), output: vec![TxOut {
|
||||
let mut tx = Transaction { version: 0, lock_time: PackedLockTime::ZERO, input: Vec::new(), output: vec![TxOut {
|
||||
value: funding_generation.2, script_pubkey: funding_generation.3,
|
||||
}] };
|
||||
let funding_output = 'search_loop: loop {
|
||||
|
@ -1,11 +1,12 @@
|
||||
// Imports that need to be added manually
|
||||
use lightning_rapid_gossip_sync::RapidGossipSync;
|
||||
use bitcoin::hashes::Hash as TraitImport;
|
||||
|
||||
use utils::test_logger;
|
||||
|
||||
/// Actual fuzz test, method signature and name are fixed
|
||||
fn do_test<Out: test_logger::Output>(data: &[u8], out: Out) {
|
||||
let block_hash = bitcoin::BlockHash::default();
|
||||
let block_hash = bitcoin::BlockHash::all_zeros();
|
||||
let logger = test_logger::TestLogger::new("".to_owned(), out);
|
||||
let network_graph = lightning::routing::gossip::NetworkGraph::new(block_hash, &logger);
|
||||
let rapid_sync = RapidGossipSync::new(&network_graph);
|
||||
|
@ -14,7 +14,7 @@ all-features = true
|
||||
rustdoc-args = ["--cfg", "docsrs"]
|
||||
|
||||
[dependencies]
|
||||
bitcoin = "0.28.1"
|
||||
bitcoin = "0.29.0"
|
||||
lightning = { version = "0.0.110", path = "../lightning", features = ["std"] }
|
||||
lightning-rapid-gossip-sync = { version = "0.0.110", path = "../lightning-rapid-gossip-sync" }
|
||||
|
||||
|
@ -491,6 +491,7 @@ impl Drop for BackgroundProcessor {
|
||||
mod tests {
|
||||
use bitcoin::blockdata::block::BlockHeader;
|
||||
use bitcoin::blockdata::constants::genesis_block;
|
||||
use bitcoin::blockdata::locktime::PackedLockTime;
|
||||
use bitcoin::blockdata::transaction::{Transaction, TxOut};
|
||||
use bitcoin::network::constants::Network;
|
||||
use lightning::chain::{BestBlock, Confirm, chainmonitor};
|
||||
@ -516,6 +517,8 @@ mod tests {
|
||||
use std::sync::{Arc, Mutex};
|
||||
use std::sync::mpsc::SyncSender;
|
||||
use std::time::Duration;
|
||||
use bitcoin::hashes::Hash;
|
||||
use bitcoin::TxMerkleNode;
|
||||
use lightning::routing::scoring::{FixedPenaltyScorer};
|
||||
use lightning_rapid_gossip_sync::RapidGossipSync;
|
||||
use super::{BackgroundProcessor, GossipSync, FRESHNESS_TIMER};
|
||||
@ -703,7 +706,7 @@ mod tests {
|
||||
assert_eq!(channel_value_satoshis, $channel_value);
|
||||
assert_eq!(user_channel_id, 42);
|
||||
|
||||
let tx = Transaction { version: 1 as i32, lock_time: 0, input: Vec::new(), output: vec![TxOut {
|
||||
let tx = Transaction { version: 1 as i32, lock_time: PackedLockTime(0), input: Vec::new(), output: vec![TxOut {
|
||||
value: channel_value_satoshis, script_pubkey: output_script.clone(),
|
||||
}]};
|
||||
(temporary_channel_id, tx)
|
||||
@ -725,7 +728,7 @@ mod tests {
|
||||
for i in 1..=depth {
|
||||
let prev_blockhash = node.best_block.block_hash();
|
||||
let height = node.best_block.height() + 1;
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash, merkle_root: Default::default(), time: height, bits: 42, nonce: 42 };
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash, merkle_root: TxMerkleNode::all_zeros(), time: height, bits: 42, nonce: 42 };
|
||||
let txdata = vec![(0, tx)];
|
||||
node.best_block = BestBlock::new(header.block_hash(), height);
|
||||
match i {
|
||||
|
@ -18,7 +18,7 @@ rest-client = [ "serde", "serde_json", "chunked_transfer" ]
|
||||
rpc-client = [ "serde", "serde_json", "chunked_transfer" ]
|
||||
|
||||
[dependencies]
|
||||
bitcoin = "0.28.1"
|
||||
bitcoin = "0.29.0"
|
||||
lightning = { version = "0.0.110", path = "../lightning" }
|
||||
futures = { version = "0.3" }
|
||||
tokio = { version = "1.0", features = [ "io-util", "net", "time" ], optional = true }
|
||||
|
@ -15,6 +15,7 @@ use serde_json;
|
||||
use std::convert::From;
|
||||
use std::convert::TryFrom;
|
||||
use std::convert::TryInto;
|
||||
use bitcoin::hashes::Hash;
|
||||
|
||||
/// Conversion from `std::io::Error` into `BlockSourceError`.
|
||||
impl From<std::io::Error> for BlockSourceError {
|
||||
@ -57,7 +58,7 @@ impl TryInto<BlockHeaderData> for JsonResponse {
|
||||
|
||||
// Add an empty previousblockhash for the genesis block.
|
||||
if let None = header.get("previousblockhash") {
|
||||
let hash: BlockHash = Default::default();
|
||||
let hash: BlockHash = BlockHash::all_zeros();
|
||||
header.as_object_mut().unwrap().insert("previousblockhash".to_string(), serde_json::json!(hash.to_hex()));
|
||||
}
|
||||
|
||||
|
@ -7,7 +7,7 @@ use bitcoin::hash_types::BlockHash;
|
||||
use bitcoin::network::constants::Network;
|
||||
use bitcoin::util::uint::Uint256;
|
||||
use bitcoin::util::hash::bitcoin_merkle_root;
|
||||
use bitcoin::Transaction;
|
||||
use bitcoin::{PackedLockTime, Transaction};
|
||||
|
||||
use lightning::chain;
|
||||
|
||||
@ -45,7 +45,7 @@ impl Blockchain {
|
||||
// but that's OK because those tests don't trigger the check.
|
||||
let coinbase = Transaction {
|
||||
version: 0,
|
||||
lock_time: 0,
|
||||
lock_time: PackedLockTime::ZERO,
|
||||
input: vec![],
|
||||
output: vec![]
|
||||
};
|
||||
|
@ -19,9 +19,9 @@ no-std = ["hashbrown", "lightning/no-std", "core2/alloc"]
|
||||
std = ["bitcoin_hashes/std", "num-traits/std", "lightning/std", "bech32/std"]
|
||||
|
||||
[dependencies]
|
||||
bech32 = { version = "0.8", default-features = false }
|
||||
bech32 = { version = "0.9.0", default-features = false }
|
||||
lightning = { version = "0.0.110", path = "../lightning", default-features = false }
|
||||
secp256k1 = { version = "0.22", default-features = false, features = ["recovery", "alloc"] }
|
||||
secp256k1 = { version = "0.24.0", default-features = false, features = ["recovery", "alloc"] }
|
||||
num-traits = { version = "0.2.8", default-features = false }
|
||||
bitcoin_hashes = { version = "0.10", default-features = false }
|
||||
hashbrown = { version = "0.11", optional = true }
|
||||
|
@ -16,7 +16,7 @@ honggfuzz = { version = "0.5", optional = true }
|
||||
afl = { version = "0.4", optional = true }
|
||||
lightning-invoice = { path = ".." }
|
||||
lightning = { path = "../../lightning", features = ["regex"] }
|
||||
bech32 = "0.8"
|
||||
bech32 = "0.9.0"
|
||||
|
||||
# Prevent this from interfering with workspaces
|
||||
[workspace]
|
||||
|
@ -15,7 +15,7 @@ all-features = true
|
||||
rustdoc-args = ["--cfg", "docsrs"]
|
||||
|
||||
[dependencies]
|
||||
bitcoin = "0.28.1"
|
||||
bitcoin = "0.29.0"
|
||||
lightning = { version = "0.0.110", path = "../lightning" }
|
||||
tokio = { version = "1.0", features = [ "io-util", "macros", "rt", "sync", "net", "time" ] }
|
||||
|
||||
|
@ -16,7 +16,7 @@ rustdoc-args = ["--cfg", "docsrs"]
|
||||
_bench_unstable = ["lightning/_bench_unstable"]
|
||||
|
||||
[dependencies]
|
||||
bitcoin = "0.28.1"
|
||||
bitcoin = "0.29.0"
|
||||
lightning = { version = "0.0.110", path = "../lightning" }
|
||||
libc = "0.2"
|
||||
|
||||
|
@ -137,7 +137,7 @@ mod tests {
|
||||
use crate::FilesystemPersister;
|
||||
use bitcoin::blockdata::block::{Block, BlockHeader};
|
||||
use bitcoin::hashes::hex::FromHex;
|
||||
use bitcoin::Txid;
|
||||
use bitcoin::{Txid, TxMerkleNode};
|
||||
use lightning::chain::ChannelMonitorUpdateErr;
|
||||
use lightning::chain::chainmonitor::Persist;
|
||||
use lightning::chain::transaction::OutPoint;
|
||||
@ -147,6 +147,7 @@ mod tests {
|
||||
use lightning::util::events::{ClosureReason, MessageSendEventsProvider};
|
||||
use lightning::util::test_utils;
|
||||
use std::fs;
|
||||
use bitcoin::hashes::Hash;
|
||||
#[cfg(target_os = "windows")]
|
||||
use {
|
||||
lightning::get_event_msg,
|
||||
@ -224,7 +225,7 @@ mod tests {
|
||||
let node_txn = nodes[0].tx_broadcaster.txn_broadcasted.lock().unwrap();
|
||||
assert_eq!(node_txn.len(), 1);
|
||||
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[0].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[0].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
connect_block(&nodes[1], &Block { header, txdata: vec![node_txn[0].clone(), node_txn[0].clone()]});
|
||||
check_closed_broadcast!(nodes[1], true);
|
||||
check_closed_event!(nodes[1], 1, ClosureReason::CommitmentTxConfirmed);
|
||||
|
@ -14,7 +14,7 @@ _bench_unstable = []
|
||||
|
||||
[dependencies]
|
||||
lightning = { version = "0.0.110", path = "../lightning" }
|
||||
bitcoin = { version = "0.28.1", default-features = false }
|
||||
bitcoin = { version = "0.29.0", default-features = false }
|
||||
|
||||
[dev-dependencies]
|
||||
lightning = { version = "0.0.110", path = "../lightning", features = ["_test_utils"] }
|
||||
|
@ -38,7 +38,7 @@ grind_signatures = []
|
||||
default = ["std", "grind_signatures"]
|
||||
|
||||
[dependencies]
|
||||
bitcoin = { version = "0.28.1", default-features = false, features = ["secp-recovery"] }
|
||||
bitcoin = { version = "0.29.0", default-features = false, features = ["secp-recovery"] }
|
||||
|
||||
hashbrown = { version = "0.11", optional = true }
|
||||
hex = { version = "0.4", optional = true }
|
||||
@ -52,6 +52,6 @@ hex = "0.4"
|
||||
regex = "1.5.6"
|
||||
|
||||
[dev-dependencies.bitcoin]
|
||||
version = "0.28.1"
|
||||
version = "0.29.0"
|
||||
default-features = false
|
||||
features = ["bitcoinconsensus", "secp-recovery"]
|
||||
|
@ -733,7 +733,8 @@ impl<ChannelSigner: Sign, C: Deref, T: Deref, F: Deref, L: Deref, P: Deref> even
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use bitcoin::BlockHeader;
|
||||
use bitcoin::{BlockHeader, TxMerkleNode};
|
||||
use bitcoin::hashes::Hash;
|
||||
use ::{check_added_monitors, check_closed_broadcast, check_closed_event};
|
||||
use ::{expect_payment_sent, expect_payment_claimed, expect_payment_sent_without_paths, expect_payment_path_successful, get_event_msg};
|
||||
use ::{get_htlc_update_msgs, get_local_commitment_txn, get_revoke_commit_msgs, get_route_and_payment_hash, unwrap_send_err};
|
||||
@ -900,7 +901,7 @@ mod tests {
|
||||
let new_header = BlockHeader {
|
||||
version: 2, time: 0, bits: 0, nonce: 0,
|
||||
prev_blockhash: nodes[0].best_block_info().0,
|
||||
merkle_root: Default::default() };
|
||||
merkle_root: TxMerkleNode::all_zeros() };
|
||||
nodes[0].chain_monitor.chain_monitor.transactions_confirmed(&new_header,
|
||||
&[(0, &remote_txn[0]), (1, &remote_txn[1])], nodes[0].best_block_info().1 + 1);
|
||||
assert!(nodes[0].chain_monitor.release_pending_monitor_events().is_empty());
|
||||
@ -926,7 +927,7 @@ mod tests {
|
||||
let latest_header = BlockHeader {
|
||||
version: 2, time: 0, bits: 0, nonce: 0,
|
||||
prev_blockhash: nodes[0].best_block_info().0,
|
||||
merkle_root: Default::default() };
|
||||
merkle_root: TxMerkleNode::all_zeros() };
|
||||
nodes[0].chain_monitor.chain_monitor.best_block_updated(&latest_header, nodes[0].best_block_info().1 + LATENCY_GRACE_PERIOD_BLOCKS);
|
||||
} else {
|
||||
let persistences = chanmon_cfgs[0].persister.chain_sync_monitor_persistences.lock().unwrap().clone();
|
||||
|
@ -404,7 +404,7 @@ impl Writeable for OnchainEventEntry {
|
||||
|
||||
impl MaybeReadable for OnchainEventEntry {
|
||||
fn read<R: io::Read>(reader: &mut R) -> Result<Option<Self>, DecodeError> {
|
||||
let mut txid = Default::default();
|
||||
let mut txid = Txid::all_zeros();
|
||||
let mut height = 0;
|
||||
let mut event = None;
|
||||
read_tlv_fields!(reader, {
|
||||
@ -1756,12 +1756,12 @@ macro_rules! fail_unbroadcast_htlcs {
|
||||
|
||||
#[cfg(test)]
|
||||
pub fn deliberately_bogus_accepted_htlc_witness_program() -> Vec<u8> {
|
||||
let mut ret = [opcodes::all::OP_NOP.into_u8(); 136];
|
||||
ret[131] = opcodes::all::OP_DROP.into_u8();
|
||||
ret[132] = opcodes::all::OP_DROP.into_u8();
|
||||
ret[133] = opcodes::all::OP_DROP.into_u8();
|
||||
ret[134] = opcodes::all::OP_DROP.into_u8();
|
||||
ret[135] = opcodes::OP_TRUE.into_u8();
|
||||
let mut ret = [opcodes::all::OP_NOP.to_u8(); 136];
|
||||
ret[131] = opcodes::all::OP_DROP.to_u8();
|
||||
ret[132] = opcodes::all::OP_DROP.to_u8();
|
||||
ret[133] = opcodes::all::OP_DROP.to_u8();
|
||||
ret[134] = opcodes::all::OP_DROP.to_u8();
|
||||
ret[135] = opcodes::OP_TRUE.to_u8();
|
||||
Vec::from(&ret[..])
|
||||
}
|
||||
|
||||
@ -2110,7 +2110,7 @@ impl<Signer: Sign> ChannelMonitorImpl<Signer> {
|
||||
};
|
||||
}
|
||||
|
||||
let commitment_number = 0xffffffffffff - ((((tx.input[0].sequence as u64 & 0xffffff) << 3*8) | (tx.lock_time as u64 & 0xffffff)) ^ self.commitment_transaction_number_obscure_factor);
|
||||
let commitment_number = 0xffffffffffff - ((((tx.input[0].sequence.0 as u64 & 0xffffff) << 3*8) | (tx.lock_time.0 as u64 & 0xffffff)) ^ self.commitment_transaction_number_obscure_factor);
|
||||
if commitment_number >= self.get_min_seen_secret() {
|
||||
let secret = self.get_secret(commitment_number).unwrap();
|
||||
let per_commitment_key = ignore_error!(SecretKey::from_slice(&secret));
|
||||
@ -2495,7 +2495,7 @@ impl<Signer: Sign> ChannelMonitorImpl<Signer> {
|
||||
log_info!(logger, "Channel {} closed by funding output spend in txid {}.",
|
||||
log_bytes!(self.funding_info.0.to_channel_id()), tx.txid());
|
||||
self.funding_spend_seen = true;
|
||||
if (tx.input[0].sequence >> 8*3) as u8 == 0x80 && (tx.lock_time >> 8*3) as u8 == 0x20 {
|
||||
if (tx.input[0].sequence.0 >> 8*3) as u8 == 0x80 && (tx.lock_time.0 >> 8*3) as u8 == 0x20 {
|
||||
let (mut new_outpoints, new_outputs) = self.check_spend_counterparty_transaction(&tx, height, &logger);
|
||||
if !new_outputs.1.is_empty() {
|
||||
watch_outputs.push(new_outputs);
|
||||
@ -3469,7 +3469,7 @@ mod tests {
|
||||
use util::ser::{ReadableArgs, Writeable};
|
||||
use sync::{Arc, Mutex};
|
||||
use io;
|
||||
use bitcoin::Witness;
|
||||
use bitcoin::{PackedLockTime, Sequence, TxMerkleNode, Witness};
|
||||
use prelude::*;
|
||||
|
||||
fn do_test_funding_spend_refuses_updates(use_local_txn: bool) {
|
||||
@ -3513,7 +3513,7 @@ mod tests {
|
||||
let new_header = BlockHeader {
|
||||
version: 2, time: 0, bits: 0, nonce: 0,
|
||||
prev_blockhash: nodes[0].best_block_info().0,
|
||||
merkle_root: Default::default() };
|
||||
merkle_root: TxMerkleNode::all_zeros() };
|
||||
let conf_height = nodes[0].best_block_info().1 + 1;
|
||||
nodes[1].chain_monitor.chain_monitor.transactions_confirmed(&new_header,
|
||||
&[(0, broadcast_tx)], conf_height);
|
||||
@ -3573,7 +3573,7 @@ mod tests {
|
||||
let fee_estimator = TestFeeEstimator { sat_per_kw: Mutex::new(253) };
|
||||
|
||||
let dummy_key = PublicKey::from_secret_key(&secp_ctx, &SecretKey::from_slice(&[42; 32]).unwrap());
|
||||
let dummy_tx = Transaction { version: 0, lock_time: 0, input: Vec::new(), output: Vec::new() };
|
||||
let dummy_tx = Transaction { version: 0, lock_time: PackedLockTime::ZERO, input: Vec::new(), output: Vec::new() };
|
||||
|
||||
let mut preimages = Vec::new();
|
||||
{
|
||||
@ -3639,7 +3639,7 @@ mod tests {
|
||||
delayed_payment_basepoint: PublicKey::from_secret_key(&secp_ctx, &SecretKey::from_slice(&[47; 32]).unwrap()),
|
||||
htlc_basepoint: PublicKey::from_secret_key(&secp_ctx, &SecretKey::from_slice(&[48; 32]).unwrap())
|
||||
};
|
||||
let funding_outpoint = OutPoint { txid: Default::default(), index: u16::max_value() };
|
||||
let funding_outpoint = OutPoint { txid: Txid::all_zeros(), index: u16::max_value() };
|
||||
let channel_parameters = ChannelTransactionParameters {
|
||||
holder_pubkeys: keys.holder_channel_pubkeys.clone(),
|
||||
holder_selected_contest_delay: 66,
|
||||
@ -3753,7 +3753,7 @@ mod tests {
|
||||
|
||||
// Justice tx with 1 to_holder, 2 revoked offered HTLCs, 1 revoked received HTLCs
|
||||
for &opt_anchors in [false, true].iter() {
|
||||
let mut claim_tx = Transaction { version: 0, lock_time: 0, input: Vec::new(), output: Vec::new() };
|
||||
let mut claim_tx = Transaction { version: 0, lock_time: PackedLockTime::ZERO, input: Vec::new(), output: Vec::new() };
|
||||
let mut sum_actual_sigs = 0;
|
||||
for i in 0..4 {
|
||||
claim_tx.input.push(TxIn {
|
||||
@ -3762,7 +3762,7 @@ mod tests {
|
||||
vout: i,
|
||||
},
|
||||
script_sig: Script::new(),
|
||||
sequence: 0xfffffffd,
|
||||
sequence: Sequence::ENABLE_RBF_NO_LOCKTIME,
|
||||
witness: Witness::new(),
|
||||
});
|
||||
}
|
||||
@ -3785,7 +3785,7 @@ mod tests {
|
||||
|
||||
// Claim tx with 1 offered HTLCs, 3 received HTLCs
|
||||
for &opt_anchors in [false, true].iter() {
|
||||
let mut claim_tx = Transaction { version: 0, lock_time: 0, input: Vec::new(), output: Vec::new() };
|
||||
let mut claim_tx = Transaction { version: 0, lock_time: PackedLockTime::ZERO, input: Vec::new(), output: Vec::new() };
|
||||
let mut sum_actual_sigs = 0;
|
||||
for i in 0..4 {
|
||||
claim_tx.input.push(TxIn {
|
||||
@ -3794,7 +3794,7 @@ mod tests {
|
||||
vout: i,
|
||||
},
|
||||
script_sig: Script::new(),
|
||||
sequence: 0xfffffffd,
|
||||
sequence: Sequence::ENABLE_RBF_NO_LOCKTIME,
|
||||
witness: Witness::new(),
|
||||
});
|
||||
}
|
||||
@ -3817,7 +3817,7 @@ mod tests {
|
||||
|
||||
// Justice tx with 1 revoked HTLC-Success tx output
|
||||
for &opt_anchors in [false, true].iter() {
|
||||
let mut claim_tx = Transaction { version: 0, lock_time: 0, input: Vec::new(), output: Vec::new() };
|
||||
let mut claim_tx = Transaction { version: 0, lock_time: PackedLockTime::ZERO, input: Vec::new(), output: Vec::new() };
|
||||
let mut sum_actual_sigs = 0;
|
||||
claim_tx.input.push(TxIn {
|
||||
previous_output: BitcoinOutPoint {
|
||||
@ -3825,7 +3825,7 @@ mod tests {
|
||||
vout: 0,
|
||||
},
|
||||
script_sig: Script::new(),
|
||||
sequence: 0xfffffffd,
|
||||
sequence: Sequence::ENABLE_RBF_NO_LOCKTIME,
|
||||
witness: Witness::new(),
|
||||
});
|
||||
claim_tx.output.push(TxOut {
|
||||
|
@ -25,11 +25,11 @@ use bitcoin::hashes::sha256::Hash as Sha256;
|
||||
use bitcoin::hashes::sha256d::Hash as Sha256dHash;
|
||||
use bitcoin::hash_types::WPubkeyHash;
|
||||
|
||||
use bitcoin::secp256k1::{SecretKey, PublicKey};
|
||||
use bitcoin::secp256k1::{SecretKey, PublicKey, Scalar};
|
||||
use bitcoin::secp256k1::{Secp256k1, ecdsa::Signature, Signing};
|
||||
use bitcoin::secp256k1::ecdh::SharedSecret;
|
||||
use bitcoin::secp256k1::ecdsa::RecoverableSignature;
|
||||
use bitcoin::{secp256k1, Witness};
|
||||
use bitcoin::{PackedLockTime, secp256k1, Sequence, Witness};
|
||||
|
||||
use util::{byte_utils, transaction_utils};
|
||||
use util::crypto::{hkdf_extract_expand_twice, sign};
|
||||
@ -410,7 +410,7 @@ pub trait KeysInterface {
|
||||
/// secret, though this is less efficient.
|
||||
///
|
||||
/// [`node secret`]: Self::get_node_secret
|
||||
fn ecdh(&self, recipient: Recipient, other_key: &PublicKey, tweak: Option<&[u8; 32]>) -> Result<SharedSecret, ()>;
|
||||
fn ecdh(&self, recipient: Recipient, other_key: &PublicKey, tweak: Option<&Scalar>) -> Result<SharedSecret, ()>;
|
||||
/// Get a script pubkey which we send funds to when claiming on-chain contestable outputs.
|
||||
///
|
||||
/// This method should return a different value each time it is called, to avoid linking
|
||||
@ -626,7 +626,7 @@ impl InMemorySigner {
|
||||
if spend_tx.input.len() <= input_idx { return Err(()); }
|
||||
if !spend_tx.input[input_idx].script_sig.is_empty() { return Err(()); }
|
||||
if spend_tx.input[input_idx].previous_output != descriptor.outpoint.into_bitcoin_outpoint() { return Err(()); }
|
||||
if spend_tx.input[input_idx].sequence != descriptor.to_self_delay as u32 { return Err(()); }
|
||||
if spend_tx.input[input_idx].sequence.0 != descriptor.to_self_delay as u32 { return Err(()); }
|
||||
|
||||
let delayed_payment_key = chan_utils::derive_private_key(&secp_ctx, &descriptor.per_commitment_point, &self.delayed_payment_base_key)
|
||||
.expect("We constructed the payment_base_key, so we can only fail here if the RNG is busted.");
|
||||
@ -1022,7 +1022,7 @@ impl KeysManager {
|
||||
input.push(TxIn {
|
||||
previous_output: descriptor.outpoint.into_bitcoin_outpoint(),
|
||||
script_sig: Script::new(),
|
||||
sequence: 0,
|
||||
sequence: Sequence::ZERO,
|
||||
witness: Witness::new(),
|
||||
});
|
||||
witness_weight += StaticPaymentOutputDescriptor::MAX_WITNESS_LENGTH;
|
||||
@ -1033,7 +1033,7 @@ impl KeysManager {
|
||||
input.push(TxIn {
|
||||
previous_output: descriptor.outpoint.into_bitcoin_outpoint(),
|
||||
script_sig: Script::new(),
|
||||
sequence: descriptor.to_self_delay as u32,
|
||||
sequence: Sequence(descriptor.to_self_delay as u32),
|
||||
witness: Witness::new(),
|
||||
});
|
||||
witness_weight += DelayedPaymentOutputDescriptor::MAX_WITNESS_LENGTH;
|
||||
@ -1044,7 +1044,7 @@ impl KeysManager {
|
||||
input.push(TxIn {
|
||||
previous_output: outpoint.into_bitcoin_outpoint(),
|
||||
script_sig: Script::new(),
|
||||
sequence: 0,
|
||||
sequence: Sequence::ZERO,
|
||||
witness: Witness::new(),
|
||||
});
|
||||
witness_weight += 1 + 73 + 34;
|
||||
@ -1056,7 +1056,7 @@ impl KeysManager {
|
||||
}
|
||||
let mut spend_tx = Transaction {
|
||||
version: 2,
|
||||
lock_time: 0,
|
||||
lock_time: PackedLockTime(0),
|
||||
input,
|
||||
output: outputs,
|
||||
};
|
||||
@ -1140,10 +1140,10 @@ impl KeysInterface for KeysManager {
|
||||
}
|
||||
}
|
||||
|
||||
fn ecdh(&self, recipient: Recipient, other_key: &PublicKey, tweak: Option<&[u8; 32]>) -> Result<SharedSecret, ()> {
|
||||
fn ecdh(&self, recipient: Recipient, other_key: &PublicKey, tweak: Option<&Scalar>) -> Result<SharedSecret, ()> {
|
||||
let mut node_secret = self.get_node_secret(recipient)?;
|
||||
if let Some(tweak) = tweak {
|
||||
node_secret.mul_assign(tweak).map_err(|_| ())?;
|
||||
node_secret = node_secret.mul_tweak(tweak).map_err(|_| ())?;
|
||||
}
|
||||
Ok(SharedSecret::new(other_key, &node_secret))
|
||||
}
|
||||
@ -1232,10 +1232,10 @@ impl KeysInterface for PhantomKeysManager {
|
||||
}
|
||||
}
|
||||
|
||||
fn ecdh(&self, recipient: Recipient, other_key: &PublicKey, tweak: Option<&[u8; 32]>) -> Result<SharedSecret, ()> {
|
||||
fn ecdh(&self, recipient: Recipient, other_key: &PublicKey, tweak: Option<&Scalar>) -> Result<SharedSecret, ()> {
|
||||
let mut node_secret = self.get_node_secret(recipient)?;
|
||||
if let Some(tweak) = tweak {
|
||||
node_secret.mul_assign(tweak).map_err(|_| ())?;
|
||||
node_secret = node_secret.mul_tweak(tweak).map_err(|_| ())?;
|
||||
}
|
||||
Ok(SharedSecret::new(other_key, &node_secret))
|
||||
}
|
||||
|
@ -38,6 +38,7 @@ use alloc::collections::BTreeMap;
|
||||
use core::cmp;
|
||||
use core::ops::Deref;
|
||||
use core::mem::replace;
|
||||
use bitcoin::hashes::Hash;
|
||||
|
||||
const MAX_ALLOC_SIZE: usize = 64*1024;
|
||||
|
||||
@ -92,7 +93,7 @@ impl Writeable for OnchainEventEntry {
|
||||
|
||||
impl MaybeReadable for OnchainEventEntry {
|
||||
fn read<R: io::Read>(reader: &mut R) -> Result<Option<Self>, DecodeError> {
|
||||
let mut txid = Default::default();
|
||||
let mut txid = Txid::all_zeros();
|
||||
let mut height = 0;
|
||||
let mut event = None;
|
||||
read_tlv_fields!(reader, {
|
||||
@ -389,7 +390,7 @@ impl<ChannelSigner: Sign> OnchainTxHandler<ChannelSigner> {
|
||||
if cached_request.is_malleable() {
|
||||
let predicted_weight = cached_request.package_weight(&self.destination_script, self.channel_transaction_parameters.opt_anchors.is_some());
|
||||
if let Some((output_value, new_feerate)) =
|
||||
cached_request.compute_package_output(predicted_weight, self.destination_script.dust_value().as_sat(), fee_estimator, logger) {
|
||||
cached_request.compute_package_output(predicted_weight, self.destination_script.dust_value().to_sat(), fee_estimator, logger) {
|
||||
assert!(new_feerate != 0);
|
||||
|
||||
let transaction = cached_request.finalize_package(self, output_value, self.destination_script.clone(), logger).unwrap();
|
||||
|
@ -36,7 +36,7 @@ use prelude::*;
|
||||
use core::cmp;
|
||||
use core::mem;
|
||||
use core::ops::Deref;
|
||||
use bitcoin::Witness;
|
||||
use bitcoin::{PackedLockTime, Sequence, Witness};
|
||||
|
||||
use super::chaininterface::LowerBoundedFeeEstimator;
|
||||
|
||||
@ -393,7 +393,7 @@ impl PackageSolvingData {
|
||||
if let Ok(chan_keys) = TxCreationKeys::derive_new(&onchain_handler.secp_ctx, &outp.per_commitment_point, &outp.counterparty_delayed_payment_base_key, &outp.counterparty_htlc_base_key, &onchain_handler.signer.pubkeys().revocation_basepoint, &onchain_handler.signer.pubkeys().htlc_basepoint) {
|
||||
let witness_script = chan_utils::get_htlc_redeemscript_with_explicit_keys(&outp.htlc, onchain_handler.opt_anchors(), &chan_keys.broadcaster_htlc_key, &chan_keys.countersignatory_htlc_key, &chan_keys.revocation_key);
|
||||
|
||||
bumped_tx.lock_time = outp.htlc.cltv_expiry; // Right now we don't aggregate time-locked transaction, if we do we should set lock_time before to avoid breaking hash computation
|
||||
bumped_tx.lock_time = PackedLockTime(outp.htlc.cltv_expiry); // Right now we don't aggregate time-locked transaction, if we do we should set lock_time before to avoid breaking hash computation
|
||||
if let Ok(sig) = onchain_handler.signer.sign_counterparty_htlc_transaction(&bumped_tx, i, &outp.htlc.amount_msat / 1000, &outp.per_commitment_point, &outp.htlc, &onchain_handler.secp_ctx) {
|
||||
let mut ser_sig = sig.serialize_der().to_vec();
|
||||
ser_sig.push(EcdsaSighashType::All as u8);
|
||||
@ -615,7 +615,7 @@ impl PackageTemplate {
|
||||
PackageMalleability::Malleable => {
|
||||
let mut bumped_tx = Transaction {
|
||||
version: 2,
|
||||
lock_time: 0,
|
||||
lock_time: PackedLockTime::ZERO,
|
||||
input: vec![],
|
||||
output: vec![TxOut {
|
||||
script_pubkey: destination_script,
|
||||
@ -626,7 +626,7 @@ impl PackageTemplate {
|
||||
bumped_tx.input.push(TxIn {
|
||||
previous_output: *outpoint,
|
||||
script_sig: Script::new(),
|
||||
sequence: 0xfffffffd,
|
||||
sequence: Sequence::ENABLE_RBF_NO_LOCKTIME,
|
||||
witness: Witness::new(),
|
||||
});
|
||||
}
|
||||
|
@ -26,10 +26,10 @@ use util::ser::{Readable, Writeable, Writer};
|
||||
use util::{byte_utils, transaction_utils};
|
||||
|
||||
use bitcoin::hash_types::WPubkeyHash;
|
||||
use bitcoin::secp256k1::{SecretKey, PublicKey};
|
||||
use bitcoin::secp256k1::{SecretKey, PublicKey, Scalar};
|
||||
use bitcoin::secp256k1::{Secp256k1, ecdsa::Signature, Message};
|
||||
use bitcoin::secp256k1::Error as SecpError;
|
||||
use bitcoin::{secp256k1, Witness};
|
||||
use bitcoin::{PackedLockTime, secp256k1, Sequence, Witness};
|
||||
|
||||
use io;
|
||||
use prelude::*;
|
||||
@ -101,7 +101,7 @@ pub fn build_closing_transaction(to_holder_value_sat: u64, to_counterparty_value
|
||||
ins.push(TxIn {
|
||||
previous_output: funding_outpoint,
|
||||
script_sig: Script::new(),
|
||||
sequence: 0xffffffff,
|
||||
sequence: Sequence::MAX,
|
||||
witness: Witness::new(),
|
||||
});
|
||||
ins
|
||||
@ -132,7 +132,7 @@ pub fn build_closing_transaction(to_holder_value_sat: u64, to_counterparty_value
|
||||
|
||||
Transaction {
|
||||
version: 2,
|
||||
lock_time: 0,
|
||||
lock_time: PackedLockTime::ZERO,
|
||||
input: txins,
|
||||
output: outputs,
|
||||
}
|
||||
@ -264,9 +264,7 @@ pub fn derive_private_key<T: secp256k1::Signing>(secp_ctx: &Secp256k1<T>, per_co
|
||||
sha.input(&PublicKey::from_secret_key(&secp_ctx, &base_secret).serialize());
|
||||
let res = Sha256::from_engine(sha).into_inner();
|
||||
|
||||
let mut key = base_secret.clone();
|
||||
key.add_assign(&res)?;
|
||||
Ok(key)
|
||||
base_secret.clone().add_tweak(&Scalar::from_be_bytes(res).unwrap())
|
||||
}
|
||||
|
||||
/// Derives a per-commitment-transaction public key (eg an htlc key or a delayed_payment key)
|
||||
@ -313,12 +311,9 @@ pub fn derive_private_revocation_key<T: secp256k1::Signing>(secp_ctx: &Secp256k1
|
||||
Sha256::from_engine(sha).into_inner()
|
||||
};
|
||||
|
||||
let mut countersignatory_contrib = countersignatory_revocation_base_secret.clone();
|
||||
countersignatory_contrib.mul_assign(&rev_append_commit_hash_key)?;
|
||||
let mut broadcaster_contrib = per_commitment_secret.clone();
|
||||
broadcaster_contrib.mul_assign(&commit_append_rev_hash_key)?;
|
||||
countersignatory_contrib.add_assign(&broadcaster_contrib[..])?;
|
||||
Ok(countersignatory_contrib)
|
||||
let countersignatory_contrib = countersignatory_revocation_base_secret.clone().mul_tweak(&Scalar::from_be_bytes(rev_append_commit_hash_key).unwrap())?;
|
||||
let broadcaster_contrib = per_commitment_secret.clone().mul_tweak(&Scalar::from_be_bytes(commit_append_rev_hash_key).unwrap())?;
|
||||
countersignatory_contrib.add_tweak(&Scalar::from_be_bytes(broadcaster_contrib.secret_bytes()).unwrap())
|
||||
}
|
||||
|
||||
/// Derives a per-commitment-transaction revocation public key from its constituent parts. This is
|
||||
@ -348,10 +343,8 @@ pub fn derive_public_revocation_key<T: secp256k1::Verification>(secp_ctx: &Secp2
|
||||
Sha256::from_engine(sha).into_inner()
|
||||
};
|
||||
|
||||
let mut countersignatory_contrib = countersignatory_revocation_base_point.clone();
|
||||
countersignatory_contrib.mul_assign(&secp_ctx, &rev_append_commit_hash_key)?;
|
||||
let mut broadcaster_contrib = per_commitment_point.clone();
|
||||
broadcaster_contrib.mul_assign(&secp_ctx, &commit_append_rev_hash_key)?;
|
||||
let countersignatory_contrib = countersignatory_revocation_base_point.clone().mul_tweak(&secp_ctx, &Scalar::from_be_bytes(rev_append_commit_hash_key).unwrap())?;
|
||||
let broadcaster_contrib = per_commitment_point.clone().mul_tweak(&secp_ctx, &Scalar::from_be_bytes(commit_append_rev_hash_key).unwrap())?;
|
||||
countersignatory_contrib.combine(&broadcaster_contrib)
|
||||
}
|
||||
|
||||
@ -614,7 +607,7 @@ pub fn build_htlc_transaction(commitment_txid: &Txid, feerate_per_kw: u32, conte
|
||||
vout: htlc.transaction_output_index.expect("Can't build an HTLC transaction for a dust output"),
|
||||
},
|
||||
script_sig: Script::new(),
|
||||
sequence: if opt_anchors { 1 } else { 0 },
|
||||
sequence: Sequence(if opt_anchors { 1 } else { 0 }),
|
||||
witness: Witness::new(),
|
||||
});
|
||||
|
||||
@ -633,7 +626,7 @@ pub fn build_htlc_transaction(commitment_txid: &Txid, feerate_per_kw: u32, conte
|
||||
|
||||
Transaction {
|
||||
version: 2,
|
||||
lock_time: if htlc.offered { htlc.cltv_expiry } else { 0 },
|
||||
lock_time: PackedLockTime(if htlc.offered { htlc.cltv_expiry } else { 0 }),
|
||||
input: txins,
|
||||
output: txouts,
|
||||
}
|
||||
@ -863,7 +856,7 @@ impl HolderCommitmentTransaction {
|
||||
holder_selected_contest_delay: 0,
|
||||
is_outbound_from_holder: false,
|
||||
counterparty_parameters: Some(CounterpartyChannelTransactionParameters { pubkeys: channel_pubkeys.clone(), selected_contest_delay: 0 }),
|
||||
funding_outpoint: Some(chain::transaction::OutPoint { txid: Default::default(), index: 0 }),
|
||||
funding_outpoint: Some(chain::transaction::OutPoint { txid: Txid::all_zeros(), index: 0 }),
|
||||
opt_anchors: None
|
||||
};
|
||||
let mut htlcs_with_aux: Vec<(_, ())> = Vec::new();
|
||||
@ -1167,7 +1160,7 @@ impl CommitmentTransaction {
|
||||
fn make_transaction(obscured_commitment_transaction_number: u64, txins: Vec<TxIn>, outputs: Vec<TxOut>) -> Transaction {
|
||||
Transaction {
|
||||
version: 2,
|
||||
lock_time: ((0x20 as u32) << 8 * 3) | ((obscured_commitment_transaction_number & 0xffffffu64) as u32),
|
||||
lock_time: PackedLockTime(((0x20 as u32) << 8 * 3) | ((obscured_commitment_transaction_number & 0xffffffu64) as u32)),
|
||||
input: txins,
|
||||
output: outputs,
|
||||
}
|
||||
@ -1291,8 +1284,8 @@ impl CommitmentTransaction {
|
||||
ins.push(TxIn {
|
||||
previous_output: channel_parameters.funding_outpoint(),
|
||||
script_sig: Script::new(),
|
||||
sequence: ((0x80 as u32) << 8 * 3)
|
||||
| ((obscured_commitment_transaction_number >> 3 * 8) as u32),
|
||||
sequence: Sequence(((0x80 as u32) << 8 * 3)
|
||||
| ((obscured_commitment_transaction_number >> 3 * 8) as u32)),
|
||||
witness: Witness::new(),
|
||||
});
|
||||
ins
|
||||
@ -1508,7 +1501,8 @@ mod tests {
|
||||
use bitcoin::secp256k1::{PublicKey, SecretKey, Secp256k1};
|
||||
use util::test_utils;
|
||||
use chain::keysinterface::{KeysInterface, BaseSign};
|
||||
use bitcoin::Network;
|
||||
use bitcoin::{Network, Txid};
|
||||
use bitcoin::hashes::Hash;
|
||||
use ln::PaymentHash;
|
||||
use bitcoin::hashes::hex::ToHex;
|
||||
|
||||
@ -1533,7 +1527,7 @@ mod tests {
|
||||
holder_selected_contest_delay: 0,
|
||||
is_outbound_from_holder: false,
|
||||
counterparty_parameters: Some(CounterpartyChannelTransactionParameters { pubkeys: counterparty_pubkeys.clone(), selected_contest_delay: 0 }),
|
||||
funding_outpoint: Some(chain::transaction::OutPoint { txid: Default::default(), index: 0 }),
|
||||
funding_outpoint: Some(chain::transaction::OutPoint { txid: Txid::all_zeros(), index: 0 }),
|
||||
opt_anchors: None
|
||||
};
|
||||
|
||||
|
@ -36,6 +36,8 @@ use ln::functional_test_utils::*;
|
||||
use util::test_utils;
|
||||
|
||||
use io;
|
||||
use bitcoin::hashes::Hash;
|
||||
use bitcoin::TxMerkleNode;
|
||||
use prelude::*;
|
||||
use sync::{Arc, Mutex};
|
||||
|
||||
@ -116,7 +118,14 @@ fn test_monitor_and_persister_update_fail() {
|
||||
assert!(chain_mon.watch_channel(outpoint, new_monitor).is_ok());
|
||||
chain_mon
|
||||
};
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: Default::default(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header = BlockHeader {
|
||||
version: 0x20000000,
|
||||
prev_blockhash: BlockHash::all_zeros(),
|
||||
merkle_root: TxMerkleNode::all_zeros(),
|
||||
time: 42,
|
||||
bits: 42,
|
||||
nonce: 42
|
||||
};
|
||||
chain_mon.chain_monitor.block_connected(&Block { header, txdata: vec![] }, 200);
|
||||
|
||||
// Set the persister's return value to be a TemporaryFailure.
|
||||
|
@ -6603,7 +6603,7 @@ mod tests {
|
||||
use util::errors::APIError;
|
||||
use util::test_utils;
|
||||
use util::test_utils::OnGetShutdownScriptpubkey;
|
||||
use bitcoin::secp256k1::{Secp256k1, ecdsa::Signature};
|
||||
use bitcoin::secp256k1::{Secp256k1, ecdsa::Signature, Scalar};
|
||||
use bitcoin::secp256k1::ffi::Signature as FFISignature;
|
||||
use bitcoin::secp256k1::{SecretKey,PublicKey};
|
||||
use bitcoin::secp256k1::ecdh::SharedSecret;
|
||||
@ -6612,6 +6612,7 @@ mod tests {
|
||||
use bitcoin::hashes::Hash;
|
||||
use bitcoin::hash_types::WPubkeyHash;
|
||||
use bitcoin::bech32::u5;
|
||||
use bitcoin::PackedLockTime;
|
||||
use bitcoin::util::address::WitnessVersion;
|
||||
use prelude::*;
|
||||
|
||||
@ -6647,7 +6648,7 @@ mod tests {
|
||||
type Signer = InMemorySigner;
|
||||
|
||||
fn get_node_secret(&self, _recipient: Recipient) -> Result<SecretKey, ()> { panic!(); }
|
||||
fn ecdh(&self, _recipient: Recipient, _other_key: &PublicKey, _tweak: Option<&[u8; 32]>) -> Result<SharedSecret, ()> { panic!(); }
|
||||
fn ecdh(&self, _recipient: Recipient, _other_key: &PublicKey, _tweak: Option<&Scalar>) -> Result<SharedSecret, ()> { panic!(); }
|
||||
fn get_inbound_payment_key_material(&self) -> KeyMaterial { panic!(); }
|
||||
fn get_destination_script(&self) -> Script {
|
||||
let secp_ctx = Secp256k1::signing_only();
|
||||
@ -6872,7 +6873,7 @@ mod tests {
|
||||
|
||||
// Node A --> Node B: funding created
|
||||
let output_script = node_a_chan.get_funding_redeemscript();
|
||||
let tx = Transaction { version: 1, lock_time: 0, input: Vec::new(), output: vec![TxOut {
|
||||
let tx = Transaction { version: 1, lock_time: PackedLockTime::ZERO, input: Vec::new(), output: vec![TxOut {
|
||||
value: 10000000, script_pubkey: output_script.clone(),
|
||||
}]};
|
||||
let funding_outpoint = OutPoint{ txid: tx.txid(), index: 0 };
|
||||
|
@ -32,7 +32,7 @@ use bitcoin::hash_types::{BlockHash, Txid};
|
||||
use bitcoin::secp256k1::{SecretKey,PublicKey};
|
||||
use bitcoin::secp256k1::Secp256k1;
|
||||
use bitcoin::secp256k1::ecdh::SharedSecret;
|
||||
use bitcoin::secp256k1;
|
||||
use bitcoin::{LockTime, secp256k1, Sequence};
|
||||
|
||||
use chain;
|
||||
use chain::{Confirm, ChannelMonitorUpdateErr, Watch, BestBlock};
|
||||
@ -2897,7 +2897,7 @@ impl<Signer: Sign, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref> ChannelMana
|
||||
// constituting our Lightning node might not have perfect sync about their blockchain views. Thus, if
|
||||
// the wallet module is in advance on the LDK view, allow one more block of headroom.
|
||||
// TODO: updated if/when https://github.com/rust-bitcoin/rust-bitcoin/pull/994 landed and rust-bitcoin bumped.
|
||||
if !funding_transaction.input.iter().all(|input| input.sequence == 0xffffffff) && funding_transaction.lock_time < 500_000_000 && funding_transaction.lock_time > height + 2 {
|
||||
if !funding_transaction.input.iter().all(|input| input.sequence == Sequence::MAX) && LockTime::from(funding_transaction.lock_time).is_block_height() && funding_transaction.lock_time.0 > height + 2 {
|
||||
return Err(APIError::APIMisuseError {
|
||||
err: "Funding transaction absolute timelock is non-final".to_owned()
|
||||
});
|
||||
@ -7974,7 +7974,7 @@ pub mod bench {
|
||||
|
||||
use bitcoin::hashes::Hash;
|
||||
use bitcoin::hashes::sha256::Hash as Sha256;
|
||||
use bitcoin::{Block, BlockHeader, Transaction, TxOut};
|
||||
use bitcoin::{Block, BlockHeader, PackedLockTime, Transaction, TxMerkleNode, TxOut};
|
||||
|
||||
use sync::{Arc, Mutex};
|
||||
|
||||
@ -8036,7 +8036,7 @@ pub mod bench {
|
||||
|
||||
let tx;
|
||||
if let Event::FundingGenerationReady { temporary_channel_id, output_script, .. } = get_event!(node_a_holder, Event::FundingGenerationReady) {
|
||||
tx = Transaction { version: 2, lock_time: 0, input: Vec::new(), output: vec![TxOut {
|
||||
tx = Transaction { version: 2, lock_time: PackedLockTime::ZERO, input: Vec::new(), output: vec![TxOut {
|
||||
value: 8_000_000, script_pubkey: output_script,
|
||||
}]};
|
||||
node_a.funding_transaction_generated(&temporary_channel_id, &node_b.get_our_node_id(), tx.clone()).unwrap();
|
||||
@ -8048,7 +8048,7 @@ pub mod bench {
|
||||
assert_eq!(&tx_broadcaster.txn_broadcasted.lock().unwrap()[..], &[tx.clone()]);
|
||||
|
||||
let block = Block {
|
||||
header: BlockHeader { version: 0x20000000, prev_blockhash: genesis_hash, merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 },
|
||||
header: BlockHeader { version: 0x20000000, prev_blockhash: genesis_hash, merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 },
|
||||
txdata: vec![tx],
|
||||
};
|
||||
Listen::block_connected(&node_a, &block, 1);
|
||||
|
@ -47,6 +47,7 @@ use alloc::rc::Rc;
|
||||
use sync::{Arc, Mutex};
|
||||
use core::mem;
|
||||
use core::iter::repeat;
|
||||
use bitcoin::{PackedLockTime, TxMerkleNode};
|
||||
|
||||
pub const CHAN_CONFIRM_DEPTH: u32 = 10;
|
||||
|
||||
@ -77,11 +78,11 @@ pub fn confirm_transaction_at<'a, 'b, 'c, 'd>(node: &'a Node<'b, 'c, 'd>, tx: &T
|
||||
connect_blocks(node, conf_height - first_connect_height);
|
||||
}
|
||||
let mut block = Block {
|
||||
header: BlockHeader { version: 0x20000000, prev_blockhash: node.best_block_hash(), merkle_root: Default::default(), time: conf_height, bits: 42, nonce: 42 },
|
||||
header: BlockHeader { version: 0x20000000, prev_blockhash: node.best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: conf_height, bits: 42, nonce: 42 },
|
||||
txdata: Vec::new(),
|
||||
};
|
||||
for _ in 0..*node.network_chan_count.borrow() { // Make sure we don't end up with channels at the same short id by offsetting by chan_count
|
||||
block.txdata.push(Transaction { version: 0, lock_time: 0, input: Vec::new(), output: Vec::new() });
|
||||
block.txdata.push(Transaction { version: 0, lock_time: PackedLockTime::ZERO, input: Vec::new(), output: Vec::new() });
|
||||
}
|
||||
block.txdata.push(tx.clone());
|
||||
connect_block(node, &block);
|
||||
@ -148,7 +149,7 @@ pub fn connect_blocks<'a, 'b, 'c, 'd>(node: &'a Node<'b, 'c, 'd>, depth: u32) ->
|
||||
|
||||
let height = node.best_block_info().1 + 1;
|
||||
let mut block = Block {
|
||||
header: BlockHeader { version: 0x2000000, prev_blockhash: node.best_block_hash(), merkle_root: Default::default(), time: height, bits: 42, nonce: 42 },
|
||||
header: BlockHeader { version: 0x2000000, prev_blockhash: node.best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: height, bits: 42, nonce: 42 },
|
||||
txdata: vec![],
|
||||
};
|
||||
assert!(depth >= 1);
|
||||
@ -156,7 +157,7 @@ pub fn connect_blocks<'a, 'b, 'c, 'd>(node: &'a Node<'b, 'c, 'd>, depth: u32) ->
|
||||
let prev_blockhash = block.header.block_hash();
|
||||
do_connect_block(node, block, skip_intermediaries);
|
||||
block = Block {
|
||||
header: BlockHeader { version: 0x20000000, prev_blockhash, merkle_root: Default::default(), time: height + i, bits: 42, nonce: 42 },
|
||||
header: BlockHeader { version: 0x20000000, prev_blockhash, merkle_root: TxMerkleNode::all_zeros(), time: height + i, bits: 42, nonce: 42 },
|
||||
txdata: vec![],
|
||||
};
|
||||
}
|
||||
@ -619,7 +620,7 @@ pub fn create_funding_transaction<'a, 'b, 'c>(node: &Node<'a, 'b, 'c>, expected_
|
||||
assert_eq!(*channel_value_satoshis, expected_chan_value);
|
||||
assert_eq!(user_channel_id, expected_user_chan_id);
|
||||
|
||||
let tx = Transaction { version: chan_id as i32, lock_time: 0, input: Vec::new(), output: vec![TxOut {
|
||||
let tx = Transaction { version: chan_id as i32, lock_time: PackedLockTime::ZERO, input: Vec::new(), output: vec![TxOut {
|
||||
value: *channel_value_satoshis, script_pubkey: output_script.clone(),
|
||||
}]};
|
||||
let funding_outpoint = OutPoint { txid: tx.txid(), index: 0 };
|
||||
@ -893,11 +894,11 @@ macro_rules! check_spends {
|
||||
{
|
||||
$(
|
||||
for outp in $spends_txn.output.iter() {
|
||||
assert!(outp.value >= outp.script_pubkey.dust_value().as_sat(), "Input tx output didn't meet dust limit");
|
||||
assert!(outp.value >= outp.script_pubkey.dust_value().to_sat(), "Input tx output didn't meet dust limit");
|
||||
}
|
||||
)*
|
||||
for outp in $tx.output.iter() {
|
||||
assert!(outp.value >= outp.script_pubkey.dust_value().as_sat(), "Spending tx output didn't meet dust limit");
|
||||
assert!(outp.value >= outp.script_pubkey.dust_value().to_sat(), "Spending tx output didn't meet dust limit");
|
||||
}
|
||||
let get_output = |out_point: &bitcoin::blockdata::transaction::OutPoint| {
|
||||
$(
|
||||
@ -2125,9 +2126,9 @@ pub fn test_txn_broadcast<'a, 'b, 'c>(node: &Node<'a, 'b, 'c>, chan: &(msgs::Cha
|
||||
if tx.input.len() == 1 && tx.input[0].previous_output.txid == res[0].txid() {
|
||||
check_spends!(tx, res[0]);
|
||||
if has_htlc_tx == HTLCType::TIMEOUT {
|
||||
assert!(tx.lock_time != 0);
|
||||
assert!(tx.lock_time.0 != 0);
|
||||
} else {
|
||||
assert!(tx.lock_time == 0);
|
||||
assert!(tx.lock_time.0 == 0);
|
||||
}
|
||||
res.push(tx.clone());
|
||||
false
|
||||
|
@ -42,7 +42,7 @@ use bitcoin::blockdata::script::{Builder, Script};
|
||||
use bitcoin::blockdata::opcodes;
|
||||
use bitcoin::blockdata::constants::genesis_block;
|
||||
use bitcoin::network::constants::Network;
|
||||
use bitcoin::{Transaction, TxIn, TxOut, Witness};
|
||||
use bitcoin::{PackedLockTime, Sequence, Transaction, TxIn, TxMerkleNode, TxOut, Witness};
|
||||
use bitcoin::OutPoint as BitcoinOutPoint;
|
||||
|
||||
use bitcoin::secp256k1::Secp256k1;
|
||||
@ -55,6 +55,7 @@ use prelude::*;
|
||||
use alloc::collections::BTreeSet;
|
||||
use core::default::Default;
|
||||
use core::iter::repeat;
|
||||
use bitcoin::hashes::Hash;
|
||||
use sync::{Arc, Mutex};
|
||||
|
||||
use ln::functional_test_utils::*;
|
||||
@ -503,7 +504,7 @@ fn do_test_sanity_on_in_flight_opens(steps: u8) {
|
||||
|
||||
if steps & 0b1000_0000 != 0{
|
||||
let block = Block {
|
||||
header: BlockHeader { version: 0x20000000, prev_blockhash: nodes[0].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 },
|
||||
header: BlockHeader { version: 0x20000000, prev_blockhash: nodes[0].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 },
|
||||
txdata: vec![],
|
||||
};
|
||||
connect_block(&nodes[0], &block);
|
||||
@ -2717,11 +2718,11 @@ fn test_htlc_on_chain_success() {
|
||||
assert_eq!(node_txn[1].input[0].witness.clone().last().unwrap().len(), ACCEPTED_HTLC_SCRIPT_WEIGHT);
|
||||
assert!(node_txn[0].output[0].script_pubkey.is_v0_p2wsh()); // revokeable output
|
||||
assert!(node_txn[1].output[0].script_pubkey.is_v0_p2wsh()); // revokeable output
|
||||
assert_eq!(node_txn[0].lock_time, 0);
|
||||
assert_eq!(node_txn[1].lock_time, 0);
|
||||
assert_eq!(node_txn[0].lock_time.0, 0);
|
||||
assert_eq!(node_txn[1].lock_time.0, 0);
|
||||
|
||||
// Verify that B's ChannelManager is able to extract preimage from HTLC Success tx and pass it backward
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42};
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42};
|
||||
connect_block(&nodes[1], &Block { header, txdata: node_txn});
|
||||
connect_blocks(&nodes[1], TEST_FINAL_CLTV - 1); // Confirm blocks until the HTLC expires
|
||||
{
|
||||
@ -2791,8 +2792,8 @@ fn test_htlc_on_chain_success() {
|
||||
// Node[0]: ChannelManager: 3 (commtiemtn tx, 2*HTLC-Timeout tx), ChannelMonitor: 2 HTLC-timeout
|
||||
check_spends!(node_txn[1], $commitment_tx);
|
||||
check_spends!(node_txn[2], $commitment_tx);
|
||||
assert_ne!(node_txn[1].lock_time, 0);
|
||||
assert_ne!(node_txn[2].lock_time, 0);
|
||||
assert_ne!(node_txn[1].lock_time.0, 0);
|
||||
assert_ne!(node_txn[2].lock_time.0, 0);
|
||||
if $htlc_offered {
|
||||
assert_eq!(node_txn[1].input[0].witness.last().unwrap().len(), OFFERED_HTLC_SCRIPT_WEIGHT);
|
||||
assert_eq!(node_txn[2].input[0].witness.last().unwrap().len(), OFFERED_HTLC_SCRIPT_WEIGHT);
|
||||
@ -2841,7 +2842,7 @@ fn test_htlc_on_chain_success() {
|
||||
assert_eq!(commitment_spend.input.len(), 2);
|
||||
assert_eq!(commitment_spend.input[0].witness.last().unwrap().len(), OFFERED_HTLC_SCRIPT_WEIGHT);
|
||||
assert_eq!(commitment_spend.input[1].witness.last().unwrap().len(), OFFERED_HTLC_SCRIPT_WEIGHT);
|
||||
assert_eq!(commitment_spend.lock_time, 0);
|
||||
assert_eq!(commitment_spend.lock_time.0, 0);
|
||||
assert!(commitment_spend.output[0].script_pubkey.is_v0_p2wpkh()); // direct payment
|
||||
check_spends!(node_txn[3], chan_1.3);
|
||||
assert_eq!(node_txn[3].input[0].witness.clone().last().unwrap().len(), 71);
|
||||
@ -2851,7 +2852,7 @@ fn test_htlc_on_chain_success() {
|
||||
// we already checked the same situation with A.
|
||||
|
||||
// Verify that A's ChannelManager is able to extract preimage from preimage tx and generate PaymentSent
|
||||
let mut header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[0].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42};
|
||||
let mut header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[0].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42};
|
||||
connect_block(&nodes[0], &Block { header, txdata: vec![node_a_commitment_tx[0].clone(), commitment_spend.clone()] });
|
||||
connect_blocks(&nodes[0], TEST_FINAL_CLTV + MIN_CLTV_EXPIRY_DELTA as u32 - 1); // Confirm blocks until the HTLC expires
|
||||
check_closed_broadcast!(nodes[0], true);
|
||||
@ -3408,7 +3409,7 @@ fn test_htlc_ignore_latest_remote_commitment() {
|
||||
assert_eq!(node_txn.len(), 3);
|
||||
assert_eq!(node_txn[0], node_txn[1]);
|
||||
|
||||
let mut header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let mut header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
connect_block(&nodes[1], &Block { header, txdata: vec![node_txn[0].clone(), node_txn[1].clone()]});
|
||||
check_closed_broadcast!(nodes[1], true);
|
||||
check_added_monitors!(nodes[1], 1);
|
||||
@ -3491,7 +3492,7 @@ fn test_force_close_fail_back() {
|
||||
assert_eq!(node_txn.len(), 1);
|
||||
assert_eq!(node_txn[0].input.len(), 1);
|
||||
assert_eq!(node_txn[0].input[0].previous_output.txid, tx.txid());
|
||||
assert_eq!(node_txn[0].lock_time, 0); // Must be an HTLC-Success
|
||||
assert_eq!(node_txn[0].lock_time.0, 0); // Must be an HTLC-Success
|
||||
assert_eq!(node_txn[0].input[0].witness.len(), 5); // Must be an HTLC-Success
|
||||
|
||||
check_spends!(node_txn[0], tx);
|
||||
@ -4259,7 +4260,7 @@ fn do_test_htlc_timeout(send_partial_mpp: bool) {
|
||||
};
|
||||
|
||||
let mut block = Block {
|
||||
header: BlockHeader { version: 0x20000000, prev_blockhash: nodes[0].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 },
|
||||
header: BlockHeader { version: 0x20000000, prev_blockhash: nodes[0].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 },
|
||||
txdata: vec![],
|
||||
};
|
||||
connect_block(&nodes[0], &block);
|
||||
@ -4804,7 +4805,7 @@ fn test_claim_sizeable_push_msat() {
|
||||
assert_eq!(spend_txn.len(), 1);
|
||||
assert_eq!(spend_txn[0].input.len(), 1);
|
||||
check_spends!(spend_txn[0], node_txn[0]);
|
||||
assert_eq!(spend_txn[0].input[0].sequence, BREAKDOWN_TIMEOUT as u32);
|
||||
assert_eq!(spend_txn[0].input[0].sequence.0, BREAKDOWN_TIMEOUT as u32);
|
||||
}
|
||||
|
||||
#[test]
|
||||
@ -5034,10 +5035,10 @@ fn test_static_spendable_outputs_justice_tx_revoked_htlc_timeout_tx() {
|
||||
assert_eq!(revoked_htlc_txn[1].input.len(), 1);
|
||||
assert_eq!(revoked_htlc_txn[1].input[0].witness.last().unwrap().len(), OFFERED_HTLC_SCRIPT_WEIGHT);
|
||||
check_spends!(revoked_htlc_txn[1], revoked_local_txn[0]);
|
||||
assert_ne!(revoked_htlc_txn[1].lock_time, 0); // HTLC-Timeout
|
||||
assert_ne!(revoked_htlc_txn[1].lock_time.0, 0); // HTLC-Timeout
|
||||
|
||||
// B will generate justice tx from A's revoked commitment/HTLC tx
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
connect_block(&nodes[1], &Block { header, txdata: vec![revoked_local_txn[0].clone(), revoked_htlc_txn[1].clone()] });
|
||||
check_closed_broadcast!(nodes[1], true);
|
||||
check_added_monitors!(nodes[1], 1);
|
||||
@ -5111,7 +5112,7 @@ fn test_static_spendable_outputs_justice_tx_revoked_htlc_success_tx() {
|
||||
assert_eq!(revoked_local_txn[0].output[unspent_local_txn_output].script_pubkey.len(), 2 + 20); // P2WPKH
|
||||
|
||||
// A will generate justice tx from B's revoked commitment/HTLC tx
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[0].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[0].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
connect_block(&nodes[0], &Block { header, txdata: vec![revoked_local_txn[0].clone(), revoked_htlc_txn[0].clone()] });
|
||||
check_closed_broadcast!(nodes[0], true);
|
||||
check_added_monitors!(nodes[0], 1);
|
||||
@ -5208,10 +5209,10 @@ fn test_onchain_to_onchain_claim() {
|
||||
assert_eq!(c_txn[1].input[0].witness.clone().last().unwrap().len(), 71);
|
||||
assert_eq!(c_txn[2].input[0].witness.clone().last().unwrap().len(), ACCEPTED_HTLC_SCRIPT_WEIGHT);
|
||||
assert!(c_txn[0].output[0].script_pubkey.is_v0_p2wsh()); // revokeable output
|
||||
assert_eq!(c_txn[0].lock_time, 0); // Success tx
|
||||
assert_eq!(c_txn[0].lock_time.0, 0); // Success tx
|
||||
|
||||
// So we broadcast C's commitment tx and HTLC-Success on B's chain, we should successfully be able to extract preimage and update downstream monitor
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42};
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42};
|
||||
connect_block(&nodes[1], &Block { header, txdata: vec![c_txn[1].clone(), c_txn[2].clone()]});
|
||||
check_added_monitors!(nodes[1], 1);
|
||||
let events = nodes[1].node.get_and_clear_pending_events();
|
||||
@ -5269,7 +5270,7 @@ fn test_onchain_to_onchain_claim() {
|
||||
check_spends!(b_txn[0], commitment_tx[0]);
|
||||
assert_eq!(b_txn[0].input[0].witness.clone().last().unwrap().len(), OFFERED_HTLC_SCRIPT_WEIGHT);
|
||||
assert!(b_txn[0].output[0].script_pubkey.is_v0_p2wpkh()); // direct payment
|
||||
assert_eq!(b_txn[0].lock_time, 0); // Success tx
|
||||
assert_eq!(b_txn[0].lock_time.0, 0); // Success tx
|
||||
|
||||
check_closed_broadcast!(nodes[1], true);
|
||||
check_added_monitors!(nodes[1], 1);
|
||||
@ -5477,7 +5478,7 @@ fn test_dynamic_spendable_outputs_local_htlc_success_tx() {
|
||||
assert_eq!(spend_txn.len(), 1);
|
||||
assert_eq!(spend_txn[0].input.len(), 1);
|
||||
check_spends!(spend_txn[0], node_tx);
|
||||
assert_eq!(spend_txn[0].input[0].sequence, BREAKDOWN_TIMEOUT as u32);
|
||||
assert_eq!(spend_txn[0].input[0].sequence.0, BREAKDOWN_TIMEOUT as u32);
|
||||
}
|
||||
|
||||
fn do_test_fail_backwards_unrevoked_remote_announce(deliver_last_raa: bool, announce_latest: bool) {
|
||||
@ -5825,11 +5826,11 @@ fn test_dynamic_spendable_outputs_local_htlc_timeout_tx() {
|
||||
check_spends!(spend_txn[0], local_txn[0]);
|
||||
assert_eq!(spend_txn[1].input.len(), 1);
|
||||
check_spends!(spend_txn[1], htlc_timeout);
|
||||
assert_eq!(spend_txn[1].input[0].sequence, BREAKDOWN_TIMEOUT as u32);
|
||||
assert_eq!(spend_txn[1].input[0].sequence.0, BREAKDOWN_TIMEOUT as u32);
|
||||
assert_eq!(spend_txn[2].input.len(), 2);
|
||||
check_spends!(spend_txn[2], local_txn[0], htlc_timeout);
|
||||
assert!(spend_txn[2].input[0].sequence == BREAKDOWN_TIMEOUT as u32 ||
|
||||
spend_txn[2].input[1].sequence == BREAKDOWN_TIMEOUT as u32);
|
||||
assert!(spend_txn[2].input[0].sequence.0 == BREAKDOWN_TIMEOUT as u32 ||
|
||||
spend_txn[2].input[1].sequence.0 == BREAKDOWN_TIMEOUT as u32);
|
||||
}
|
||||
|
||||
#[test]
|
||||
@ -5908,11 +5909,11 @@ fn test_key_derivation_params() {
|
||||
check_spends!(spend_txn[0], local_txn_1[0]);
|
||||
assert_eq!(spend_txn[1].input.len(), 1);
|
||||
check_spends!(spend_txn[1], htlc_timeout);
|
||||
assert_eq!(spend_txn[1].input[0].sequence, BREAKDOWN_TIMEOUT as u32);
|
||||
assert_eq!(spend_txn[1].input[0].sequence.0, BREAKDOWN_TIMEOUT as u32);
|
||||
assert_eq!(spend_txn[2].input.len(), 2);
|
||||
check_spends!(spend_txn[2], local_txn_1[0], htlc_timeout);
|
||||
assert!(spend_txn[2].input[0].sequence == BREAKDOWN_TIMEOUT as u32 ||
|
||||
spend_txn[2].input[1].sequence == BREAKDOWN_TIMEOUT as u32);
|
||||
assert!(spend_txn[2].input[0].sequence.0 == BREAKDOWN_TIMEOUT as u32 ||
|
||||
spend_txn[2].input[1].sequence.0 == BREAKDOWN_TIMEOUT as u32);
|
||||
}
|
||||
|
||||
#[test]
|
||||
@ -5971,7 +5972,7 @@ fn do_htlc_claim_local_commitment_only(use_dust: bool) {
|
||||
|
||||
let starting_block = nodes[1].best_block_info();
|
||||
let mut block = Block {
|
||||
header: BlockHeader { version: 0x20000000, prev_blockhash: starting_block.0, merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 },
|
||||
header: BlockHeader { version: 0x20000000, prev_blockhash: starting_block.0, merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 },
|
||||
txdata: vec![],
|
||||
};
|
||||
for _ in starting_block.1 + 1..TEST_FINAL_CLTV - CLTV_CLAIM_BUFFER + starting_block.1 + 2 {
|
||||
@ -6002,7 +6003,7 @@ fn do_htlc_claim_current_remote_commitment_only(use_dust: bool) {
|
||||
// to "time out" the HTLC.
|
||||
|
||||
let starting_block = nodes[1].best_block_info();
|
||||
let mut header = BlockHeader { version: 0x20000000, prev_blockhash: starting_block.0, merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let mut header = BlockHeader { version: 0x20000000, prev_blockhash: starting_block.0, merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
|
||||
for _ in starting_block.1 + 1..TEST_FINAL_CLTV + LATENCY_GRACE_PERIOD_BLOCKS + starting_block.1 + 2 {
|
||||
connect_block(&nodes[0], &Block { header, txdata: Vec::new()});
|
||||
@ -6049,7 +6050,7 @@ fn do_htlc_claim_previous_remote_commitment_only(use_dust: bool, check_revoke_no
|
||||
|
||||
let starting_block = nodes[1].best_block_info();
|
||||
let mut block = Block {
|
||||
header: BlockHeader { version: 0x20000000, prev_blockhash: starting_block.0, merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 },
|
||||
header: BlockHeader { version: 0x20000000, prev_blockhash: starting_block.0, merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 },
|
||||
txdata: vec![],
|
||||
};
|
||||
for _ in starting_block.1 + 1..TEST_FINAL_CLTV + LATENCY_GRACE_PERIOD_BLOCKS + CHAN_CONFIRM_DEPTH + 2 {
|
||||
@ -7335,7 +7336,7 @@ fn do_test_sweep_outbound_htlc_failure_update(revoked: bool, local: bool) {
|
||||
if !revoked {
|
||||
assert_eq!(timeout_tx[0].input[0].witness.last().unwrap().len(), ACCEPTED_HTLC_SCRIPT_WEIGHT);
|
||||
} else {
|
||||
assert_eq!(timeout_tx[0].lock_time, 0);
|
||||
assert_eq!(timeout_tx[0].lock_time.0, 0);
|
||||
}
|
||||
// We fail non-dust-HTLC 2 by broadcast of local timeout/revocation-claim tx
|
||||
mine_transaction(&nodes[0], &timeout_tx[0]);
|
||||
@ -7755,7 +7756,7 @@ fn test_bump_penalty_txn_on_revoked_commitment() {
|
||||
|
||||
// Actually revoke tx by claiming a HTLC
|
||||
claim_payment(&nodes[0], &vec!(&nodes[1])[..], payment_preimage);
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: header_114, merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: header_114, merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
connect_block(&nodes[1], &Block { header, txdata: vec![revoked_txn[0].clone()] });
|
||||
check_added_monitors!(nodes[1], 1);
|
||||
|
||||
@ -7855,7 +7856,7 @@ fn test_bump_penalty_txn_on_revoked_htlcs() {
|
||||
// Revoke local commitment tx
|
||||
claim_payment(&nodes[0], &vec!(&nodes[1])[..], payment_preimage);
|
||||
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
// B will generate both revoked HTLC-timeout/HTLC-preimage txn from revoked commitment tx
|
||||
connect_block(&nodes[1], &Block { header, txdata: vec![revoked_local_txn[0].clone()] });
|
||||
check_closed_broadcast!(nodes[1], true);
|
||||
@ -7878,9 +7879,9 @@ fn test_bump_penalty_txn_on_revoked_htlcs() {
|
||||
|
||||
// Broadcast set of revoked txn on A
|
||||
let hash_128 = connect_blocks(&nodes[0], 40);
|
||||
let header_11 = BlockHeader { version: 0x20000000, prev_blockhash: hash_128, merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header_11 = BlockHeader { version: 0x20000000, prev_blockhash: hash_128, merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
connect_block(&nodes[0], &Block { header: header_11, txdata: vec![revoked_local_txn[0].clone()] });
|
||||
let header_129 = BlockHeader { version: 0x20000000, prev_blockhash: header_11.block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header_129 = BlockHeader { version: 0x20000000, prev_blockhash: header_11.block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
connect_block(&nodes[0], &Block { header: header_129, txdata: vec![revoked_htlc_txn[0].clone(), revoked_htlc_txn[2].clone()] });
|
||||
let events = nodes[0].node.get_and_clear_pending_events();
|
||||
expect_pending_htlcs_forwardable_from_events!(nodes[0], events[0..1], true);
|
||||
@ -7937,9 +7938,9 @@ fn test_bump_penalty_txn_on_revoked_htlcs() {
|
||||
}
|
||||
|
||||
// Connect one more block to see if bumped penalty are issued for HTLC txn
|
||||
let header_130 = BlockHeader { version: 0x20000000, prev_blockhash: header_129.block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header_130 = BlockHeader { version: 0x20000000, prev_blockhash: header_129.block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
connect_block(&nodes[0], &Block { header: header_130, txdata: penalty_txn });
|
||||
let header_131 = BlockHeader { version: 0x20000000, prev_blockhash: header_130.block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header_131 = BlockHeader { version: 0x20000000, prev_blockhash: header_130.block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
connect_block(&nodes[0], &Block { header: header_131, txdata: Vec::new() });
|
||||
{
|
||||
let mut node_txn = nodes[0].tx_broadcaster.txn_broadcasted.lock().unwrap();
|
||||
@ -7978,7 +7979,7 @@ fn test_bump_penalty_txn_on_revoked_htlcs() {
|
||||
txn
|
||||
};
|
||||
// Broadcast claim txn and confirm blocks to avoid further bumps on this outputs
|
||||
let header_145 = BlockHeader { version: 0x20000000, prev_blockhash: header_144, merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header_145 = BlockHeader { version: 0x20000000, prev_blockhash: header_144, merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
connect_block(&nodes[0], &Block { header: header_145, txdata: node_txn });
|
||||
connect_blocks(&nodes[0], 20);
|
||||
{
|
||||
@ -8193,7 +8194,7 @@ fn test_bump_txn_sanitize_tracking_maps() {
|
||||
node_txn.clear();
|
||||
penalty_txn
|
||||
};
|
||||
let header_130 = BlockHeader { version: 0x20000000, prev_blockhash: nodes[0].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header_130 = BlockHeader { version: 0x20000000, prev_blockhash: nodes[0].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
connect_block(&nodes[0], &Block { header: header_130, txdata: penalty_txn });
|
||||
connect_blocks(&nodes[0], ANTI_REORG_DELAY - 1);
|
||||
{
|
||||
@ -8669,7 +8670,7 @@ fn test_secret_timeout() {
|
||||
header: BlockHeader {
|
||||
version: 0x2000000,
|
||||
prev_blockhash: node_1_blocks.last().unwrap().0.block_hash(),
|
||||
merkle_root: Default::default(),
|
||||
merkle_root: TxMerkleNode::all_zeros(),
|
||||
time: node_1_blocks.len() as u32 + 7200, bits: 42, nonce: 42 },
|
||||
txdata: vec![],
|
||||
}
|
||||
@ -8814,7 +8815,7 @@ fn test_update_err_monitor_lockdown() {
|
||||
assert!(watchtower.watch_channel(outpoint, new_monitor).is_ok());
|
||||
watchtower
|
||||
};
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: Default::default(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: BlockHash::all_zeros(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
let block = Block { header, txdata: vec![] };
|
||||
// Make the tx_broadcaster aware of enough blocks that it doesn't think we're violating
|
||||
// transaction lock time requirements here.
|
||||
@ -8878,7 +8879,7 @@ fn test_concurrent_monitor_claim() {
|
||||
assert!(watchtower.watch_channel(outpoint, new_monitor).is_ok());
|
||||
watchtower
|
||||
};
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: Default::default(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: BlockHash::all_zeros(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
let block = Block { header, txdata: vec![] };
|
||||
// Make the tx_broadcaster aware of enough blocks that it doesn't think we're violating
|
||||
// transaction lock time requirements here.
|
||||
@ -8907,7 +8908,7 @@ fn test_concurrent_monitor_claim() {
|
||||
assert!(watchtower.watch_channel(outpoint, new_monitor).is_ok());
|
||||
watchtower
|
||||
};
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: Default::default(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: BlockHash::all_zeros(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
watchtower_bob.chain_monitor.block_connected(&Block { header, txdata: vec![] }, CHAN_CONFIRM_DEPTH + TEST_FINAL_CLTV + LATENCY_GRACE_PERIOD_BLOCKS);
|
||||
|
||||
// Route another payment to generate another update with still previous HTLC pending
|
||||
@ -8932,7 +8933,7 @@ fn test_concurrent_monitor_claim() {
|
||||
check_added_monitors!(nodes[0], 1);
|
||||
|
||||
//// Provide one more block to watchtower Bob, expect broadcast of commitment and HTLC-Timeout
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: Default::default(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: BlockHash::all_zeros(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
watchtower_bob.chain_monitor.block_connected(&Block { header, txdata: vec![] }, CHAN_CONFIRM_DEPTH + 1 + TEST_FINAL_CLTV + LATENCY_GRACE_PERIOD_BLOCKS);
|
||||
|
||||
// Watchtower Bob should have broadcast a commitment/HTLC-timeout
|
||||
@ -8945,7 +8946,7 @@ fn test_concurrent_monitor_claim() {
|
||||
};
|
||||
|
||||
// We confirm Bob's state Y on Alice, she should broadcast a HTLC-timeout
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: Default::default(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: BlockHash::all_zeros(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
watchtower_alice.chain_monitor.block_connected(&Block { header, txdata: vec![bob_state_y.clone()] }, CHAN_CONFIRM_DEPTH + 2 + TEST_FINAL_CLTV + LATENCY_GRACE_PERIOD_BLOCKS);
|
||||
{
|
||||
let htlc_txn = chanmon_cfgs[0].tx_broadcaster.txn_broadcasted.lock().unwrap();
|
||||
@ -9020,7 +9021,7 @@ fn test_htlc_no_detection() {
|
||||
check_spends!(local_txn[0], chan_1.3);
|
||||
|
||||
// Timeout HTLC on A's chain and so it can generate a HTLC-Timeout tx
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[0].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[0].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
connect_block(&nodes[0], &Block { header, txdata: vec![local_txn[0].clone()] });
|
||||
// We deliberately connect the local tx twice as this should provoke a failure calling
|
||||
// this test before #653 fix.
|
||||
@ -9038,7 +9039,7 @@ fn test_htlc_no_detection() {
|
||||
node_txn[1].clone()
|
||||
};
|
||||
|
||||
let header_201 = BlockHeader { version: 0x20000000, prev_blockhash: nodes[0].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let header_201 = BlockHeader { version: 0x20000000, prev_blockhash: nodes[0].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
connect_block(&nodes[0], &Block { header: header_201, txdata: vec![htlc_timeout.clone()] });
|
||||
connect_blocks(&nodes[0], ANTI_REORG_DELAY - 1);
|
||||
expect_payment_failed!(nodes[0], our_payment_hash, true);
|
||||
@ -9099,7 +9100,7 @@ fn do_test_onchain_htlc_settlement_after_close(broadcast_alice: bool, go_onchain
|
||||
true => alice_txn.clone(),
|
||||
false => get_local_commitment_txn!(nodes[1], chan_ab.2)
|
||||
};
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42};
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42};
|
||||
connect_block(&nodes[1], &Block { header, txdata: vec![txn_to_broadcast[0].clone()]});
|
||||
let mut bob_txn = nodes[1].tx_broadcaster.txn_broadcasted.lock().unwrap().clone();
|
||||
if broadcast_alice {
|
||||
@ -9182,7 +9183,7 @@ fn do_test_onchain_htlc_settlement_after_close(broadcast_alice: bool, go_onchain
|
||||
let mut txn_to_broadcast = alice_txn.clone();
|
||||
if !broadcast_alice { txn_to_broadcast = get_local_commitment_txn!(nodes[1], chan_ab.2); }
|
||||
if !go_onchain_before_fulfill {
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42};
|
||||
let header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42};
|
||||
connect_block(&nodes[1], &Block { header, txdata: vec![txn_to_broadcast[0].clone()]});
|
||||
// If Bob was the one to force-close, he will have already passed these checks earlier.
|
||||
if broadcast_alice {
|
||||
@ -9514,14 +9515,14 @@ fn test_invalid_funding_tx() {
|
||||
// long the ChannelMonitor will try to read 32 bytes from the second-to-last element, panicing
|
||||
// as its not 32 bytes long.
|
||||
let mut spend_tx = Transaction {
|
||||
version: 2i32, lock_time: 0,
|
||||
version: 2i32, lock_time: PackedLockTime::ZERO,
|
||||
input: tx.output.iter().enumerate().map(|(idx, _)| TxIn {
|
||||
previous_output: BitcoinOutPoint {
|
||||
txid: tx.txid(),
|
||||
vout: idx as u32,
|
||||
},
|
||||
script_sig: Script::new(),
|
||||
sequence: 0xfffffffd,
|
||||
sequence: Sequence::ENABLE_RBF_NO_LOCKTIME,
|
||||
witness: Witness::from_vec(channelmonitor::deliberately_bogus_accepted_htlc_witness())
|
||||
}).collect(),
|
||||
output: vec![TxOut {
|
||||
@ -10432,12 +10433,12 @@ fn test_non_final_funding_tx() {
|
||||
|
||||
let chan_id = *nodes[0].network_chan_count.borrow();
|
||||
let events = nodes[0].node.get_and_clear_pending_events();
|
||||
let input = TxIn { previous_output: BitcoinOutPoint::null(), script_sig: bitcoin::Script::new(), sequence: 0x1, witness: Witness::from_vec(vec!(vec!(1))) };
|
||||
let input = TxIn { previous_output: BitcoinOutPoint::null(), script_sig: bitcoin::Script::new(), sequence: Sequence(1), witness: Witness::from_vec(vec!(vec!(1))) };
|
||||
assert_eq!(events.len(), 1);
|
||||
let mut tx = match events[0] {
|
||||
Event::FundingGenerationReady { ref channel_value_satoshis, ref output_script, .. } => {
|
||||
// Timelock the transaction _beyond_ the best client height + 2.
|
||||
Transaction { version: chan_id as i32, lock_time: best_height + 3, input: vec![input], output: vec![TxOut {
|
||||
Transaction { version: chan_id as i32, lock_time: PackedLockTime(best_height + 3), input: vec![input], output: vec![TxOut {
|
||||
value: *channel_value_satoshis, script_pubkey: output_script.clone(),
|
||||
}]}
|
||||
},
|
||||
@ -10452,7 +10453,7 @@ fn test_non_final_funding_tx() {
|
||||
}
|
||||
|
||||
// However, transaction should be accepted if it's in a +2 headroom from best block.
|
||||
tx.lock_time -= 1;
|
||||
tx.lock_time = PackedLockTime(tx.lock_time.0 - 1);
|
||||
assert!(nodes[0].node.funding_transaction_generated(&temp_channel_id, &nodes[1].node.get_our_node_id(), tx.clone()).is_ok());
|
||||
get_event_msg!(nodes[0], MessageSendEvent::SendFundingCreated, nodes[1].node.get_our_node_id());
|
||||
}
|
||||
|
@ -663,7 +663,7 @@ fn test_balances_on_local_commitment_htlcs() {
|
||||
claimable_height: htlc_cltv_timeout,
|
||||
}]),
|
||||
sorted_vec(nodes[0].chain_monitor.chain_monitor.get_monitor(funding_outpoint).unwrap().get_claimable_balances()));
|
||||
assert_eq!(as_txn[1].lock_time, nodes[0].best_block_info().1 + 1); // as_txn[1] can be included in the next block
|
||||
assert_eq!(as_txn[1].lock_time.0, nodes[0].best_block_info().1 + 1); // as_txn[1] can be included in the next block
|
||||
|
||||
// Now confirm nodes[0]'s HTLC-Timeout transaction, which changes the claimable balance to an
|
||||
// "awaiting confirmations" one.
|
||||
|
@ -23,7 +23,7 @@ use bitcoin::hashes::cmp::fixed_time_eq;
|
||||
use bitcoin::hashes::hmac::{Hmac, HmacEngine};
|
||||
use bitcoin::hashes::sha256::Hash as Sha256;
|
||||
|
||||
use bitcoin::secp256k1::{SecretKey,PublicKey};
|
||||
use bitcoin::secp256k1::{SecretKey, PublicKey, Scalar};
|
||||
use bitcoin::secp256k1::Secp256k1;
|
||||
use bitcoin::secp256k1::ecdh::SharedSecret;
|
||||
use bitcoin::secp256k1;
|
||||
@ -82,7 +82,7 @@ pub(super) fn gen_ammag_from_shared_secret(shared_secret: &[u8]) -> [u8; 32] {
|
||||
Hmac::from_engine(hmac).into_inner()
|
||||
}
|
||||
|
||||
pub(crate) fn next_hop_packet_pubkey<T: secp256k1::Signing + secp256k1::Verification>(secp_ctx: &Secp256k1<T>, mut packet_pubkey: PublicKey, packet_shared_secret: &[u8; 32]) -> Result<PublicKey, secp256k1::Error> {
|
||||
pub(crate) fn next_hop_packet_pubkey<T: secp256k1::Signing + secp256k1::Verification>(secp_ctx: &Secp256k1<T>, packet_pubkey: PublicKey, packet_shared_secret: &[u8; 32]) -> Result<PublicKey, secp256k1::Error> {
|
||||
let blinding_factor = {
|
||||
let mut sha = Sha256::engine();
|
||||
sha.input(&packet_pubkey.serialize()[..]);
|
||||
@ -90,7 +90,7 @@ pub(crate) fn next_hop_packet_pubkey<T: secp256k1::Signing + secp256k1::Verifica
|
||||
Sha256::from_engine(sha).into_inner()
|
||||
};
|
||||
|
||||
packet_pubkey.mul_assign(secp_ctx, &blinding_factor[..]).map(|_| packet_pubkey)
|
||||
packet_pubkey.mul_tweak(secp_ctx, &Scalar::from_be_bytes(blinding_factor).unwrap())
|
||||
}
|
||||
|
||||
// can only fail if an intermediary hop has an invalid public key or session_priv is invalid
|
||||
@ -109,7 +109,7 @@ pub(super) fn construct_onion_keys_callback<T: secp256k1::Signing, FType: FnMut(
|
||||
|
||||
let ephemeral_pubkey = blinded_pub;
|
||||
|
||||
blinded_priv.mul_assign(&blinding_factor)?;
|
||||
blinded_priv = blinded_priv.mul_tweak(&Scalar::from_be_bytes(blinding_factor).unwrap())?;
|
||||
blinded_pub = PublicKey::from_secret_key(secp_ctx, &blinded_priv);
|
||||
|
||||
callback(shared_secret, blinding_factor, ephemeral_pubkey, hop, idx);
|
||||
|
@ -28,7 +28,8 @@ use util::enforcing_trait_impls::EnforcingSigner;
|
||||
use util::ser::{ReadableArgs, Writeable};
|
||||
use io;
|
||||
|
||||
use bitcoin::{Block, BlockHeader, BlockHash};
|
||||
use bitcoin::{Block, BlockHeader, BlockHash, TxMerkleNode};
|
||||
use bitcoin::hashes::Hash;
|
||||
use bitcoin::network::constants::Network;
|
||||
|
||||
use prelude::*;
|
||||
@ -605,7 +606,7 @@ fn do_test_dup_htlc_onchain_fails_on_reload(persist_manager_post_event: bool, co
|
||||
check_added_monitors!(nodes[1], 1);
|
||||
expect_payment_claimed!(nodes[1], payment_hash, 10_000_000);
|
||||
|
||||
let mut header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let mut header = BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
connect_block(&nodes[1], &Block { header, txdata: vec![node_txn[1].clone()]});
|
||||
check_closed_broadcast!(nodes[1], true);
|
||||
check_added_monitors!(nodes[1], 1);
|
||||
|
@ -28,6 +28,8 @@ use bitcoin::secp256k1::Secp256k1;
|
||||
|
||||
use prelude::*;
|
||||
use core::mem;
|
||||
use bitcoin::hashes::Hash;
|
||||
use bitcoin::TxMerkleNode;
|
||||
|
||||
use ln::functional_test_utils::*;
|
||||
|
||||
@ -68,7 +70,7 @@ fn do_test_onchain_htlc_reorg(local_commitment: bool, claim: bool) {
|
||||
check_added_monitors!(nodes[2], 1);
|
||||
get_htlc_update_msgs!(nodes[2], nodes[1].node.get_our_node_id());
|
||||
|
||||
let mut header = BlockHeader { version: 0x2000_0000, prev_blockhash: nodes[2].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 };
|
||||
let mut header = BlockHeader { version: 0x2000_0000, prev_blockhash: nodes[2].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 };
|
||||
let claim_txn = if local_commitment {
|
||||
// Broadcast node 1 commitment txn to broadcast the HTLC-Timeout
|
||||
let node_1_commitment_txn = get_local_commitment_txn!(nodes[1], chan_2.2);
|
||||
@ -131,7 +133,7 @@ fn do_test_onchain_htlc_reorg(local_commitment: bool, claim: bool) {
|
||||
disconnect_blocks(&nodes[1], ANTI_REORG_DELAY - 2);
|
||||
|
||||
let block = Block {
|
||||
header: BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 },
|
||||
header: BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 },
|
||||
txdata: claim_txn,
|
||||
};
|
||||
connect_block(&nodes[1], &block);
|
||||
@ -143,7 +145,7 @@ fn do_test_onchain_htlc_reorg(local_commitment: bool, claim: bool) {
|
||||
} else {
|
||||
// Confirm the timeout tx and check that we fail the HTLC backwards
|
||||
let block = Block {
|
||||
header: BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: Default::default(), time: 42, bits: 42, nonce: 42 },
|
||||
header: BlockHeader { version: 0x20000000, prev_blockhash: nodes[1].best_block_hash(), merkle_root: TxMerkleNode::all_zeros(), time: 42, bits: 42, nonce: 42 },
|
||||
txdata: vec![],
|
||||
};
|
||||
connect_block(&nodes[1], &block);
|
||||
|
@ -122,7 +122,7 @@ pub(crate) fn is_bolt2_compliant(script: &Script, features: &InitFeatures) -> bo
|
||||
if script.is_p2pkh() || script.is_p2sh() || script.is_v0_p2wpkh() || script.is_v0_p2wsh() {
|
||||
true
|
||||
} else if features.supports_shutdown_anysegwit() {
|
||||
script.is_witness_program() && script.as_bytes()[0] != SEGWIT_V0.into_u8()
|
||||
script.is_witness_program() && script.as_bytes()[0] != SEGWIT_V0.to_u8()
|
||||
} else {
|
||||
false
|
||||
}
|
||||
|
@ -13,7 +13,7 @@
|
||||
use bitcoin::hashes::{Hash, HashEngine};
|
||||
use bitcoin::hashes::hmac::{Hmac, HmacEngine};
|
||||
use bitcoin::hashes::sha256::Hash as Sha256;
|
||||
use bitcoin::secp256k1::{self, PublicKey, Secp256k1, SecretKey};
|
||||
use bitcoin::secp256k1::{self, PublicKey, Scalar, Secp256k1, SecretKey};
|
||||
|
||||
use chain::keysinterface::{InMemorySigner, KeysInterface, KeysManager, Recipient, Sign};
|
||||
use ln::msgs;
|
||||
@ -196,7 +196,7 @@ impl<Signer: Sign, K: Deref, L: Deref> OnionMessenger<Signer, K, L>
|
||||
Hmac::from_engine(hmac).into_inner()
|
||||
};
|
||||
match self.keys_manager.ecdh(Recipient::Node, &msg.onion_routing_packet.public_key,
|
||||
Some(&blinding_factor))
|
||||
Some(&Scalar::from_be_bytes(blinding_factor).unwrap()))
|
||||
{
|
||||
Ok(ss) => ss.secret_bytes(),
|
||||
Err(()) => {
|
||||
@ -249,11 +249,13 @@ impl<Signer: Sign, K: Deref, L: Deref> OnionMessenger<Signer, K, L>
|
||||
Sha256::from_engine(sha).into_inner()
|
||||
};
|
||||
let mut next_blinding_point = msg.blinding_point;
|
||||
if let Err(e) = next_blinding_point.mul_assign(&self.secp_ctx, &blinding_factor[..]) {
|
||||
log_trace!(self.logger, "Failed to compute next blinding point: {}", e);
|
||||
return
|
||||
match next_blinding_point.mul_tweak(&self.secp_ctx, &Scalar::from_be_bytes(blinding_factor).unwrap()) {
|
||||
Ok(bp) => bp,
|
||||
Err(e) => {
|
||||
log_trace!(self.logger, "Failed to compute next blinding point: {}", e);
|
||||
return
|
||||
}
|
||||
}
|
||||
next_blinding_point
|
||||
},
|
||||
},
|
||||
onion_routing_packet: outgoing_packet,
|
||||
|
@ -12,7 +12,7 @@
|
||||
use bitcoin::hashes::{Hash, HashEngine};
|
||||
use bitcoin::hashes::hmac::{Hmac, HmacEngine};
|
||||
use bitcoin::hashes::sha256::Hash as Sha256;
|
||||
use bitcoin::secp256k1::{self, PublicKey, Secp256k1, SecretKey};
|
||||
use bitcoin::secp256k1::{self, PublicKey, Secp256k1, SecretKey, Scalar};
|
||||
use bitcoin::secp256k1::ecdh::SharedSecret;
|
||||
|
||||
use ln::onion_utils;
|
||||
@ -43,9 +43,7 @@ pub(super) fn construct_keys_callback<T: secp256k1::Signing + secp256k1::Verific
|
||||
hmac.input(encrypted_data_ss.as_ref());
|
||||
Hmac::from_engine(hmac).into_inner()
|
||||
};
|
||||
let mut unblinded_pk = $pk;
|
||||
unblinded_pk.mul_assign(secp_ctx, &hop_pk_blinding_factor)?;
|
||||
unblinded_pk
|
||||
$pk.mul_tweak(secp_ctx, &Scalar::from_be_bytes(hop_pk_blinding_factor).unwrap())?
|
||||
};
|
||||
let onion_packet_ss = SharedSecret::new(&blinded_hop_pk, &onion_packet_pubkey_priv);
|
||||
|
||||
@ -67,7 +65,7 @@ pub(super) fn construct_keys_callback<T: secp256k1::Signing + secp256k1::Verific
|
||||
Sha256::from_engine(sha).into_inner()
|
||||
};
|
||||
|
||||
msg_blinding_point_priv.mul_assign(&msg_blinding_point_blinding_factor)?;
|
||||
msg_blinding_point_priv = msg_blinding_point_priv.mul_tweak(&Scalar::from_be_bytes(msg_blinding_point_blinding_factor).unwrap())?;
|
||||
msg_blinding_point = PublicKey::from_secret_key(secp_ctx, &msg_blinding_point_priv);
|
||||
|
||||
let onion_packet_pubkey_blinding_factor = {
|
||||
@ -76,7 +74,7 @@ pub(super) fn construct_keys_callback<T: secp256k1::Signing + secp256k1::Verific
|
||||
sha.input(onion_packet_ss.as_ref());
|
||||
Sha256::from_engine(sha).into_inner()
|
||||
};
|
||||
onion_packet_pubkey_priv.mul_assign(&onion_packet_pubkey_blinding_factor)?;
|
||||
onion_packet_pubkey_priv = onion_packet_pubkey_priv.mul_tweak(&Scalar::from_be_bytes(onion_packet_pubkey_blinding_factor).unwrap())?;
|
||||
onion_packet_pubkey = PublicKey::from_secret_key(secp_ctx, &onion_packet_pubkey_priv);
|
||||
};
|
||||
}
|
||||
|
@ -25,7 +25,7 @@ use routing::gossip::NetworkUpdate;
|
||||
use util::ser::{BigSize, FixedLengthReader, Writeable, Writer, MaybeReadable, Readable, VecReadWrapper, VecWriteWrapper};
|
||||
use routing::router::{RouteHop, RouteParameters};
|
||||
|
||||
use bitcoin::Transaction;
|
||||
use bitcoin::{PackedLockTime, Transaction};
|
||||
use bitcoin::blockdata::script::Script;
|
||||
use bitcoin::hashes::Hash;
|
||||
use bitcoin::hashes::sha256::Hash as Sha256;
|
||||
@ -907,7 +907,7 @@ impl MaybeReadable for Event {
|
||||
11u8 => {
|
||||
let f = || {
|
||||
let mut channel_id = [0; 32];
|
||||
let mut transaction = Transaction{ version: 2, lock_time: 0, input: Vec::new(), output: Vec::new() };
|
||||
let mut transaction = Transaction{ version: 2, lock_time: PackedLockTime::ZERO, input: Vec::new(), output: Vec::new() };
|
||||
read_tlv_fields!(reader, {
|
||||
(0, channel_id, required),
|
||||
(2, transaction, required),
|
||||
|
@ -91,7 +91,7 @@ impl<'a> core::fmt::Display for DebugTx<'a> {
|
||||
fn fmt(&self, f: &mut core::fmt::Formatter) -> Result<(), core::fmt::Error> {
|
||||
if self.0.input.len() >= 1 && self.0.input.iter().any(|i| !i.witness.is_empty()) {
|
||||
if self.0.input.len() == 1 && self.0.input[0].witness.last().unwrap().len() == 71 &&
|
||||
(self.0.input[0].sequence >> 8*3) as u8 == 0x80 {
|
||||
(self.0.input[0].sequence.0 >> 8*3) as u8 == 0x80 {
|
||||
write!(f, "commitment tx ")?;
|
||||
} else if self.0.input.len() == 1 && self.0.input[0].witness.last().unwrap().len() == 71 {
|
||||
write!(f, "closing tx ")?;
|
||||
|
@ -860,7 +860,7 @@ macro_rules! impl_consensus_ser {
|
||||
($bitcoin_type: ty) => {
|
||||
impl Writeable for $bitcoin_type {
|
||||
fn write<W: Writer>(&self, writer: &mut W) -> Result<(), io::Error> {
|
||||
match self.consensus_encode(WriterWriteAdaptor(writer)) {
|
||||
match self.consensus_encode(&mut WriterWriteAdaptor(writer)) {
|
||||
Ok(_) => Ok(()),
|
||||
Err(e) => Err(e),
|
||||
}
|
||||
|
@ -34,7 +34,7 @@ use bitcoin::blockdata::block::Block;
|
||||
use bitcoin::network::constants::Network;
|
||||
use bitcoin::hash_types::{BlockHash, Txid};
|
||||
|
||||
use bitcoin::secp256k1::{SecretKey, PublicKey, Secp256k1, ecdsa::Signature};
|
||||
use bitcoin::secp256k1::{SecretKey, PublicKey, Secp256k1, ecdsa::Signature, Scalar};
|
||||
use bitcoin::secp256k1::ecdh::SharedSecret;
|
||||
use bitcoin::secp256k1::ecdsa::RecoverableSignature;
|
||||
|
||||
@ -51,6 +51,7 @@ use chain::keysinterface::{InMemorySigner, Recipient, KeyMaterial};
|
||||
|
||||
#[cfg(feature = "std")]
|
||||
use std::time::{SystemTime, UNIX_EPOCH};
|
||||
use bitcoin::Sequence;
|
||||
|
||||
pub struct TestVecWriter(pub Vec<u8>);
|
||||
impl Writer for TestVecWriter {
|
||||
@ -74,7 +75,7 @@ impl keysinterface::KeysInterface for OnlyReadsKeysInterface {
|
||||
type Signer = EnforcingSigner;
|
||||
|
||||
fn get_node_secret(&self, _recipient: Recipient) -> Result<SecretKey, ()> { unreachable!(); }
|
||||
fn ecdh(&self, _recipient: Recipient, _other_key: &PublicKey, _tweak: Option<&[u8; 32]>) -> Result<SharedSecret, ()> { unreachable!(); }
|
||||
fn ecdh(&self, _recipient: Recipient, _other_key: &PublicKey, _tweak: Option<&Scalar>) -> Result<SharedSecret, ()> { unreachable!(); }
|
||||
fn get_inbound_payment_key_material(&self) -> KeyMaterial { unreachable!(); }
|
||||
fn get_destination_script(&self) -> Script { unreachable!(); }
|
||||
fn get_shutdown_scriptpubkey(&self) -> ShutdownScript { unreachable!(); }
|
||||
@ -241,10 +242,11 @@ impl TestBroadcaster {
|
||||
|
||||
impl chaininterface::BroadcasterInterface for TestBroadcaster {
|
||||
fn broadcast_transaction(&self, tx: &Transaction) {
|
||||
assert!(tx.lock_time < 1_500_000_000);
|
||||
if tx.lock_time > self.blocks.lock().unwrap().len() as u32 + 1 && tx.lock_time < 500_000_000 {
|
||||
let lock_time = tx.lock_time.0;
|
||||
assert!(lock_time < 1_500_000_000);
|
||||
if lock_time > self.blocks.lock().unwrap().len() as u32 + 1 && lock_time < 500_000_000 {
|
||||
for inp in tx.input.iter() {
|
||||
if inp.sequence != 0xffffffff {
|
||||
if inp.sequence != Sequence::MAX {
|
||||
panic!("We should never broadcast a transaction before its locktime ({})!", tx.lock_time);
|
||||
}
|
||||
}
|
||||
@ -600,7 +602,7 @@ impl keysinterface::KeysInterface for TestKeysInterface {
|
||||
fn get_node_secret(&self, recipient: Recipient) -> Result<SecretKey, ()> {
|
||||
self.backing.get_node_secret(recipient)
|
||||
}
|
||||
fn ecdh(&self, recipient: Recipient, other_key: &PublicKey, tweak: Option<&[u8; 32]>) -> Result<SharedSecret, ()> {
|
||||
fn ecdh(&self, recipient: Recipient, other_key: &PublicKey, tweak: Option<&Scalar>) -> Result<SharedSecret, ()> {
|
||||
self.backing.ecdh(recipient, other_key, tweak)
|
||||
}
|
||||
fn get_inbound_payment_key_material(&self) -> keysinterface::KeyMaterial {
|
||||
|
@ -56,7 +56,7 @@ pub(crate) fn maybe_add_change_output(tx: &mut Transaction, input_value: u64, wi
|
||||
weight_with_change += (VarInt(tx.output.len() as u64 + 1).len() - VarInt(tx.output.len() as u64).len()) as i64 * 4;
|
||||
// When calculating weight, add two for the flag bytes
|
||||
let change_value: i64 = (input_value - output_value) as i64 - weight_with_change * feerate_sat_per_1000_weight as i64 / 1000;
|
||||
if change_value >= dust_value.as_sat() as i64 {
|
||||
if change_value >= dust_value.to_sat() as i64 {
|
||||
change_output.value = change_value as u64;
|
||||
tx.output.push(change_output);
|
||||
Ok(weight_with_change as usize)
|
||||
@ -75,9 +75,8 @@ mod tests {
|
||||
use bitcoin::blockdata::script::{Script, Builder};
|
||||
use bitcoin::hash_types::{PubkeyHash, Txid};
|
||||
|
||||
use bitcoin::hashes::sha256d::Hash as Sha256dHash;
|
||||
use bitcoin::hashes::Hash;
|
||||
use bitcoin::Witness;
|
||||
use bitcoin::{PackedLockTime, Sequence, Witness};
|
||||
|
||||
use hex::decode;
|
||||
|
||||
@ -215,7 +214,7 @@ mod tests {
|
||||
#[test]
|
||||
fn test_tx_value_overrun() {
|
||||
// If we have a bogus input amount or outputs valued more than inputs, we should fail
|
||||
let mut tx = Transaction { version: 2, lock_time: 0, input: Vec::new(), output: vec![TxOut {
|
||||
let mut tx = Transaction { version: 2, lock_time: PackedLockTime::ZERO, input: Vec::new(), output: vec![TxOut {
|
||||
script_pubkey: Script::new(), value: 1000
|
||||
}] };
|
||||
assert!(maybe_add_change_output(&mut tx, 21_000_000_0000_0001, 0, 253, Script::new()).is_err());
|
||||
@ -226,10 +225,10 @@ mod tests {
|
||||
#[test]
|
||||
fn test_tx_change_edge() {
|
||||
// Check that we never add dust outputs
|
||||
let mut tx = Transaction { version: 2, lock_time: 0, input: Vec::new(), output: Vec::new() };
|
||||
let mut tx = Transaction { version: 2, lock_time: PackedLockTime::ZERO, input: Vec::new(), output: Vec::new() };
|
||||
let orig_wtxid = tx.wtxid();
|
||||
let output_spk = Script::new_p2pkh(&PubkeyHash::hash(&[0; 0]));
|
||||
assert_eq!(output_spk.dust_value().as_sat(), 546);
|
||||
assert_eq!(output_spk.dust_value().to_sat(), 546);
|
||||
// 9 sats isn't enough to pay fee on a dummy transaction...
|
||||
assert_eq!(tx.weight() as u64, 40); // ie 10 vbytes
|
||||
assert!(maybe_add_change_output(&mut tx, 9, 0, 250, output_spk.clone()).is_err());
|
||||
@ -260,8 +259,8 @@ mod tests {
|
||||
#[test]
|
||||
fn test_tx_extra_outputs() {
|
||||
// Check that we correctly handle existing outputs
|
||||
let mut tx = Transaction { version: 2, lock_time: 0, input: vec![TxIn {
|
||||
previous_output: OutPoint::new(Txid::from_hash(Sha256dHash::default()), 0), script_sig: Script::new(), witness: Witness::new(), sequence: 0,
|
||||
let mut tx = Transaction { version: 2, lock_time: PackedLockTime::ZERO, input: vec![TxIn {
|
||||
previous_output: OutPoint::new(Txid::all_zeros(), 0), script_sig: Script::new(), witness: Witness::new(), sequence: Sequence::ZERO,
|
||||
}], output: vec![TxOut {
|
||||
script_pubkey: Builder::new().push_int(1).into_script(), value: 1000
|
||||
}] };
|
||||
@ -269,7 +268,7 @@ mod tests {
|
||||
let orig_weight = tx.weight();
|
||||
assert_eq!(orig_weight / 4, 61);
|
||||
|
||||
assert_eq!(Builder::new().push_int(2).into_script().dust_value().as_sat(), 474);
|
||||
assert_eq!(Builder::new().push_int(2).into_script().dust_value().to_sat(), 474);
|
||||
|
||||
// Input value of the output value + fee - 1 should fail:
|
||||
assert!(maybe_add_change_output(&mut tx, 1000 + 61 + 100 - 1, 400, 250, Builder::new().push_int(2).into_script()).is_err());
|
||||
|
Loading…
Reference in New Issue
Block a user