Skip to main content

Client

Struct Client 

Source
pub struct Client(/* private fields */);
Expand description

Bitcoin Core RPC client. Thread-safe and cheap to clone.

Implementations§

Source§

impl Client

Source

pub fn get_block_count(&self) -> Result<u64, Error>

Returns the numbers of block in the longest chain.

Source

pub fn get_last_height(&self) -> Result<Height, Error>

Returns the numbers of block in the longest chain.

Source

pub fn get_block<'a, H>(&self, hash: &'a H) -> Result<Block, Error>
where &'a H: Into<&'a BlockHash>,

Source

pub fn get_block_info<'a, H>( &self, hash: &'a H, ) -> Result<GetBlockVerboseOne, Error>
where &'a H: Into<&'a BlockHash>,

Source

pub fn get_block_header<'a, H>(&self, hash: &'a H) -> Result<Header, Error>
where &'a H: Into<&'a BlockHash>,

Source

pub fn get_block_header_info<'a, H>( &self, hash: &'a H, ) -> Result<GetBlockHeaderVerbose, Error>
where &'a H: Into<&'a BlockHash>,

Source

pub fn get_block_hash<H>(&self, height: H) -> Result<BlockHash, Error>
where H: Into<u64> + Copy,

Source

pub fn get_block_hashes_range<H1, H2>( &self, start: H1, end: H2, ) -> Result<Vec<BlockHash>, Error>
where H1: Into<u64>, H2: Into<u64>,

Get every canonical block hash for the inclusive height range start..=end in a single JSON-RPC batch request. Returns hashes in canonical order (start, start+1, …, end). Use this whenever resolving more than ~2 heights — one HTTP round-trip beats N sequential get_block_hash calls once the per-call overhead dominates.

Source

pub fn get_tx_out( &self, txid: &Txid, vout: Vout, include_mempool: Option<bool>, ) -> Result<Option<GetTxOut>, Error>

Source

pub fn get_raw_mempool(&self) -> Result<Vec<Txid>, Error>

Source

pub fn get_raw_transaction<'a, T>( &self, txid: &'a T, ) -> Result<Transaction, Error>
where &'a T: Into<&'a Txid>,

Source

pub fn get_raw_transaction_from<'a, T, H>( &self, txid: &'a T, block_hash: &'a H, ) -> Result<Transaction, Error>
where &'a T: Into<&'a Txid>, &'a H: Into<&'a BlockHash>,

Source

pub fn get_raw_transaction_hex<'a, T>( &self, txid: &'a T, ) -> Result<String, Error>
where &'a T: Into<&'a Txid>,

Source

pub fn get_raw_transaction_hex_from<'a, T, H>( &self, txid: &'a T, block_hash: &'a H, ) -> Result<String, Error>
where &'a T: Into<&'a Txid>, &'a H: Into<&'a BlockHash>,

Source

pub fn get_mempool_raw_tx(&self, txid: &Txid) -> Result<Transaction, Error>

Source

pub fn get_raw_transactions( &self, txids: &[Txid], ) -> Result<HashMap<Txid, Transaction, FxBuildHasher>, Error>

Batched getrawtransaction over a slice of txids. Returns a map keyed by txid containing the deserialized tx. Individual failures (e.g. a tx that evicted between the listing and this call) are logged and dropped so a single bad entry doesn’t kill the batch.

Chunked at BATCH_CHUNK requests per round-trip.

Source

pub fn send_raw_transaction(&self, hex: &str) -> Result<Txid, Error>

Source

pub fn fetch_mempool_state( &self, ) -> Result<(MempoolState, Vec<BlockTemplateTx>), Error>

Core’s projected next block + live mempool txid set + mempoolminfee, fetched in a single bitcoind round-trip. GBT carries each tx’s full body and stats, so block 0 is exact even when a tx vanishes from the mempool listing between the GBT and getrawmempool calls; no follow-up entry fetch can race it. Returns the passthrough MempoolState and the raw block_template (consumed downstream by GBT synthesis), in one batched round-trip: getblocktemplate + getrawmempool false

  • getmempoolinfo.
Source

pub fn fetch_new_pool_data( &self, txids: &[Txid], ) -> Result<(Vec<MempoolEntryInfo>, HashMap<Txid, Transaction, FxBuildHasher>), Error>

