diff --git a/Cargo.lock b/Cargo.lock index cc81f52..9043d41 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -379,14 +379,14 @@ dependencies = [ [[package]] name = "ckb-bitcoin-spv-verifier" version = "0.1.0" -source = "git+https://github.com/ckb-cell/ckb-bitcoin-spv?rev=a6fce4b#a6fce4b5333967905a6d3859c56babc985ef89e9" +source = "git+https://github.com/EthanYuan/ckb-bitcoin-spv?rev=b81fd00#b81fd00d4b1db127d84ce4c4caed687f126a3234" dependencies = [ "bitcoin", "bitcoin_hashes", "ckb-merkle-mountain-range 0.6.0", - "ethereum-types", "log", "molecule", + "primitive-types", ] [[package]] @@ -1126,29 +1126,6 @@ dependencies = [ "windows-sys 0.52.0", ] -[[package]] -name = "ethbloom" -version = "0.13.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c22d4b5885b6aa2fe5e8b9329fb8d232bf739e434e6b87347c63bdd00c120f60" -dependencies = [ - "crunchy", - "fixed-hash", - "tiny-keccak", -] - -[[package]] -name = "ethereum-types" -version = "0.14.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "02d215cbf040552efcbe99a38372fe80ab9d00268e20012b79fcd0f073edd8ee" -dependencies = [ - "ethbloom", - "fixed-hash", - "primitive-types", - "uint", -] - [[package]] name = "faster-hex" version = "0.6.1" diff --git a/Cargo.toml b/Cargo.toml index d672d2c..cd05d4d 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -39,8 +39,8 @@ ckb-hash = "0.115.0-rc2" [dependencies.ckb-bitcoin-spv-verifier] version = "0.1.0" -git = "https://github.com/ckb-cell/ckb-bitcoin-spv" -rev = "a6fce4b" +git = "https://github.com/EthanYuan/ckb-bitcoin-spv" +rev = "b81fd00" [features] default = ["default-tls"] diff --git a/src/cli/init.rs b/src/cli/init.rs index e2f0b0d..a1071e5 100644 --- a/src/cli/init.rs +++ b/src/cli/init.rs @@ -4,7 +4,7 @@ use std::{collections::HashMap, path::PathBuf}; use bitcoin::blockdata::constants::DIFFCHANGE_INTERVAL; use ckb_bitcoin_spv_verifier::{ - constants::FLAG_DISABLE_DIFFICULTY_CHECK, + constants::FLAG_CHAIN_TYPE_TESTNET, types::{core::Hash as BitcoinHash, packed, prelude::Pack as VPack}, }; use ckb_jsonrpc_types::TransactionView; @@ -183,7 +183,7 @@ impl Args { let type_id = BitcoinHash::from_bytes_ref(&type_id_array); let mut flags = 0u8; if self.disable_difficulty_check { - flags |= FLAG_DISABLE_DIFFICULTY_CHECK; + flags |= FLAG_CHAIN_TYPE_TESTNET; } let args = packed::SpvTypeArgs::new_builder() .type_id(type_id.pack()) diff --git a/src/cli/serve.rs b/src/cli/serve.rs index 2f2e220..c7df5b6 100644 --- a/src/cli/serve.rs +++ b/src/cli/serve.rs @@ -181,6 +181,7 @@ impl Args { let (spv_client, spv_update) = storage.generate_spv_client_and_spv_update( spv_tip_height, self.spv_headers_update_limit, + input.info.get_flags()?, )?; let tx_hash = @@ -193,8 +194,11 @@ impl Args { let spv_tip_height = input.curr.client.headers_mmr_root.max_height; - let (spv_client, spv_update) = storage - .generate_spv_client_and_spv_update(spv_tip_height, NonZeroU32::MAX)?; + let (spv_client, spv_update) = storage.generate_spv_client_and_spv_update( + spv_tip_height, + NonZeroU32::MAX, + input.info.get_flags()?, + )?; let tx_hash = self.reorg_spv_cells(&spv_service, input, spv_client, spv_update)?; diff --git a/src/components/ckb_client.rs b/src/components/ckb_client.rs index c8e7074..d5d2f62 100644 --- a/src/components/ckb_client.rs +++ b/src/components/ckb_client.rs @@ -60,6 +60,24 @@ impl SpvInfoCell { 0 } } + + pub(crate) fn get_flags(&self) -> Result { + let script_args = self + .cell + .output + .type_() + .to_opt() + .ok_or_else(|| Error::other("the SPV info cell has no type script"))? + .args(); + let script_args_slice = script_args.as_reader().raw_data(); + let args = packed::SpvTypeArgsReader::from_slice(script_args_slice).map_err(|err| { + let msg = + format!("failed to parse the type script args for the SPV info cell since {err}"); + Error::other(msg) + })?; + let flags: u8 = args.flags().into(); + Ok(flags) + } } pub trait CkbRpcClientExtension { diff --git a/src/components/storage/prelude.rs b/src/components/storage/prelude.rs index 9f5a76c..8aa80c4 100644 --- a/src/components/storage/prelude.rs +++ b/src/components/storage/prelude.rs @@ -153,6 +153,7 @@ pub(crate) trait BitcoinSpvStorage: InternalBitcoinSpvStorage { &self, prev_height: u32, limit: NonZeroU32, + flags: u8, ) -> Result<(SpvClient, packed::SpvUpdate)> { let mut tip_height = self.get_tip_bitcoin_height()?; if tip_height > prev_height.saturating_add(limit.into()) { @@ -200,7 +201,7 @@ pub(crate) trait BitcoinSpvStorage: InternalBitcoinSpvStorage { tip_header.time ); let next_target = - calculate_next_target(curr_target, start_header.time, tip_header.time); + calculate_next_target(curr_target, start_header.time, tip_header.time, flags); log::trace!("calculated new target {next_target:#x}"); let next_bits = next_target.to_compact_lossy(); let next_target: Target = next_bits.into();