2023-07-20 00:28:55 -07:00
|
|
|
use anyhow::Context;
|
|
|
|
use serde::{Deserialize, Serialize};
|
|
|
|
use solana_sdk::pubkey::Pubkey;
|
|
|
|
use solana_sdk::transaction::VersionedTransaction;
|
2023-07-31 05:26:21 -07:00
|
|
|
use std::fmt;
|
|
|
|
use std::fmt::Display;
|
|
|
|
use std::net::SocketAddr;
|
2023-07-20 00:28:55 -07:00
|
|
|
|
|
|
|
///
|
|
|
|
/// lite-rpc to proxy wire format
|
|
|
|
/// compat info: non-public format ATM
|
|
|
|
/// initial version
|
2023-08-02 05:15:39 -07:00
|
|
|
pub const FORMAT_VERSION1: u16 = 2302;
|
2023-07-20 00:28:55 -07:00
|
|
|
|
|
|
|
#[derive(Serialize, Deserialize, Debug, Clone)]
|
|
|
|
pub struct TpuForwardingRequest {
|
|
|
|
format_version: u16,
|
2023-08-08 06:57:09 -07:00
|
|
|
tpu_socket_addr: SocketAddr,
|
|
|
|
identity_tpunode: Pubkey, // note: this is only used for debugging
|
2023-07-24 06:52:56 -07:00
|
|
|
// TODO consider not deserializing transactions in proxy
|
2023-07-20 00:28:55 -07:00
|
|
|
transactions: Vec<VersionedTransaction>,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Display for TpuForwardingRequest {
|
|
|
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
2023-07-31 05:26:21 -07:00
|
|
|
write!(
|
|
|
|
f,
|
|
|
|
"TpuForwardingRequest for tpu target {} with identity {}: payload {} tx",
|
|
|
|
&self.get_tpu_socket_addr(),
|
|
|
|
&self.get_identity_tpunode(),
|
|
|
|
&self.get_transactions().len()
|
|
|
|
)
|
2023-07-20 00:28:55 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl TpuForwardingRequest {
|
2023-07-31 05:26:21 -07:00
|
|
|
pub fn new(
|
|
|
|
tpu_socket_addr: SocketAddr,
|
|
|
|
identity_tpunode: Pubkey,
|
|
|
|
transactions: Vec<VersionedTransaction>,
|
|
|
|
) -> Self {
|
2023-07-20 00:28:55 -07:00
|
|
|
TpuForwardingRequest {
|
|
|
|
format_version: FORMAT_VERSION1,
|
|
|
|
tpu_socket_addr,
|
|
|
|
identity_tpunode,
|
|
|
|
transactions,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-08-08 06:41:29 -07:00
|
|
|
pub fn try_serialize_wire_format(&self) -> anyhow::Result<Vec<u8>> {
|
|
|
|
bincode::serialize(&self)
|
|
|
|
.context("serialize proxy request")
|
|
|
|
.map_err(anyhow::Error::from)
|
2023-08-08 06:30:42 -07:00
|
|
|
}
|
|
|
|
|
2023-08-08 06:41:29 -07:00
|
|
|
pub fn try_deserialize_from_wire_format(
|
|
|
|
raw_proxy_request: &[u8],
|
|
|
|
) -> anyhow::Result<TpuForwardingRequest> {
|
|
|
|
let request = bincode::deserialize::<TpuForwardingRequest>(raw_proxy_request);
|
2023-08-08 06:30:42 -07:00
|
|
|
|
2023-08-08 06:41:29 -07:00
|
|
|
if let Ok(ref req) = request {
|
|
|
|
assert_eq!(req.format_version, FORMAT_VERSION1);
|
|
|
|
}
|
2023-08-08 06:30:42 -07:00
|
|
|
|
|
|
|
request
|
2023-08-08 06:41:29 -07:00
|
|
|
.context("deserialize proxy request")
|
|
|
|
.map_err(anyhow::Error::from)
|
2023-08-08 06:30:42 -07:00
|
|
|
}
|
|
|
|
|
2023-07-20 00:28:55 -07:00
|
|
|
pub fn get_tpu_socket_addr(&self) -> SocketAddr {
|
|
|
|
self.tpu_socket_addr
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn get_identity_tpunode(&self) -> Pubkey {
|
|
|
|
self.identity_tpunode
|
|
|
|
}
|
|
|
|
|
2023-08-08 06:57:09 -07:00
|
|
|
pub fn get_transactions(&self) -> &[VersionedTransaction] {
|
|
|
|
self.transactions.as_slice()
|
2023-07-20 00:28:55 -07:00
|
|
|
}
|
|
|
|
}
|