mirror of
https://github.com/hinto-janai/cuprate.git
synced 2025-01-10 04:44:50 +00:00
Compare commits
No commits in common. "bf07f2c84c196e46849c921fc0302692f751e8f6" and "e2f25bd52decba7716ddd588030f0caf6079ec47" have entirely different histories.
bf07f2c84c
...
e2f25bd52d
14 changed files with 46 additions and 264 deletions
|
@ -69,48 +69,25 @@ pub enum BlockchainManagerRequest {
|
||||||
seed_hash: [u8; 32],
|
seed_hash: [u8; 32],
|
||||||
},
|
},
|
||||||
|
|
||||||
/// Add auxirilly proof-of-work to a block.
|
/// TODO
|
||||||
///
|
|
||||||
/// From the RPC `add_aux_pow` usecase's documentation:
|
|
||||||
/// ````
|
|
||||||
/// This enables merge mining with Monero without requiring
|
|
||||||
/// software that manually alters the extra field in the coinbase
|
|
||||||
/// tx to include the merkle root of the aux blocks.
|
|
||||||
/// ````
|
|
||||||
AddAuxPow {
|
AddAuxPow {
|
||||||
/// The block template to add to.
|
/// TODO
|
||||||
block_template: Block,
|
blocktemplate_blob: Vec<u8>,
|
||||||
/// The auxirilly proof-of-work to add.
|
/// TODO
|
||||||
aux_pow: Vec<AuxPow>,
|
aux_pow: Vec<AuxPow>,
|
||||||
},
|
},
|
||||||
|
|
||||||
/// Generate new blocks.
|
/// TODO
|
||||||
///
|
|
||||||
/// This request is only for regtest, see RPC's `generateblocks`.
|
|
||||||
GenerateBlocks {
|
GenerateBlocks {
|
||||||
/// Number of the blocks to be generated.
|
/// TODO
|
||||||
amount_of_blocks: u64,
|
amount_of_blocks: u64,
|
||||||
/// The previous block's hash.
|
/// TODO
|
||||||
prev_block: [u8; 32],
|
prev_block: [u8; 32],
|
||||||
/// The starting value for the nonce.
|
/// TODO
|
||||||
starting_nonce: u32,
|
starting_nonce: u32,
|
||||||
/// The address that will receive the coinbase reward.
|
/// TODO
|
||||||
wallet_address: String,
|
wallet_address: String,
|
||||||
},
|
},
|
||||||
|
|
||||||
/// Get a visual [`String`] overview of blockchain progress.
|
|
||||||
///
|
|
||||||
/// This is a highly implementation specific format used by
|
|
||||||
/// `monerod` in the `sync_info` RPC call's `overview` field;
|
|
||||||
/// it is essentially an ASCII visual of blocks.
|
|
||||||
///
|
|
||||||
/// See also:
|
|
||||||
/// - <https://www.getmonero.org/resources/developer-guides/daemon-rpc.html#sync_info>
|
|
||||||
/// - <https://github.com/monero-project/monero/blob/master/src/cryptonote_protocol/block_queue.cpp#L178>
|
|
||||||
Overview {
|
|
||||||
/// TODO: the current blockchain height? do we need to pass this?
|
|
||||||
height: usize,
|
|
||||||
},
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// TODO: use real type when public.
|
/// TODO: use real type when public.
|
||||||
|
@ -152,14 +129,11 @@ pub enum BlockchainManagerResponse {
|
||||||
|
|
||||||
/// Response to [`BlockchainManagerRequest::GenerateBlocks`]
|
/// Response to [`BlockchainManagerRequest::GenerateBlocks`]
|
||||||
GenerateBlocks {
|
GenerateBlocks {
|
||||||
/// Hashes of the blocks generated.
|
/// TODO
|
||||||
blocks: Vec<[u8; 32]>,
|
blocks: Vec<[u8; 32]>,
|
||||||
/// The new top height. (TODO: is this correct?)
|
/// TODO
|
||||||
height: usize,
|
height: usize,
|
||||||
},
|
},
|
||||||
|
|
||||||
/// Response to [`BlockchainManagerRequest::Overview`]
|
|
||||||
Overview(String),
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// TODO: use real type when public.
|
/// TODO: use real type when public.
|
||||||
|
|
|
@ -41,8 +41,8 @@ use cuprate_rpc_types::{
|
||||||
SyncInfoResponse,
|
SyncInfoResponse,
|
||||||
},
|
},
|
||||||
misc::{
|
misc::{
|
||||||
AuxPow, BlockHeader, ChainInfo, GetBan, GetMinerDataTxBacklogEntry, HardforkEntry,
|
AuxPow, BlockHeader, ChainInfo, GetBan, HardforkEntry, HistogramEntry, Status,
|
||||||
HistogramEntry, Status, SyncInfoPeer, TxBacklogEntry,
|
TxBacklogEntry,
|
||||||
},
|
},
|
||||||
CORE_RPC_VERSION,
|
CORE_RPC_VERSION,
|
||||||
};
|
};
|
||||||
|
@ -758,39 +758,17 @@ async fn relay_tx(
|
||||||
|
|
||||||
/// <https://github.com/monero-project/monero/blob/cc73fe71162d564ffda8e549b79a350bca53c454/src/rpc/core_rpc_server.cpp#L3306-L3330>
|
/// <https://github.com/monero-project/monero/blob/cc73fe71162d564ffda8e549b79a350bca53c454/src/rpc/core_rpc_server.cpp#L3306-L3330>
|
||||||
async fn sync_info(
|
async fn sync_info(
|
||||||
mut state: CupratedRpcHandler,
|
state: CupratedRpcHandler,
|
||||||
request: SyncInfoRequest,
|
request: SyncInfoRequest,
|
||||||
) -> Result<SyncInfoResponse, Error> {
|
) -> Result<SyncInfoResponse, Error> {
|
||||||
let height = usize_to_u64(
|
|
||||||
blockchain_context::context(&mut state.blockchain_context)
|
|
||||||
.await?
|
|
||||||
.unchecked_blockchain_context()
|
|
||||||
.chain_height,
|
|
||||||
);
|
|
||||||
|
|
||||||
let target_height = blockchain_manager::target_height(&mut state.blockchain_manager).await?;
|
|
||||||
|
|
||||||
let peers = address_book::connection_info::<ClearNet>(&mut DummyAddressBook)
|
|
||||||
.await?
|
|
||||||
.into_iter()
|
|
||||||
.map(|info| SyncInfoPeer { info })
|
|
||||||
.collect();
|
|
||||||
|
|
||||||
let next_needed_pruning_seed =
|
|
||||||
address_book::next_needed_pruning_seed::<ClearNet>(&mut DummyAddressBook)
|
|
||||||
.await?
|
|
||||||
.compress();
|
|
||||||
let overview = blockchain_manager::overview(&mut state.blockchain_manager, height).await?;
|
|
||||||
let spans = address_book::spans::<ClearNet>(&mut DummyAddressBook).await?;
|
|
||||||
|
|
||||||
Ok(SyncInfoResponse {
|
Ok(SyncInfoResponse {
|
||||||
base: AccessResponseBase::OK,
|
base: AccessResponseBase::OK,
|
||||||
height,
|
height: todo!(),
|
||||||
next_needed_pruning_seed,
|
next_needed_pruning_seed: todo!(),
|
||||||
overview,
|
overview: todo!(),
|
||||||
peers,
|
peers: todo!(),
|
||||||
spans,
|
spans: todo!(),
|
||||||
target_height,
|
target_height: todo!(),
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -817,38 +795,19 @@ async fn get_transaction_pool_backlog(
|
||||||
|
|
||||||
/// <https://github.com/monero-project/monero/blob/cc73fe71162d564ffda8e549b79a350bca53c454/src/rpc/core_rpc_server.cpp#L1998-L2033>
|
/// <https://github.com/monero-project/monero/blob/cc73fe71162d564ffda8e549b79a350bca53c454/src/rpc/core_rpc_server.cpp#L1998-L2033>
|
||||||
async fn get_miner_data(
|
async fn get_miner_data(
|
||||||
mut state: CupratedRpcHandler,
|
state: CupratedRpcHandler,
|
||||||
request: GetMinerDataRequest,
|
request: GetMinerDataRequest,
|
||||||
) -> Result<GetMinerDataResponse, Error> {
|
) -> Result<GetMinerDataResponse, Error> {
|
||||||
let context = blockchain_context::context(&mut state.blockchain_context).await?;
|
|
||||||
let context = context.unchecked_blockchain_context();
|
|
||||||
let major_version = context.current_hf.as_u8();
|
|
||||||
let height = usize_to_u64(context.chain_height);
|
|
||||||
let prev_id = hex::encode(context.top_hash);
|
|
||||||
let seed_hash = todo!();
|
|
||||||
let difficulty = format!("{:#x}", context.next_difficulty);
|
|
||||||
let median_weight = usize_to_u64(context.median_weight_for_block_reward);
|
|
||||||
let already_generated_coins = context.already_generated_coins;
|
|
||||||
let tx_backlog = txpool::block_template_backlog(&mut state.txpool_read)
|
|
||||||
.await?
|
|
||||||
.into_iter()
|
|
||||||
.map(|entry| GetMinerDataTxBacklogEntry {
|
|
||||||
id: hex::encode(entry.id),
|
|
||||||
weight: entry.weight,
|
|
||||||
fee: entry.fee,
|
|
||||||
})
|
|
||||||
.collect();
|
|
||||||
|
|
||||||
Ok(GetMinerDataResponse {
|
Ok(GetMinerDataResponse {
|
||||||
base: ResponseBase::OK,
|
base: ResponseBase::OK,
|
||||||
major_version,
|
major_version: todo!(),
|
||||||
height,
|
height: todo!(),
|
||||||
prev_id,
|
prev_id: todo!(),
|
||||||
seed_hash,
|
seed_hash: todo!(),
|
||||||
difficulty,
|
difficulty: todo!(),
|
||||||
median_weight,
|
median_weight: todo!(),
|
||||||
already_generated_coins,
|
already_generated_coins: todo!(),
|
||||||
tx_backlog,
|
tx_backlog: todo!(),
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -910,9 +869,7 @@ async fn add_aux_pow(
|
||||||
mut state: CupratedRpcHandler,
|
mut state: CupratedRpcHandler,
|
||||||
request: AddAuxPowRequest,
|
request: AddAuxPowRequest,
|
||||||
) -> Result<AddAuxPowResponse, Error> {
|
) -> Result<AddAuxPowResponse, Error> {
|
||||||
let hex = hex::decode(request.blocktemplate_blob)?;
|
let blocktemplate_blob = hex::decode(request.blocktemplate_blob)?;
|
||||||
let block_template = Block::read(&mut hex.as_slice())?;
|
|
||||||
|
|
||||||
let aux_pow = request
|
let aux_pow = request
|
||||||
.aux_pow
|
.aux_pow
|
||||||
.into_iter()
|
.into_iter()
|
||||||
|
@ -924,7 +881,7 @@ async fn add_aux_pow(
|
||||||
.collect::<Result<Vec<_>, Error>>()?;
|
.collect::<Result<Vec<_>, Error>>()?;
|
||||||
|
|
||||||
let resp =
|
let resp =
|
||||||
blockchain_manager::add_aux_pow(&mut state.blockchain_manager, block_template, aux_pow)
|
blockchain_manager::add_aux_pow(&mut state.blockchain_manager, blocktemplate_blob, aux_pow)
|
||||||
.await?;
|
.await?;
|
||||||
|
|
||||||
let blocktemplate_blob = hex::encode(resp.blocktemplate_blob);
|
let blocktemplate_blob = hex::encode(resp.blocktemplate_blob);
|
||||||
|
|
|
@ -3,8 +3,7 @@
|
||||||
use std::convert::Infallible;
|
use std::convert::Infallible;
|
||||||
|
|
||||||
use anyhow::{anyhow, Error};
|
use anyhow::{anyhow, Error};
|
||||||
use cuprate_pruning::PruningSeed;
|
use cuprate_rpc_types::misc::ConnectionInfo;
|
||||||
use cuprate_rpc_types::misc::{ConnectionInfo, Span};
|
|
||||||
use tower::ServiceExt;
|
use tower::ServiceExt;
|
||||||
|
|
||||||
use cuprate_helper::cast::usize_to_u64;
|
use cuprate_helper::cast::usize_to_u64;
|
||||||
|
@ -157,53 +156,3 @@ pub(crate) async fn get_bans<Z: NetworkZone>(
|
||||||
|
|
||||||
Ok(bans)
|
Ok(bans)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// [`AddressBookRequest::Spans`]
|
|
||||||
pub(crate) async fn spans<Z: NetworkZone>(
|
|
||||||
address_book: &mut impl AddressBook<Z>,
|
|
||||||
) -> Result<Vec<Span>, Error> {
|
|
||||||
let AddressBookResponse::Spans(vec) = address_book
|
|
||||||
.ready()
|
|
||||||
.await
|
|
||||||
.map_err(|e| anyhow!(e))?
|
|
||||||
.call(AddressBookRequest::Spans)
|
|
||||||
.await
|
|
||||||
.map_err(|e| anyhow!(e))?
|
|
||||||
else {
|
|
||||||
unreachable!();
|
|
||||||
};
|
|
||||||
|
|
||||||
// FIXME: impl this map somewhere instead of inline.
|
|
||||||
let vec = vec
|
|
||||||
.into_iter()
|
|
||||||
.map(|span| Span {
|
|
||||||
connection_id: span.connection_id,
|
|
||||||
nblocks: span.nblocks,
|
|
||||||
rate: span.rate,
|
|
||||||
remote_address: span.remote_address,
|
|
||||||
size: span.size,
|
|
||||||
speed: span.speed,
|
|
||||||
start_block_height: span.start_block_height,
|
|
||||||
})
|
|
||||||
.collect();
|
|
||||||
|
|
||||||
Ok(vec)
|
|
||||||
}
|
|
||||||
|
|
||||||
/// [`AddressBookRequest::NextNeededPruningSeed`]
|
|
||||||
pub(crate) async fn next_needed_pruning_seed<Z: NetworkZone>(
|
|
||||||
address_book: &mut impl AddressBook<Z>,
|
|
||||||
) -> Result<PruningSeed, Error> {
|
|
||||||
let AddressBookResponse::NextNeededPruningSeed(seed) = address_book
|
|
||||||
.ready()
|
|
||||||
.await
|
|
||||||
.map_err(|e| anyhow!(e))?
|
|
||||||
.call(AddressBookRequest::NextNeededPruningSeed)
|
|
||||||
.await
|
|
||||||
.map_err(|e| anyhow!(e))?
|
|
||||||
else {
|
|
||||||
unreachable!();
|
|
||||||
};
|
|
||||||
|
|
||||||
Ok(seed)
|
|
||||||
}
|
|
||||||
|
|
|
@ -15,9 +15,9 @@ use cuprate_types::{FeeEstimate, HardFork, HardForkInfo};
|
||||||
|
|
||||||
/// [`BlockChainContextRequest::Context`].
|
/// [`BlockChainContextRequest::Context`].
|
||||||
pub(crate) async fn context(
|
pub(crate) async fn context(
|
||||||
blockchain_context: &mut BlockChainContextService,
|
service: &mut BlockChainContextService,
|
||||||
) -> Result<BlockChainContext, Error> {
|
) -> Result<BlockChainContext, Error> {
|
||||||
let BlockChainContextResponse::Context(context) = blockchain_context
|
let BlockChainContextResponse::Context(context) = service
|
||||||
.ready()
|
.ready()
|
||||||
.await
|
.await
|
||||||
.map_err(|e| anyhow!(e))?
|
.map_err(|e| anyhow!(e))?
|
||||||
|
@ -33,10 +33,10 @@ pub(crate) async fn context(
|
||||||
|
|
||||||
/// [`BlockChainContextRequest::HardForkInfo`].
|
/// [`BlockChainContextRequest::HardForkInfo`].
|
||||||
pub(crate) async fn hard_fork_info(
|
pub(crate) async fn hard_fork_info(
|
||||||
blockchain_context: &mut BlockChainContextService,
|
service: &mut BlockChainContextService,
|
||||||
hard_fork: HardFork,
|
hard_fork: HardFork,
|
||||||
) -> Result<HardForkInfo, Error> {
|
) -> Result<HardForkInfo, Error> {
|
||||||
let BlockChainContextResponse::HardForkInfo(hf_info) = blockchain_context
|
let BlockChainContextResponse::HardForkInfo(hf_info) = service
|
||||||
.ready()
|
.ready()
|
||||||
.await
|
.await
|
||||||
.map_err(|e| anyhow!(e))?
|
.map_err(|e| anyhow!(e))?
|
||||||
|
@ -52,10 +52,10 @@ pub(crate) async fn hard_fork_info(
|
||||||
|
|
||||||
/// [`BlockChainContextRequest::FeeEstimate`].
|
/// [`BlockChainContextRequest::FeeEstimate`].
|
||||||
pub(crate) async fn fee_estimate(
|
pub(crate) async fn fee_estimate(
|
||||||
blockchain_context: &mut BlockChainContextService,
|
service: &mut BlockChainContextService,
|
||||||
grace_blocks: u64,
|
grace_blocks: u64,
|
||||||
) -> Result<FeeEstimate, Error> {
|
) -> Result<FeeEstimate, Error> {
|
||||||
let BlockChainContextResponse::FeeEstimate(fee) = blockchain_context
|
let BlockChainContextResponse::FeeEstimate(fee) = service
|
||||||
.ready()
|
.ready()
|
||||||
.await
|
.await
|
||||||
.map_err(|e| anyhow!(e))?
|
.map_err(|e| anyhow!(e))?
|
||||||
|
|
|
@ -172,14 +172,14 @@ pub(crate) async fn calculate_pow(
|
||||||
/// [`BlockchainManagerRequest::AddAuxPow`]
|
/// [`BlockchainManagerRequest::AddAuxPow`]
|
||||||
pub(crate) async fn add_aux_pow(
|
pub(crate) async fn add_aux_pow(
|
||||||
blockchain_manager: &mut BlockchainManagerHandle,
|
blockchain_manager: &mut BlockchainManagerHandle,
|
||||||
block_template: Block,
|
blocktemplate_blob: Vec<u8>,
|
||||||
aux_pow: Vec<AuxPow>,
|
aux_pow: Vec<AuxPow>,
|
||||||
) -> Result<AddAuxPow, Error> {
|
) -> Result<AddAuxPow, Error> {
|
||||||
let BlockchainManagerResponse::AddAuxPow(response) = blockchain_manager
|
let BlockchainManagerResponse::AddAuxPow(response) = blockchain_manager
|
||||||
.ready()
|
.ready()
|
||||||
.await?
|
.await?
|
||||||
.call(BlockchainManagerRequest::AddAuxPow {
|
.call(BlockchainManagerRequest::AddAuxPow {
|
||||||
block_template,
|
blocktemplate_blob,
|
||||||
aux_pow,
|
aux_pow,
|
||||||
})
|
})
|
||||||
.await?
|
.await?
|
||||||
|
@ -214,22 +214,3 @@ pub(crate) async fn generate_blocks(
|
||||||
|
|
||||||
Ok((blocks, usize_to_u64(height)))
|
Ok((blocks, usize_to_u64(height)))
|
||||||
}
|
}
|
||||||
|
|
||||||
/// [`BlockchainManagerRequest::Overview`]
|
|
||||||
pub(crate) async fn overview(
|
|
||||||
blockchain_manager: &mut BlockchainManagerHandle,
|
|
||||||
height: u64,
|
|
||||||
) -> Result<String, Error> {
|
|
||||||
let BlockchainManagerResponse::Overview(overview) = blockchain_manager
|
|
||||||
.ready()
|
|
||||||
.await?
|
|
||||||
.call(BlockchainManagerRequest::Overview {
|
|
||||||
height: u64_to_usize(height),
|
|
||||||
})
|
|
||||||
.await?
|
|
||||||
else {
|
|
||||||
unreachable!();
|
|
||||||
};
|
|
||||||
|
|
||||||
Ok(overview)
|
|
||||||
}
|
|
||||||
|
|
|
@ -11,7 +11,7 @@ use cuprate_txpool::{
|
||||||
interface::{TxpoolReadRequest, TxpoolReadResponse},
|
interface::{TxpoolReadRequest, TxpoolReadResponse},
|
||||||
TxpoolReadHandle,
|
TxpoolReadHandle,
|
||||||
},
|
},
|
||||||
BlockTemplateTxEntry, TxEntry,
|
TxEntry,
|
||||||
};
|
};
|
||||||
|
|
||||||
// FIXME: use `anyhow::Error` over `tower::BoxError` in txpool.
|
// FIXME: use `anyhow::Error` over `tower::BoxError` in txpool.
|
||||||
|
@ -32,24 +32,6 @@ pub(crate) async fn backlog(txpool_read: &mut TxpoolReadHandle) -> Result<Vec<Tx
|
||||||
Ok(tx_entries)
|
Ok(tx_entries)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// [`TxpoolReadRequest::BlockTemplateBacklog`]
|
|
||||||
pub(crate) async fn block_template_backlog(
|
|
||||||
txpool_read: &mut TxpoolReadHandle,
|
|
||||||
) -> Result<Vec<BlockTemplateTxEntry>, Error> {
|
|
||||||
let TxpoolReadResponse::BlockTemplateBacklog(tx_entries) = txpool_read
|
|
||||||
.ready()
|
|
||||||
.await
|
|
||||||
.map_err(|e| anyhow!(e))?
|
|
||||||
.call(TxpoolReadRequest::BlockTemplateBacklog)
|
|
||||||
.await
|
|
||||||
.map_err(|e| anyhow!(e))?
|
|
||||||
else {
|
|
||||||
unreachable!();
|
|
||||||
};
|
|
||||||
|
|
||||||
Ok(tx_entries)
|
|
||||||
}
|
|
||||||
|
|
||||||
/// [`TxpoolReadRequest::Size`]
|
/// [`TxpoolReadRequest::Size`]
|
||||||
pub(crate) async fn size(
|
pub(crate) async fn size(
|
||||||
txpool_read: &mut TxpoolReadHandle,
|
txpool_read: &mut TxpoolReadHandle,
|
||||||
|
|
|
@ -424,9 +424,7 @@ impl<Z: BorshNetworkZone> Service<AddressBookRequest<Z>> for AddressBook<Z> {
|
||||||
| AddressBookRequest::ConnectionCount
|
| AddressBookRequest::ConnectionCount
|
||||||
| AddressBookRequest::SetBan(_)
|
| AddressBookRequest::SetBan(_)
|
||||||
| AddressBookRequest::GetBans
|
| AddressBookRequest::GetBans
|
||||||
| AddressBookRequest::ConnectionInfo
|
| AddressBookRequest::ConnectionInfo => {
|
||||||
| AddressBookRequest::NextNeededPruningSeed
|
|
||||||
| AddressBookRequest::Spans => {
|
|
||||||
todo!("finish https://github.com/Cuprate/cuprate/pull/297")
|
todo!("finish https://github.com/Cuprate/cuprate/pull/297")
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -112,9 +112,7 @@ impl<N: NetworkZone> Service<AddressBookRequest<N>> for DummyAddressBook {
|
||||||
| AddressBookRequest::ConnectionCount
|
| AddressBookRequest::ConnectionCount
|
||||||
| AddressBookRequest::SetBan(_)
|
| AddressBookRequest::SetBan(_)
|
||||||
| AddressBookRequest::GetBans
|
| AddressBookRequest::GetBans
|
||||||
| AddressBookRequest::ConnectionInfo
|
| AddressBookRequest::ConnectionInfo => {
|
||||||
| AddressBookRequest::NextNeededPruningSeed
|
|
||||||
| AddressBookRequest::Spans => {
|
|
||||||
todo!("finish https://github.com/Cuprate/cuprate/pull/297")
|
todo!("finish https://github.com/Cuprate/cuprate/pull/297")
|
||||||
}
|
}
|
||||||
}))
|
}))
|
||||||
|
|
|
@ -6,7 +6,7 @@ use cuprate_wire::{CoreSyncData, PeerListEntryBase};
|
||||||
use crate::{
|
use crate::{
|
||||||
client::InternalPeerID,
|
client::InternalPeerID,
|
||||||
handles::ConnectionHandle,
|
handles::ConnectionHandle,
|
||||||
types::{BanState, ConnectionInfo, SetBan, Span},
|
types::{BanState, ConnectionInfo, SetBan},
|
||||||
NetZoneAddress, NetworkAddressIncorrectZone, NetworkZone,
|
NetZoneAddress, NetworkAddressIncorrectZone, NetworkZone,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -132,12 +132,6 @@ pub enum AddressBookRequest<Z: NetworkZone> {
|
||||||
|
|
||||||
/// Get the state of all bans.
|
/// Get the state of all bans.
|
||||||
GetBans,
|
GetBans,
|
||||||
|
|
||||||
/// TODO
|
|
||||||
Spans,
|
|
||||||
|
|
||||||
/// TODO
|
|
||||||
NextNeededPruningSeed,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// A response from the address book service.
|
/// A response from the address book service.
|
||||||
|
@ -175,10 +169,4 @@ pub enum AddressBookResponse<Z: NetworkZone> {
|
||||||
|
|
||||||
/// Response to [`AddressBookRequest::GetBans`].
|
/// Response to [`AddressBookRequest::GetBans`].
|
||||||
GetBans(Vec<BanState<Z::Addr>>),
|
GetBans(Vec<BanState<Z::Addr>>),
|
||||||
|
|
||||||
/// Response to [`AddressBookRequest::Spans`].
|
|
||||||
Spans(Vec<Span>),
|
|
||||||
|
|
||||||
/// Response to [`AddressBookRequest::NextNeededPruningSeed`].
|
|
||||||
NextNeededPruningSeed(PruningSeed),
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -52,17 +52,3 @@ pub struct ConnectionInfo<A: NetZoneAddress> {
|
||||||
pub state: String,
|
pub state: String,
|
||||||
pub support_flags: u32,
|
pub support_flags: u32,
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Used in RPC's `sync_info`.
|
|
||||||
///
|
|
||||||
/// Data within [`crate::services::AddressBookResponse::Spans`].
|
|
||||||
#[derive(Clone, Debug, Default, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
|
||||||
pub struct Span {
|
|
||||||
pub connection_id: String,
|
|
||||||
pub nblocks: u64,
|
|
||||||
pub rate: u32,
|
|
||||||
pub remote_address: String,
|
|
||||||
pub size: u64,
|
|
||||||
pub speed: u32,
|
|
||||||
pub start_block_height: u64,
|
|
||||||
}
|
|
||||||
|
|
|
@ -15,7 +15,7 @@ pub mod types;
|
||||||
|
|
||||||
pub use config::Config;
|
pub use config::Config;
|
||||||
pub use free::open;
|
pub use free::open;
|
||||||
pub use tx::{BlockTemplateTxEntry, TxEntry};
|
pub use tx::TxEntry;
|
||||||
|
|
||||||
//re-exports
|
//re-exports
|
||||||
pub use cuprate_database;
|
pub use cuprate_database;
|
||||||
|
|
|
@ -5,10 +5,7 @@ use std::sync::Arc;
|
||||||
|
|
||||||
use cuprate_types::TransactionVerificationData;
|
use cuprate_types::TransactionVerificationData;
|
||||||
|
|
||||||
use crate::{
|
use crate::{tx::TxEntry, types::TransactionHash};
|
||||||
tx::{BlockTemplateTxEntry, TxEntry},
|
|
||||||
types::TransactionHash,
|
|
||||||
};
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------- TxpoolReadRequest
|
//---------------------------------------------------------------------------------------------------- TxpoolReadRequest
|
||||||
/// The transaction pool [`tower::Service`] read request type.
|
/// The transaction pool [`tower::Service`] read request type.
|
||||||
|
@ -22,9 +19,6 @@ pub enum TxpoolReadRequest {
|
||||||
/// Get information on all transactions in the pool.
|
/// Get information on all transactions in the pool.
|
||||||
Backlog,
|
Backlog,
|
||||||
|
|
||||||
/// TODO
|
|
||||||
BlockTemplateBacklog,
|
|
||||||
|
|
||||||
/// Get the number of transactions in the pool.
|
/// Get the number of transactions in the pool.
|
||||||
Size {
|
Size {
|
||||||
/// TODO
|
/// TODO
|
||||||
|
@ -51,11 +45,6 @@ pub enum TxpoolReadResponse {
|
||||||
/// the transactions currently in the pool.
|
/// the transactions currently in the pool.
|
||||||
Backlog(Vec<TxEntry>),
|
Backlog(Vec<TxEntry>),
|
||||||
|
|
||||||
/// Response to [`TxpoolReadRequest::BlockTemplateBacklog`].
|
|
||||||
///
|
|
||||||
/// TODO
|
|
||||||
BlockTemplateBacklog(Vec<BlockTemplateTxEntry>),
|
|
||||||
|
|
||||||
/// Response to [`TxpoolReadRequest::Size`].
|
/// Response to [`TxpoolReadRequest::Size`].
|
||||||
///
|
///
|
||||||
/// The inner value is the amount of
|
/// The inner value is the amount of
|
||||||
|
|
|
@ -66,7 +66,6 @@ fn map_request(
|
||||||
TxpoolReadRequest::TxBlob(tx_hash) => tx_blob(env, &tx_hash),
|
TxpoolReadRequest::TxBlob(tx_hash) => tx_blob(env, &tx_hash),
|
||||||
TxpoolReadRequest::TxVerificationData(tx_hash) => tx_verification_data(env, &tx_hash),
|
TxpoolReadRequest::TxVerificationData(tx_hash) => tx_verification_data(env, &tx_hash),
|
||||||
TxpoolReadRequest::Backlog => backlog(env),
|
TxpoolReadRequest::Backlog => backlog(env),
|
||||||
TxpoolReadRequest::BlockTemplateBacklog => block_template_backlog(env),
|
|
||||||
TxpoolReadRequest::Size {
|
TxpoolReadRequest::Size {
|
||||||
include_sensitive_txs,
|
include_sensitive_txs,
|
||||||
} => size(env, include_sensitive_txs),
|
} => size(env, include_sensitive_txs),
|
||||||
|
@ -120,12 +119,6 @@ fn backlog(env: &ConcreteEnv) -> ReadResponseResult {
|
||||||
Ok(TxpoolReadResponse::Backlog(todo!()))
|
Ok(TxpoolReadResponse::Backlog(todo!()))
|
||||||
}
|
}
|
||||||
|
|
||||||
/// [`TxpoolReadRequest::BlockTemplateBacklog`].
|
|
||||||
#[inline]
|
|
||||||
fn block_template_backlog(env: &ConcreteEnv) -> ReadResponseResult {
|
|
||||||
Ok(TxpoolReadResponse::BlockTemplateBacklog(todo!()))
|
|
||||||
}
|
|
||||||
|
|
||||||
/// [`TxpoolReadRequest::Size`].
|
/// [`TxpoolReadRequest::Size`].
|
||||||
#[inline]
|
#[inline]
|
||||||
fn size(env: &ConcreteEnv, include_sensitive_txs: bool) -> ReadResponseResult {
|
fn size(env: &ConcreteEnv, include_sensitive_txs: bool) -> ReadResponseResult {
|
||||||
|
|
|
@ -12,16 +12,3 @@ pub struct TxEntry {
|
||||||
/// How long the transaction has been in the pool.
|
/// How long the transaction has been in the pool.
|
||||||
pub time_in_pool: std::time::Duration,
|
pub time_in_pool: std::time::Duration,
|
||||||
}
|
}
|
||||||
|
|
||||||
/// TODO
|
|
||||||
///
|
|
||||||
/// Used in [`TxpoolReadResponse::BlockTemplateBacklog`](crate::service::interface::TxpoolReadResponse::BlockTemplateBacklog).
|
|
||||||
#[derive(Copy, Clone, Debug, Ord, PartialOrd, Eq, PartialEq, Hash)]
|
|
||||||
pub struct BlockTemplateTxEntry {
|
|
||||||
/// TODO
|
|
||||||
pub id: [u8; 32],
|
|
||||||
/// TODO
|
|
||||||
pub weight: u64,
|
|
||||||
/// TODO
|
|
||||||
pub fee: u64,
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in a new issue