Skip to content

Commit

Permalink
update spv lib
Browse files Browse the repository at this point in the history
  • Loading branch information
EthanYuan committed Jun 11, 2024
1 parent 3b25270 commit 6a0449d
Show file tree
Hide file tree
Showing 6 changed files with 32 additions and 32 deletions.
27 changes: 2 additions & 25 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 2 additions & 2 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -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"]
Expand Down
4 changes: 2 additions & 2 deletions src/cli/init.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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;
Expand Down Expand Up @@ -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())
Expand Down
8 changes: 6 additions & 2 deletions src/cli/serve.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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 =
Expand All @@ -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)?;
Expand Down
18 changes: 18 additions & 0 deletions src/components/ckb_client.rs
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,24 @@ impl SpvInfoCell {
0
}
}

pub(crate) fn get_flags(&self) -> Result<u8> {
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 {
Expand Down
3 changes: 2 additions & 1 deletion src/components/storage/prelude.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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()) {
Expand Down Expand Up @@ -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();
Expand Down

0 comments on commit 6a0449d

Please sign in to comment.