use crate::define_rmc_proto; use crate::rmc::structures::RmcSerialize; use macros::{RmcSerialize, method_id, rmc_proto}; use rnex_core::rmc::response::ErrorCode; use std::io; use std::net::SocketAddrV4; use tokio::io::{AsyncRead, AsyncReadExt, AsyncWrite, AsyncWriteExt}; pub trait UnitPacketRead: AsyncRead + Unpin { async fn read_buffer(&mut self) -> Result, io::Error> { let mut len_raw: [u8; 4] = [0; 4]; self.read_exact(&mut len_raw).await?; let len = u32::from_le_bytes(len_raw); let mut vec = vec![0u8; len as _]; self.read_exact(&mut vec).await?; Ok(vec) } } impl UnitPacketRead for T {} pub trait UnitPacketWrite: AsyncWrite + Unpin { async fn send_buffer(&mut self, data: &[u8]) -> Result<(), io::Error> { let mut dest_data = Vec::new(); data.serialize(&mut dest_data) .expect("ran out of memory or something"); self.write_all(&dest_data[..]).await?; self.flush().await?; Ok(()) } } impl UnitPacketWrite for T {} #[rmc_proto(1)] pub trait EdgeNodeManagement { #[method_id(1)] async fn get_url(&self, seed: u64) -> Result; } define_rmc_proto!( proto EdgeNodeHolder{ EdgeNodeManagement } ); #[derive(RmcSerialize, Debug)] #[repr(u32)] pub enum EdgeNodeHolderConnectOption { DontRegister = 0, Register(SocketAddrV4) = 1, }