diff --git a/tuic/src/prototype/authenticate.rs b/tuic/src/prototype/authenticate.rs index 118ee20..ca54f39 100644 --- a/tuic/src/prototype/authenticate.rs +++ b/tuic/src/prototype/authenticate.rs @@ -10,8 +10,6 @@ pub struct Tx { header: Header, } -pub struct Rx; - impl Authenticate { pub(super) fn new(token: [u8; 8]) -> Self { Self { @@ -27,3 +25,21 @@ impl Authenticate { &tx.header } } + +pub struct Rx { + token: [u8; 8], +} + +impl Authenticate { + pub(super) fn new(token: [u8; 8]) -> Self { + Self { + inner: Side::Rx(Rx { token }), + _marker: side::Rx, + } + } + + pub fn token(&self) -> &[u8; 8] { + let Side::Rx(rx) = &self.inner else { unreachable!() }; + &rx.token + } +} diff --git a/tuic/src/prototype/dissociate.rs b/tuic/src/prototype/dissociate.rs index bf7f728..e6e4072 100644 --- a/tuic/src/prototype/dissociate.rs +++ b/tuic/src/prototype/dissociate.rs @@ -10,8 +10,6 @@ pub struct Tx { header: Header, } -pub struct Rx; - impl Dissociate { pub(super) fn new(assoc_id: u16) -> Self { Self { @@ -27,3 +25,21 @@ impl Dissociate { &tx.header } } + +pub struct Rx { + assoc_id: u16, +} + +impl Dissociate { + pub(super) fn new(assoc_id: u16) -> Self { + Self { + inner: Side::Rx(Rx { assoc_id }), + _marker: side::Rx, + } + } + + pub fn assoc_id(&self) -> &u16 { + let Side::Rx(rx) = &self.inner else { unreachable!() }; + &rx.assoc_id + } +} diff --git a/tuic/src/prototype/heartbeat.rs b/tuic/src/prototype/heartbeat.rs index b5b96eb..8fce8b0 100644 --- a/tuic/src/prototype/heartbeat.rs +++ b/tuic/src/prototype/heartbeat.rs @@ -10,8 +10,6 @@ pub struct Tx { header: Header, } -pub struct Rx; - impl Heartbeat { pub(super) fn new() -> Self { Self { @@ -27,3 +25,14 @@ impl Heartbeat { &tx.header } } + +pub struct Rx; + +impl Heartbeat { + pub(super) fn new() -> Self { + Self { + inner: Side::Rx(Rx), + _marker: side::Rx, + } + } +} diff --git a/tuic/src/prototype/mod.rs b/tuic/src/prototype/mod.rs index b79cd7e..358f456 100644 --- a/tuic/src/prototype/mod.rs +++ b/tuic/src/prototype/mod.rs @@ -1,4 +1,7 @@ -use crate::protocol::{Address, Connect as ConnectHeader, Packet as PacketHeader}; +use crate::protocol::{ + Address, Authenticate as AuthenticateHeader, Connect as ConnectHeader, + Dissociate as DissociateHeader, Heartbeat as HeartbeatHeader, Packet as PacketHeader, +}; use parking_lot::Mutex; use std::{ collections::HashMap, @@ -45,7 +48,12 @@ where } pub fn send_authenticate(&self, token: [u8; 8]) -> Authenticate { - Authenticate::new(token) + Authenticate::::new(token) + } + + pub fn recv_authenticate(&self, header: AuthenticateHeader) -> Authenticate { + let (token,) = header.into(); + Authenticate::::new(token) } pub fn send_connect(&self, addr: Address) -> Connect { @@ -82,11 +90,21 @@ where } pub fn send_dissociate(&self, assoc_id: u16) -> Dissociate { - self.udp_sessions.lock().dissociate(assoc_id) + self.udp_sessions.lock().send_dissociate(assoc_id) + } + + pub fn recv_dissociate(&self, header: DissociateHeader) -> Dissociate { + let (assoc_id,) = header.into(); + self.udp_sessions.lock().recv_dissociate(assoc_id) } pub fn send_heartbeat(&self) -> Heartbeat { - Heartbeat::new() + Heartbeat::::new() + } + + pub fn recv_heartbeat(&self, header: HeartbeatHeader) -> Heartbeat { + let () = header.into(); + Heartbeat::::new() } pub fn task_connect_count(&self) -> usize { @@ -174,9 +192,14 @@ where .recv_packet(sessions, assoc_id, pkt_id, frag_total, frag_id, size, addr) } - fn dissociate(&mut self, assoc_id: u16) -> Dissociate { + fn send_dissociate(&mut self, assoc_id: u16) -> Dissociate { self.sessions.remove(&assoc_id); - Dissociate::new(assoc_id) + Dissociate::::new(assoc_id) + } + + fn recv_dissociate(&mut self, assoc_id: u16) -> Dissociate { + self.sessions.remove(&assoc_id); + Dissociate::::new(assoc_id) } fn insert( diff --git a/tuic/src/prototype/packet.rs b/tuic/src/prototype/packet.rs index 5afd443..7b757a8 100644 --- a/tuic/src/prototype/packet.rs +++ b/tuic/src/prototype/packet.rs @@ -18,10 +18,7 @@ pub struct Tx { max_pkt_size: usize, } -impl Packet -where - B: AsRef<[u8]>, -{ +impl Packet { pub(super) fn new(assoc_id: u16, pkt_id: u16, addr: Address, max_pkt_size: usize) -> Self { Self { inner: Side::Tx(Tx {