Struct bitcoincore_rpc::Client

source ·
pub struct Client { /* private fields */ }
Expand description

Client implements a JSON-RPC client for the Bitcoin Core daemon or compatible APIs.

Implementations§

source§

impl Client

source

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

Creates a client to a bitcoind JSON-RPC server.

Can only return Err when using cookie authentication.

source

pub fn from_jsonrpc(client: Client) -> Client

Create a new Client using the given jsonrpc::Client.

source

pub fn get_jsonrpc_client(&self) -> &Client

Get the underlying JSONRPC client.

Trait Implementations§

source§

impl Debug for Client

source§

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

Formats the value using the given formatter. Read more
source§

impl RpcApi for Client

source§

fn call<T: for<'a> Deserialize<'a>>( &self, cmd: &str, args: &[Value] ) -> Result<T>

Call an cmd rpc with given args list

source§

fn get_by_id<T: Queryable<Self>>( &self, id: &<T as Queryable<Self>>::Id ) -> Result<T>

Query an object implementing Querable type
source§

fn get_network_info(&self) -> Result<GetNetworkInfoResult>

source§

fn get_index_info(&self) -> Result<GetIndexInfoResult>

source§

fn version(&self) -> Result<usize>

source§

fn add_multisig_address( &self, nrequired: usize, keys: &[PubKeyOrAddress<'_>], label: Option<&str>, address_type: Option<AddressType> ) -> Result<AddMultiSigAddressResult>

source§

fn load_wallet(&self, wallet: &str) -> Result<LoadWalletResult>

source§

fn unload_wallet( &self, wallet: Option<&str> ) -> Result<Option<UnloadWalletResult>>

source§

fn create_wallet( &self, wallet: &str, disable_private_keys: Option<bool>, blank: Option<bool>, passphrase: Option<&str>, avoid_reuse: Option<bool> ) -> Result<LoadWalletResult>

source§

fn list_wallets(&self) -> Result<Vec<String>>

source§

fn list_wallet_dir(&self) -> Result<Vec<String>>

source§

fn get_wallet_info(&self) -> Result<GetWalletInfoResult>

source§

fn backup_wallet(&self, destination: Option<&str>) -> Result<()>

source§

fn dump_private_key(&self, address: &Address) -> Result<PrivateKey>

source§

fn encrypt_wallet(&self, passphrase: &str) -> Result<()>

source§

fn get_difficulty(&self) -> Result<f64>

source§

fn get_connection_count(&self) -> Result<usize>

source§

fn get_block(&self, hash: &BlockHash) -> Result<Block>

source§

fn get_block_hex(&self, hash: &BlockHash) -> Result<String>

source§

fn get_block_info(&self, hash: &BlockHash) -> Result<GetBlockResult>

source§

fn get_block_header(&self, hash: &BlockHash) -> Result<Header>

source§

fn get_block_header_info( &self, hash: &BlockHash ) -> Result<GetBlockHeaderResult>

source§

fn get_mining_info(&self) -> Result<GetMiningInfoResult>

source§

fn get_block_template( &self, mode: GetBlockTemplateModes, rules: &[GetBlockTemplateRules], capabilities: &[GetBlockTemplateCapabilities] ) -> Result<GetBlockTemplateResult>

source§

fn get_blockchain_info(&self) -> Result<GetBlockchainInfoResult>

Returns a data structure containing various state info regarding blockchain processing.
source§

fn get_block_count(&self) -> Result<u64>

Returns the numbers of block in the longest chain.
source§

fn get_best_block_hash(&self) -> Result<BlockHash>

Returns the hash of the best (tip) block in the longest blockchain.
source§

fn get_block_hash(&self, height: u64) -> Result<BlockHash>

Get block hash at a given height
source§

fn get_block_stats(&self, height: u64) -> Result<GetBlockStatsResult>

source§

fn get_block_stats_fields( &self, height: u64, fields: &[BlockStatsFields] ) -> Result<GetBlockStatsResultPartial>

source§

fn get_raw_transaction( &self, txid: &Txid, block_hash: Option<&BlockHash> ) -> Result<Transaction>

source§

fn get_raw_transaction_hex( &self, txid: &Txid, block_hash: Option<&BlockHash> ) -> Result<String>

source§

fn get_raw_transaction_info( &self, txid: &Txid, block_hash: Option<&BlockHash> ) -> Result<GetRawTransactionResult>

source§

fn get_block_filter( &self, block_hash: &BlockHash ) -> Result<GetBlockFilterResult>

source§

fn get_balance( &self, minconf: Option<usize>, include_watchonly: Option<bool> ) -> Result<Amount>

source§

fn get_balances(&self) -> Result<GetBalancesResult>

source§

fn get_received_by_address( &self, address: &Address, minconf: Option<u32> ) -> Result<Amount>

source§

fn get_transaction( &self, txid: &Txid, include_watchonly: Option<bool> ) -> Result<GetTransactionResult>

source§

fn list_transactions( &self, label: Option<&str>, count: Option<usize>, skip: Option<usize>, include_watchonly: Option<bool> ) -> Result<Vec<ListTransactionResult>>

source§

fn list_since_block( &self, blockhash: Option<&BlockHash>, target_confirmations: Option<usize>, include_watchonly: Option<bool>, include_removed: Option<bool> ) -> Result<ListSinceBlockResult>

source§

fn get_tx_out( &self, txid: &Txid, vout: u32, include_mempool: Option<bool> ) -> Result<Option<GetTxOutResult>>

source§

fn get_tx_out_proof( &self, txids: &[Txid], block_hash: Option<&BlockHash> ) -> Result<Vec<u8>>

source§

fn import_public_key( &self, pubkey: &PublicKey, label: Option<&str>, rescan: Option<bool> ) -> Result<()>

source§

fn import_private_key( &self, privkey: &PrivateKey, label: Option<&str>, rescan: Option<bool> ) -> Result<()>

source§

fn import_address( &self, address: &Address, label: Option<&str>, rescan: Option<bool> ) -> Result<()>

source§

fn import_address_script( &self, script: &Script, label: Option<&str>, rescan: Option<bool>, p2sh: Option<bool> ) -> Result<()>

source§

fn import_multi( &self, requests: &[ImportMultiRequest<'_>], options: Option<&ImportMultiOptions> ) -> Result<Vec<ImportMultiResult>>

source§

fn import_descriptors( &self, req: ImportDescriptors ) -> Result<Vec<ImportMultiResult>>

source§

fn set_label(&self, address: &Address, label: &str) -> Result<()>

source§

fn key_pool_refill(&self, new_size: Option<usize>) -> Result<()>

source§

fn list_unspent( &self, minconf: Option<usize>, maxconf: Option<usize>, addresses: Option<&[&Address<NetworkChecked>]>, include_unsafe: Option<bool>, query_options: Option<ListUnspentQueryOptions> ) -> Result<Vec<ListUnspentResultEntry>>

source§

fn lock_unspent(&self, outputs: &[OutPoint]) -> Result<bool>

To unlock, use [unlock_unspent].
source§

fn unlock_unspent(&self, outputs: &[OutPoint]) -> Result<bool>

source§

fn unlock_unspent_all(&self) -> Result<bool>

Unlock all unspent UTXOs.
source§

fn list_received_by_address( &self, address_filter: Option<&Address>, minconf: Option<u32>, include_empty: Option<bool>, include_watchonly: Option<bool> ) -> Result<Vec<ListReceivedByAddressResult>>

source§

fn create_psbt( &self, inputs: &[CreateRawTransactionInput], outputs: &HashMap<String, Amount>, locktime: Option<i64>, replaceable: Option<bool> ) -> Result<String>

source§

fn create_raw_transaction_hex( &self, utxos: &[CreateRawTransactionInput], outs: &HashMap<String, Amount>, locktime: Option<i64>, replaceable: Option<bool> ) -> Result<String>

source§

fn create_raw_transaction( &self, utxos: &[CreateRawTransactionInput], outs: &HashMap<String, Amount>, locktime: Option<i64>, replaceable: Option<bool> ) -> Result<Transaction>

source§

fn decode_raw_transaction<R: RawTx>( &self, tx: R, is_witness: Option<bool> ) -> Result<DecodeRawTransactionResult>

source§

fn fund_raw_transaction<R: RawTx>( &self, tx: R, options: Option<&FundRawTransactionOptions>, is_witness: Option<bool> ) -> Result<FundRawTransactionResult>

source§

fn sign_raw_transaction<R: RawTx>( &self, tx: R, utxos: Option<&[SignRawTransactionInput]>, private_keys: Option<&[PrivateKey]>, sighash_type: Option<SigHashType> ) -> Result<SignRawTransactionResult>

👎Deprecated
source§

fn sign_raw_transaction_with_wallet<R: RawTx>( &self, tx: R, utxos: Option<&[SignRawTransactionInput]>, sighash_type: Option<SigHashType> ) -> Result<SignRawTransactionResult>

source§

fn sign_raw_transaction_with_key<R: RawTx>( &self, tx: R, privkeys: &[PrivateKey], prevtxs: Option<&[SignRawTransactionInput]>, sighash_type: Option<SigHashType> ) -> Result<SignRawTransactionResult>

source§

fn test_mempool_accept<R: RawTx>( &self, rawtxs: &[R] ) -> Result<Vec<TestMempoolAcceptResult>>

source§

fn stop(&self) -> Result<String>

source§

fn verify_message( &self, address: &Address, signature: &Signature, message: &str ) -> Result<bool>

source§

fn get_new_address( &self, label: Option<&str>, address_type: Option<AddressType> ) -> Result<Address<NetworkUnchecked>>

Generate new address under own control
source§

fn get_raw_change_address( &self, address_type: Option<AddressType> ) -> Result<Address<NetworkUnchecked>>

Generate new address for receiving change
source§

fn get_address_info(&self, address: &Address) -> Result<GetAddressInfoResult>

source§

fn generate_to_address( &self, block_num: u64, address: &Address<NetworkChecked> ) -> Result<Vec<BlockHash>>

Mine block_num blocks and pay coinbase to address Read more
source§

fn generate( &self, block_num: u64, maxtries: Option<u64> ) -> Result<Vec<BlockHash>>

Mine up to block_num blocks immediately (before the RPC call returns) to an address in the wallet.
source§

fn invalidate_block(&self, block_hash: &BlockHash) -> Result<()>

Mark a block as invalid by block_hash
source§

fn reconsider_block(&self, block_hash: &BlockHash) -> Result<()>

Mark a block as valid by block_hash
source§

fn get_mempool_info(&self) -> Result<GetMempoolInfoResult>

Returns details on the active state of the TX memory pool
source§

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

Get txids of all transactions in a memory pool
source§

fn get_raw_mempool_verbose( &self ) -> Result<HashMap<Txid, GetMempoolEntryResult>>

Get details for the transactions in a memory pool
source§

fn get_mempool_entry(&self, txid: &Txid) -> Result<GetMempoolEntryResult>

Get mempool data for given transaction
source§

fn get_chain_tips(&self) -> Result<GetChainTipsResult>

Get information about all known tips in the block tree, including the main chain as well as stale branches.
source§

fn send_to_address( &self, address: &Address<NetworkChecked>, amount: Amount, comment: Option<&str>, comment_to: Option<&str>, subtract_fee: Option<bool>, replaceable: Option<bool>, confirmation_target: Option<u32>, estimate_mode: Option<EstimateMode> ) -> Result<Txid>

source§

fn add_node(&self, addr: &str) -> Result<()>

Attempts to add a node to the addnode list. Nodes added using addnode (or -connect) are protected from DoS disconnection and are not required to be full nodes/support SegWit as other outbound peers are (though such peers will not be synced from).
source§

fn remove_node(&self, addr: &str) -> Result<()>

Attempts to remove a node from the addnode list.
source§

fn onetry_node(&self, addr: &str) -> Result<()>

Attempts to connect to a node without permanently adding it to the addnode list.
source§

fn disconnect_node(&self, addr: &str) -> Result<()>

Immediately disconnects from the specified peer node.
source§

fn disconnect_node_by_id(&self, node_id: u32) -> Result<()>

source§

fn get_added_node_info( &self, node: Option<&str> ) -> Result<Vec<GetAddedNodeInfoResult>>

Returns information about the given added node, or all added nodes (note that onetry addnodes are not listed here)
source§

fn get_node_addresses( &self, count: Option<usize> ) -> Result<Vec<GetNodeAddressesResult>>

Return known addresses which can potentially be used to find new nodes in the network
source§

fn list_banned(&self) -> Result<Vec<ListBannedResult>>

List all banned IPs/Subnets.
source§

fn clear_banned(&self) -> Result<()>

Clear all banned IPs.
source§

fn add_ban(&self, subnet: &str, bantime: u64, absolute: bool) -> Result<()>

Attempts to add an IP/Subnet to the banned list.
source§

fn remove_ban(&self, subnet: &str) -> Result<()>

Attempts to remove an IP/Subnet from the banned list.
source§

fn set_network_active(&self, state: bool) -> Result<bool>

Disable/enable all p2p network activity.
source§

fn get_peer_info(&self) -> Result<Vec<GetPeerInfoResult>>

Returns data about each connected network node as an array of PeerInfo
source§

fn ping(&self) -> Result<()>

Requests that a ping be sent to all other nodes, to measure ping time. Read more
source§

fn send_raw_transaction<R: RawTx>(&self, tx: R) -> Result<Txid>

source§

fn estimate_smart_fee( &self, conf_target: u16, estimate_mode: Option<EstimateMode> ) -> Result<EstimateSmartFeeResult>

source§

fn wait_for_new_block(&self, timeout: u64) -> Result<BlockRef>

Waits for a specific new block and returns useful info about it. Returns the current block on timeout or exit. Read more
source§

fn wait_for_block( &self, blockhash: &BlockHash, timeout: u64 ) -> Result<BlockRef>

Waits for a specific new block and returns useful info about it. Returns the current block on timeout or exit. Read more
source§

fn wallet_create_funded_psbt( &self, inputs: &[CreateRawTransactionInput], outputs: &HashMap<String, Amount>, locktime: Option<i64>, options: Option<WalletCreateFundedPsbtOptions>, bip32derivs: Option<bool> ) -> Result<WalletCreateFundedPsbtResult>

source§

fn wallet_process_psbt( &self, psbt: &str, sign: Option<bool>, sighash_type: Option<SigHashType>, bip32derivs: Option<bool> ) -> Result<WalletProcessPsbtResult>

source§

fn get_descriptor_info(&self, desc: &str) -> Result<GetDescriptorInfoResult>

source§

fn join_psbt(&self, psbts: &[String]) -> Result<String>

source§

fn combine_psbt(&self, psbts: &[String]) -> Result<String>

source§

fn combine_raw_transaction(&self, hex_strings: &[String]) -> Result<String>

source§

fn finalize_psbt( &self, psbt: &str, extract: Option<bool> ) -> Result<FinalizePsbtResult>

source§

fn derive_addresses( &self, descriptor: &str, range: Option<[u32; 2]> ) -> Result<Vec<Address<NetworkUnchecked>>>

source§

fn rescan_blockchain( &self, start_from: Option<usize>, stop_height: Option<usize> ) -> Result<(usize, Option<usize>)>

source§

fn get_tx_out_set_info( &self, hash_type: Option<TxOutSetHashType>, hash_or_height: Option<HashOrHeight>, use_index: Option<bool> ) -> Result<GetTxOutSetInfoResult>

Returns statistics about the unspent transaction output set. Note this call may take some time if you are not using coinstatsindex.
source§

fn get_net_totals(&self) -> Result<GetNetTotalsResult>

Returns information about network traffic, including bytes in, bytes out, and current time.
source§

fn get_network_hash_ps( &self, nblocks: Option<u64>, height: Option<u64> ) -> Result<f64>

Returns the estimated network hashes per second based on the last n blocks.
source§

fn uptime(&self) -> Result<u64>

Returns the total uptime of the server in seconds
source§

fn submit_block(&self, block: &Block) -> Result<()>

Submit a block
source§

fn submit_block_bytes(&self, block_bytes: &[u8]) -> Result<()>

Submit a raw block
source§

fn submit_block_hex(&self, block_hex: &str) -> Result<()>

Submit a block as a hex string
source§

fn scan_tx_out_set_blocking( &self, descriptors: &[ScanTxOutRequest] ) -> Result<ScanTxOutResult>

Auto Trait Implementations§

§

impl !RefUnwindSafe for Client

§

impl Send for Client

§

impl Sync for Client

§

impl Unpin for Client

§

impl !UnwindSafe for Client

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere 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, U> TryFrom<U> for Twhere U: Into<T>,

§

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 Twhere U: TryFrom<T>,

§

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.
§

impl<V, T> VZip<V> for Twhere V: MultiLane<T>,

§

fn vzip(self) -> V