diff options
| author | omagdy <omar.professional8777@gmail.com> | 2025-07-23 03:06:26 +0300 |
|---|---|---|
| committer | omagdy <omar.professional8777@gmail.com> | 2025-07-23 03:06:26 +0300 |
| commit | 089ed7f549eaf82fb7bc3c46616b19615c55d72a (patch) | |
| tree | df0e4eeed7f8cb069b5adacd0dfa88f67d10bcf0 /src/lib.rs | |
| parent | 21a90f12690729f3f4aaca64d413e9e5d8dc0bd4 (diff) | |
| download | redis-rust-089ed7f549eaf82fb7bc3c46616b19615c55d72a.tar.xz redis-rust-089ed7f549eaf82fb7bc3c46616b19615c55d72a.zip | |
feat: Added second step in the handshake process
Diffstat (limited to 'src/lib.rs')
| -rw-r--r-- | src/lib.rs | 31 |
1 files changed, 27 insertions, 4 deletions
@@ -5,6 +5,8 @@ use std::{ net::{TcpListener, TcpStream}, }; +use crate::resp_parser::parse; + #[macro_use] pub mod macros; pub mod rdb; @@ -50,17 +52,38 @@ fn handshake_process(slave: &RedisServer) -> Result<(), String> { // PING match TcpStream::connect(master_address) { Ok(mut stream) => { + let mut buffer = [0; 512]; + + // PING if let Err(e) = stream.write_all(&resp_bytes!(array => [resp!(bulk "PING")])) { return Err(format!("Failed to send: {}", e)); - } else { - Ok(()) } + + let _ = match stream.read(&mut buffer) { + Ok(0) => return Ok(()), // connection closed + Ok(n) => n, + Err(_) => return Ok(()), // error occurred + }; + + // REPLCONF + if let Err(e) = stream.write_all(&resp_bytes!(array => [resp!(bulk "REPLCONF"), resp!(bulk "listening-port"), resp!(bulk slave.port.clone())])) { + return Err(format!("Failed to send: {}", e)); + } + + let _ = match stream.read(&mut buffer) { + Ok(0) => return Ok(()), // connection closed + Ok(n) => n, + Err(_) => return Ok(()), // error occurred + }; + + if let Err(e) = stream.write_all(&resp_bytes!(array => [resp!(bulk "REPLCONF"), resp!(bulk "capa"), resp!(bulk "psync2")])) { + return Err(format!("Failed to send: {}", e)); + } + Ok(()) } Err(e) => Err(format!("Master node doesn't exists: {}", e)), } - // REPLCONF - // PSYNC } |
