changed to u32

This commit is contained in:
dachus 2023-11-30 11:59:41 -03:00
parent 2b41e82d27
commit bf3190615c
2 changed files with 7 additions and 8 deletions

View File

@ -25,7 +25,7 @@ type HttpSender = tokio::sync::oneshot::Sender<(HttpResponse, Vec<u8>)>;
/// mapping from an open websocket connection to a channel that will ingest /// mapping from an open websocket connection to a channel that will ingest
/// WebSocketPush messages from the app that handles the connection, and /// WebSocketPush messages from the app that handles the connection, and
/// send them to the connection. /// send them to the connection.
type WebSocketSenders = Arc<DashMap<u64, (ProcessId, WebSocketSender)>>; type WebSocketSenders = Arc<DashMap<u32, (ProcessId, WebSocketSender)>>;
type WebSocketSender = tokio::sync::mpsc::Sender<warp::ws::Message>; type WebSocketSender = tokio::sync::mpsc::Sender<warp::ws::Message>;
type PathBindings = Arc<RwLock<Router<BoundPath>>>; type PathBindings = Arc<RwLock<Router<BoundPath>>>;
@ -424,8 +424,7 @@ async fn maintain_websocket(
return; return;
} }
let max_js_safe_integer: u64 = (1u64 << 53) - 1; let ws_channel_id: u32 = rand::random();
let ws_channel_id: u64 = rand::random::<u64>() & max_js_safe_integer;
let (ws_sender, mut ws_receiver) = tokio::sync::mpsc::channel(100); let (ws_sender, mut ws_receiver) = tokio::sync::mpsc::channel(100);
ws_senders.insert(ws_channel_id, (owner_process.clone(), ws_sender)); ws_senders.insert(ws_channel_id, (owner_process.clone(), ws_sender));
@ -510,7 +509,7 @@ async fn maintain_websocket(
} }
async fn websocket_close( async fn websocket_close(
channel_id: u64, channel_id: u32,
process: ProcessId, process: ProcessId,
ws_senders: &WebSocketSenders, ws_senders: &WebSocketSenders,
send_to_loop: &MessageSender, send_to_loop: &MessageSender,

View File

@ -74,17 +74,17 @@ pub enum HttpServerAction {
/// Processes will RECEIVE this kind of request when a client connects to them. /// Processes will RECEIVE this kind of request when a client connects to them.
/// If a process does not want this websocket open, they can respond with an /// If a process does not want this websocket open, they can respond with an
/// [`enum@HttpServerAction::WebSocketClose`] message. /// [`enum@HttpServerAction::WebSocketClose`] message.
WebSocketOpen(u64), WebSocketOpen(u32),
/// Processes can both SEND and RECEIVE this kind of request. /// Processes can both SEND and RECEIVE this kind of request.
/// When sent, expects a payload containing the WebSocket message bytes to send. /// When sent, expects a payload containing the WebSocket message bytes to send.
WebSocketPush { WebSocketPush {
channel_id: u64, channel_id: u32,
message_type: WsMessageType, message_type: WsMessageType,
}, },
/// Processes can both SEND and RECEIVE this kind of request. Sending will /// Processes can both SEND and RECEIVE this kind of request. Sending will
/// close a socket the process controls. Receiving will indicate that the /// close a socket the process controls. Receiving will indicate that the
/// client closed the socket. /// client closed the socket.
WebSocketClose(u64), WebSocketClose(u32),
} }
/// The possible message types for WebSocketPush. Ping and Pong are limited to 125 bytes /// The possible message types for WebSocketPush. Ping and Pong are limited to 125 bytes
@ -129,7 +129,7 @@ pub struct WsRegister {
/// Structure sent from this server to client websocket upon opening a new connection. /// Structure sent from this server to client websocket upon opening a new connection.
#[derive(Clone, Debug, Serialize, Deserialize)] #[derive(Clone, Debug, Serialize, Deserialize)]
pub struct WsRegisterResponse { pub struct WsRegisterResponse {
pub channel_id: u64, pub channel_id: u32,
// TODO symmetric key exchange here // TODO symmetric key exchange here
} }