Mixed batch of getmempoolentry + getrawtransaction for the same txid set in one round-trip. Returns the entries vec and the raw-tx map keyed by txid. Per-item -5 (NOT_FOUND — tx evicted between the listing and this call) drops silently for either leg; transport-level failures still propagate. Chunked at BATCH_CHUNK txids per round-trip (2× that on the wire).

Source

pub fn get_closest_valid_height( &self, hash: BlockHash, ) -> Result<(Height, BlockHash), Error>

Source

pub fn get_blockchain_info(&self) -> Result<GetBlockchainInfo, Error>

Source

pub fn get_network(&self) -> Result<Network, Error>

Bitcoin network the connected node is running on, derived from getblockchaininfo.chain.

Source

pub fn wait_for_synced_node(&self) -> Result<(), Error>

Source§

impl Client

Source

pub fn new(url: &str, auth: Auth) -> Result<Client, Error>

Source

pub fn new_with( url: &str, auth: Auth, max_retries: usize, retry_delay: Duration, ) -> Result<Client, Error>

Source

pub fn default_url() -> &'static str

Source

pub fn default_bitcoin_path() -> PathBuf

Source

pub fn default_linux_bitcoin_path() -> PathBuf

Source

pub fn default_mac_bitcoin_path() -> PathBuf

Trait Implementations§

Source§

impl Clone for Client

Source§

fn clone(&self) -> Client

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Client

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> DynClone for T
where T: Clone,

Source§

fn __clone_box(&self, _: Private) -> *mut ()

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> FromRef<T> for T
where T: Clone,

Source§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoApi for T

Source§

fn into_api<A>(self) -> UseApi<T, A>

into UseApi
Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<D> OwoColorize for D

Source§

fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>
where C: Color,

Set the foreground color generically Read more
Source§

fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>
where C: Color,

Set the background color generically. Read more
Source§

fn black(&self) -> FgColorDisplay<'_, Black, Self>

Change the foreground color to black
Source§

fn on_black(&self) -> BgColorDisplay<'_, Black, Self>

Change the background color to black
Source§

fn red(&self) -> FgColorDisplay<'_, Red, Self>

Change the foreground color to red
Source§

fn on_red(&self) -> BgColorDisplay<'_, Red, Self>

Change the background color to red
Source§

fn green(&self) -> FgColorDisplay<'_, Green, Self>

Change the foreground color to green
Source§

fn on_green(&self) -> BgColorDisplay<'_, Green, Self>

Change the background color to green
Source§

fn yellow(&self) -> FgColorDisplay<'_, Yellow, Self>

Change the foreground color to yellow
Source§

fn on_yellow(&self) -> BgColorDisplay<'_, Yellow, Self>

Change the background color to yellow
Source§

fn blue(&self) -> FgColorDisplay<'_, Blue, Self>

Change the foreground color to blue
Source§

fn on_blue(&self) -> BgColorDisplay<'_, Blue, Self>

Change the background color to blue
Source§

fn magenta(&self) -> FgColorDisplay<'_, Magenta, Self>

Change the foreground color to magenta
Source§

fn on_magenta(&self) -> BgColorDisplay<'_, Magenta, Self>

Change the background color to magenta
Source§

fn purple(&self) -> FgColorDisplay<'_, Magenta, Self>

Change the foreground color to purple
Source§

fn on_purple(&self) -> BgColorDisplay<'_, Magenta, Self>

Change the background color to purple
Source§

fn cyan(&self) -> FgColorDisplay<'_, Cyan, Self>

Change the foreground color to cyan
Source§

fn on_cyan(&self) -> BgColorDisplay<'_, Cyan, Self>

Change the background color to cyan
Source§

fn white(&self) -> FgColorDisplay<'_, White, Self>

Change the foreground color to white
Source§

fn on_white(&self) -> BgColorDisplay<'_, White, Self>

Change the background color to white
Source§

fn default_color(&self) -> FgColorDisplay<'_, Default, Self>

Change the foreground color to the terminal default
Source§

fn on_default_color(&self) -> BgColorDisplay<'_, Default, Self>

Change the background color to the terminal default
Source§

fn bright_black(&self) -> FgColorDisplay<'_, BrightBlack, Self>

Change the foreground color to bright black
Source§

fn on_bright_black(&self) -> BgColorDisplay<'_, BrightBlack, Self>

Change the background color to bright black
Source§

