zzzz
This commit is contained in:
@@ -36,7 +36,7 @@ const LENGTH: usize = 7;
|
||||
const EXTENSIONS: usize = 4;
|
||||
const SIGNATURE: usize = 64;
|
||||
|
||||
const PING: u8 = 0;
|
||||
pub const PING: u8 = 0;
|
||||
const OK: u8 = 128;
|
||||
const ERROR: u8 = 129;
|
||||
const HELLO: u8 = 1;
|
||||
@@ -58,7 +58,7 @@ pub fn handle_recevied_message(
|
||||
server_name: &String,
|
||||
cmd_tx: crossbeam_channel::Sender<NetworkEvent>,
|
||||
ip: SocketAddr,
|
||||
handhsake_history: &Arc<Mutex<HandshakeHistory>>,
|
||||
handhsake_history: Arc<HandshakeHistory>,
|
||||
) {
|
||||
if recevied_message.len() < 4 {
|
||||
return;
|
||||
@@ -114,10 +114,9 @@ pub fn parse_message(
|
||||
cmd_tx: crossbeam_channel::Sender<NetworkEvent>,
|
||||
ip: SocketAddr,
|
||||
messages_list: &Arc<Mutex<HashMap<i32, EventType>>>,
|
||||
handhsake_history_mutex: &Arc<Mutex<HandshakeHistory>>,
|
||||
handhsake_history: Arc<HandshakeHistory>,
|
||||
senders: &MultipleSenders,
|
||||
) -> Option<Vec<u8>> {
|
||||
let mut handhsake_history = handhsake_history_mutex.lock().unwrap();
|
||||
let cmd_tx_clone = cmd_tx.clone();
|
||||
|
||||
let id_bytes: [u8; 4] = received_message[0..ID]
|
||||
@@ -148,12 +147,8 @@ pub fn parse_message(
|
||||
.block_on(get_peer_key(&username))
|
||||
.expect("failed to retrieve public key"),
|
||||
};
|
||||
match msgtype {
|
||||
HELLOREPLY => {
|
||||
handhsake_history.add_new_handshake(peer_pubkey, "".to_string(), ip);
|
||||
}
|
||||
_ => {}
|
||||
}
|
||||
println!("handshake JULIUS added");
|
||||
handhsake_history.add_new_handshake(peer_pubkey, "".to_string(), ip);
|
||||
let signature: [u8; SIGNATURE] = received_message
|
||||
[LENGTH + msg_length..LENGTH + msg_length + SIGNATURE]
|
||||
.try_into()
|
||||
@@ -194,14 +189,10 @@ pub fn parse_message(
|
||||
// Message handling
|
||||
let mut constructed_message: Option<Vec<u8>> = None;
|
||||
match msgtype {
|
||||
// PING
|
||||
//
|
||||
// envoie un OK
|
||||
PING => {
|
||||
constructed_message = construct_message(OK, Vec::new(), id, crypto_pair);
|
||||
}
|
||||
//
|
||||
// OK
|
||||
|
||||
OK => {
|
||||
let mut guard = messages_list.lock().unwrap();
|
||||
let res = guard.get(&id);
|
||||
@@ -216,9 +207,7 @@ pub fn parse_message(
|
||||
}
|
||||
}
|
||||
}
|
||||
//
|
||||
// rien ?
|
||||
// si NATTRAVERSALREQUEST alors
|
||||
|
||||
NATTRAVERSALREQUEST => {
|
||||
// send ok & send nattraversalrequest2 to peer
|
||||
constructed_message = construct_message(OK, Vec::new(), id, crypto_pair);
|
||||
@@ -277,10 +266,7 @@ pub fn parse_message(
|
||||
);
|
||||
constructed_message = None;
|
||||
}
|
||||
//
|
||||
// ERROR
|
||||
//
|
||||
// affiche un msg d'erreur
|
||||
|
||||
ERROR => {
|
||||
if let Ok(err_received) =
|
||||
String::from_utf8(received_message[LENGTH..(msg_length + LENGTH)].to_vec())
|
||||
@@ -292,10 +278,7 @@ pub fn parse_message(
|
||||
let _ = cmd_tx_clone.send(NetworkEvent::Error(err_msg));
|
||||
}
|
||||
}
|
||||
// HELLO
|
||||
//
|
||||
// envoie une hello reply
|
||||
//
|
||||
|
||||
HELLO => {
|
||||
let mut payload = Vec::new();
|
||||
|
||||
@@ -318,10 +301,7 @@ pub fn parse_message(
|
||||
|
||||
return helloreply;
|
||||
}
|
||||
// HELLOREPLY
|
||||
//
|
||||
//
|
||||
// ajoute a la liste des peers handshake
|
||||
|
||||
HELLOREPLY => {
|
||||
// ajoute l'username a la liste des peers handshake
|
||||
let received_length = u16::from_be_bytes(
|
||||
@@ -365,13 +345,6 @@ pub fn parse_message(
|
||||
None => {}
|
||||
}
|
||||
}
|
||||
//
|
||||
// ROOTREQUEST
|
||||
//
|
||||
// envoie un root reply
|
||||
//
|
||||
// ROOTREPLY
|
||||
//
|
||||
ROOTREPLY => {
|
||||
// recuperer le pseudo du peers ayant repondu
|
||||
let peers_exist = handhsake_history.get_peer_info_ip(ip.to_string());
|
||||
@@ -422,16 +395,6 @@ pub fn parse_message(
|
||||
}
|
||||
}
|
||||
}
|
||||
//
|
||||
// DATUMREQUEST
|
||||
//
|
||||
// envoie le datum
|
||||
//
|
||||
// NODATUM
|
||||
//
|
||||
// affiche un msg d'erreur
|
||||
//
|
||||
// DATUM
|
||||
DATUM => {
|
||||
let mut guard = messages_list.lock().expect("Échec du verrouillage");
|
||||
let res = guard.get(&id);
|
||||
@@ -461,65 +424,6 @@ pub fn parse_message(
|
||||
None => {}
|
||||
}
|
||||
}
|
||||
// parcourt le directory recu ou le big directory et renvoie une DATUMREQUEST pour chaque
|
||||
// directory ou big directory lu
|
||||
//
|
||||
// NATTRAVERSALREQUEST
|
||||
//
|
||||
// repond OK et envoie un NATTRAVERSALREQUEST2 au pair B
|
||||
//
|
||||
// NATTRAVERSALREQUEST2
|
||||
//
|
||||
// envoie OK à S puis envoie un ping à S
|
||||
|
||||
// PING
|
||||
//
|
||||
// envoie un OK
|
||||
//
|
||||
// OK
|
||||
//
|
||||
// si NATTRAVERSALREQUEST alors
|
||||
//
|
||||
// ERROR
|
||||
//
|
||||
// affiche un msg d'erreur
|
||||
//
|
||||
// HELLO
|
||||
//
|
||||
// envoie une hello reply
|
||||
//
|
||||
// HELLOREPLY
|
||||
//
|
||||
// envoie un root request
|
||||
//
|
||||
// ROOTREQUEST
|
||||
//
|
||||
// envoie un root reply
|
||||
//
|
||||
// ROOTREPLY
|
||||
//
|
||||
// envoie un datum request
|
||||
//
|
||||
// DATUMREQUEST
|
||||
//
|
||||
// envoie le datum
|
||||
//
|
||||
// NODATUM
|
||||
//
|
||||
// affiche un msg d'erreur
|
||||
//
|
||||
// DATUM
|
||||
//
|
||||
// parcourt le directory recu ou le big directory et renvoie une DATUMREQUEST pour chaque
|
||||
// directory ou big directory lu
|
||||
//
|
||||
// NATTRAVERSALREQUEST
|
||||
//
|
||||
// repond OK et envoie un NATTRAVERSALREQUEST2 au pair B
|
||||
//
|
||||
// NATTRAVERSALREQUEST2
|
||||
//
|
||||
// envoie OK à S puis envoie un ping à S
|
||||
_ => return None,
|
||||
};
|
||||
constructed_message
|
||||
|
||||
Reference in New Issue
Block a user