rust-nex/rnex-core/src/reggie.rs

61 lines
1.4 KiB
Rust
Raw Normal View History

use std::io;
use std::net::SocketAddrV4;
use macros::{method_id, rmc_proto, RmcSerialize};
use tokio::io::{AsyncRead, AsyncReadExt, AsyncWrite, AsyncWriteExt};
use crate::define_rmc_proto;
2025-09-21 15:59:27 +02:00
use rnex_core::rmc::response::ErrorCode;
use crate::rmc::structures::RmcSerialize;
pub trait UnitPacketRead: AsyncRead + Unpin{
async fn read_buffer(&mut self) -> Result<Vec<u8>, 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<T: AsyncRead + Unpin> 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<T: AsyncWrite + Unpin> UnitPacketWrite for T{}
#[rmc_proto(1)]
2025-07-30 21:39:54 +02:00
pub trait EdgeNodeManagement {
#[method_id(1)]
async fn get_url(&self, seed: u64) -> Result<SocketAddrV4, ErrorCode>;
}
define_rmc_proto!(
2025-07-30 21:39:54 +02:00
proto EdgeNodeHolder{
EdgeNodeManagement
}
);
2025-07-30 21:39:54 +02:00
#[derive(RmcSerialize, Debug)]
2025-06-29 12:01:31 +02:00
#[repr(u32)]
2025-07-30 21:39:54 +02:00
pub enum EdgeNodeHolderConnectOption{
DontRegister = 0,
Register(SocketAddrV4) = 1
2025-06-29 12:01:31 +02:00
}