fn bright_red(&self) -> FgColorDisplay<'_, BrightRed, Self>

Change the foreground color to bright red
Source§

fn on_bright_red(&self) -> BgColorDisplay<'_, BrightRed, Self>

Change the background color to bright red
Source§

fn bright_green(&self) -> FgColorDisplay<'_, BrightGreen, Self>

Change the foreground color to bright green
Source§

fn on_bright_green(&self) -> BgColorDisplay<'_, BrightGreen, Self>

Change the background color to bright green
Source§

fn bright_yellow(&self) -> FgColorDisplay<'_, BrightYellow, Self>

Change the foreground color to bright yellow
Source§

fn on_bright_yellow(&self) -> BgColorDisplay<'_, BrightYellow, Self>

Change the background color to bright yellow
Source§

fn bright_blue(&self) -> FgColorDisplay<'_, BrightBlue, Self>

Change the foreground color to bright blue
Source§

fn on_bright_blue(&self) -> BgColorDisplay<'_, BrightBlue, Self>

Change the background color to bright blue
Source§

fn bright_magenta(&self) -> FgColorDisplay<'_, BrightMagenta, Self>

Change the foreground color to bright magenta
Source§

fn on_bright_magenta(&self) -> BgColorDisplay<'_, BrightMagenta, Self>

Change the background color to bright magenta
Source§

fn bright_purple(&self) -> FgColorDisplay<'_, BrightMagenta, Self>

Change the foreground color to bright purple
Source§

fn on_bright_purple(&self) -> BgColorDisplay<'_, BrightMagenta, Self>

Change the background color to bright purple
Source§

fn bright_cyan(&self) -> FgColorDisplay<'_, BrightCyan, Self>

Change the foreground color to bright cyan
Source§

fn on_bright_cyan(&self) -> BgColorDisplay<'_, BrightCyan, Self>

Change the background color to bright cyan
Source§

fn bright_white(&self) -> FgColorDisplay<'_, BrightWhite, Self>

Change the foreground color to bright white
Source§

fn on_bright_white(&self) -> BgColorDisplay<'_, BrightWhite, Self>

Change the background color to bright white
Source§

fn bold(&self) -> BoldDisplay<'_, Self>

Make the text bold
Source§

fn dimmed(&self) -> DimDisplay<'_, Self>

Make the text dim
Source§

fn italic(&self) -> ItalicDisplay<'_, Self>

Make the text italicized
Source§

fn underline(&self) -> UnderlineDisplay<'_, Self>

Make the text underlined
Make the text blink
Make the text blink (but fast!)
Source§

fn reversed(&self) -> ReversedDisplay<'_, Self>

Swap the foreground and background colors
Source§

fn hidden(&self) -> HiddenDisplay<'_, Self>

Hide the text
Source§

fn strikethrough(&self) -> StrikeThroughDisplay<'_, Self>

Cross out the text
Source§

fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>
where Color: DynColor,

Set the foreground color at runtime. Only use if you do not know which color will be used at compile-time. If the color is constant, use either OwoColorize::fg or a color-specific method, such as OwoColorize::green, Read more
Source§

fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>
where Color: DynColor,

Set the background color at runtime. Only use if you do not know what color to use at compile-time. If the color is constant, use either OwoColorize::bg or a color-specific method, such as OwoColorize::on_yellow, Read more
Source§

fn fg_rgb<const R: u8, const G: u8, const B: u8>( &self, ) -> FgColorDisplay<'_, CustomColor<R, G, B>, Self>

Set the foreground color to a specific RGB value.
Source§

fn bg_rgb<const R: u8, const G: u8, const B: u8>( &self, ) -> BgColorDisplay<'_, CustomColor<R, G, B>, Self>

Set the background color to a specific RGB value.
Source§

fn truecolor(&self, r: u8, g: u8, b: u8) -> FgDynColorDisplay<'_, Rgb, Self>

Sets the foreground color to an RGB value.
Source§

fn on_truecolor(&self, r: u8, g: u8, b: u8) -> BgDynColorDisplay<'_, Rgb, Self>

Sets the background color to an RGB value.
Source§

fn style(&self, style: Style) -> Styled<&Self>

Apply a runtime-determined style
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<A, B, T> HttpServerConnExec<A, B> for T
where B: Body,

Source§

impl<T> VecValue for T
where T: Debug + Clone + Send + Sync + 'static,