2024-09-01 20:59:33 +00:00
|
|
|
//! Dummy implementation of [`RpcHandler`].
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------- Use
|
|
|
|
use std::task::Poll;
|
|
|
|
|
|
|
|
use futures::channel::oneshot::channel;
|
|
|
|
use serde::{Deserialize, Serialize};
|
|
|
|
use tower::Service;
|
|
|
|
|
2024-09-02 21:37:18 +00:00
|
|
|
use cuprate_blockchain::service::{BlockchainReadHandle, BlockchainWriteHandle};
|
2024-09-01 20:59:33 +00:00
|
|
|
use cuprate_helper::asynch::InfallibleOneshotReceiver;
|
|
|
|
use cuprate_json_rpc::Id;
|
|
|
|
use cuprate_rpc_interface::{RpcError, RpcHandler, RpcRequest, RpcResponse};
|
2024-09-02 21:37:18 +00:00
|
|
|
use cuprate_txpool::service::{TxpoolReadHandle, TxpoolWriteHandle};
|
|
|
|
|
|
|
|
use crate::rpc::{bin, json, other};
|
2024-09-01 20:59:33 +00:00
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------- CupratedRpcHandler
|
|
|
|
/// TODO
|
|
|
|
#[derive(Clone, Debug, PartialEq, Eq, PartialOrd, Ord, Hash, Deserialize, Serialize)]
|
|
|
|
pub struct CupratedRpcHandler {
|
|
|
|
/// Should this RPC server be [restricted](RpcHandler::restricted)?
|
|
|
|
pub restricted: bool,
|
2024-09-02 21:37:18 +00:00
|
|
|
|
|
|
|
/// Read handle to the blockchain database.
|
|
|
|
pub blockchain_read: BlockchainReadHandle,
|
|
|
|
/// Write handle to the blockchain database.
|
|
|
|
pub blockchain_write: BlockchainWriteHandle,
|
|
|
|
/// Direct handle to the blockchain database.
|
|
|
|
pub blockchain_db: Arc<ConcreteEnv>,
|
|
|
|
|
|
|
|
/// Read handle to the transaction pool database.
|
|
|
|
pub txpool_read: TxpoolReadHandle,
|
|
|
|
/// Write handle to the transaction pool database.
|
|
|
|
pub txpool_write: TxpoolWriteHandle,
|
|
|
|
/// Direct handle to the transaction pool database.
|
|
|
|
pub txpool_db: Arc<ConcreteEnv>,
|
2024-09-01 20:59:33 +00:00
|
|
|
}
|
|
|
|
|
2024-09-02 21:37:18 +00:00
|
|
|
//---------------------------------------------------------------------------------------------------- RpcHandler Impl
|
2024-09-01 20:59:33 +00:00
|
|
|
impl RpcHandler for CupratedRpcHandler {
|
|
|
|
fn restricted(&self) -> bool {
|
|
|
|
self.restricted
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Service<RpcRequest> for CupratedRpcHandler {
|
|
|
|
type Response = RpcResponse;
|
|
|
|
type Error = RpcError;
|
|
|
|
type Future = InfallibleOneshotReceiver<Result<RpcResponse, RpcError>>;
|
|
|
|
|
|
|
|
fn poll_ready(&mut self, _: &mut std::task::Context<'_>) -> Poll<Result<(), Self::Error>> {
|
|
|
|
Poll::Ready(Ok(()))
|
|
|
|
}
|
|
|
|
|
|
|
|
fn call(&mut self, req: RpcRequest) -> Self::Future {
|
|
|
|
use cuprate_rpc_types::bin::BinRequest as BReq;
|
|
|
|
use cuprate_rpc_types::bin::BinResponse as BResp;
|
|
|
|
use cuprate_rpc_types::json::JsonRpcRequest as JReq;
|
|
|
|
use cuprate_rpc_types::json::JsonRpcResponse as JResp;
|
|
|
|
use cuprate_rpc_types::other::OtherRequest as OReq;
|
|
|
|
use cuprate_rpc_types::other::OtherResponse as OResp;
|
|
|
|
|
2024-09-02 21:37:18 +00:00
|
|
|
// INVARIANT:
|
|
|
|
//
|
|
|
|
// We don't need to check for `self.is_restricted()`
|
|
|
|
// here because `cuprate-rpc-interface` handles that.
|
|
|
|
//
|
|
|
|
// We can assume the request coming has the required permissions.
|
2024-09-01 20:59:33 +00:00
|
|
|
|
2024-09-02 21:37:18 +00:00
|
|
|
let state = CupratedRpcHandler::clone(self);
|
2024-09-01 20:59:33 +00:00
|
|
|
|
2024-09-02 21:37:18 +00:00
|
|
|
let resp = match req {
|
|
|
|
RpcRequest::JsonRpc(r) => json::map_request(r), // JSON-RPC 2.0 requests.
|
|
|
|
RpcRequest::Binary(r) => bin::map_request(r), // Binary requests.
|
|
|
|
RpcRequest::Other(o) => other::map_request(r), // JSON (but not JSON-RPC) requests.
|
2024-09-01 20:59:33 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
let (tx, rx) = channel();
|
|
|
|
drop(tx.send(Ok(resp)));
|
|
|
|
InfallibleOneshotReceiver::from(rx)
|
|
|
|
}
|
|
|
|
}
|