gameServer2/src/server/handlers/loggingin.rs
author alfadur
Sun, 09 Dec 2018 04:09:38 +0300
changeset 14392 e335b3120f59
parent 14374 e5db279308d7
permissions -rw-r--r--
pull file io out of server handler
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
12147
03ccb89820f3 Room creation halfplemented
unc0rr
parents:
diff changeset
     1
use mio;
03ccb89820f3 Room creation halfplemented
unc0rr
parents:
diff changeset
     2
13666
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
     3
use crate::{
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
     4
    server::{
13800
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
     5
        client::HWClient,
14374
e5db279308d7 dispose of server mods
alfadur
parents: 13805
diff changeset
     6
        core::HWServer,
13666
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
     7
        coretypes::ClientId,
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
     8
        actions::{Action, Action::*}
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
     9
    },
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    10
    protocol::messages::{
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    11
        HWProtocolMessage, HWServerMessage::*
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    12
    },
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    13
    utils::is_name_illegal
13419
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
    14
};
13800
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    15
#[cfg(feature = "official-server")]
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    16
use openssl::sha::sha1;
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    17
use std::fmt::{Formatter, LowerHex};
13805
0463a4221327 cleanup crate imports
alfadur
parents: 13800
diff changeset
    18
use log::*;
13800
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    19
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    20
#[derive(PartialEq)]
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    21
struct Sha1Digest([u8; 20]);
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    22
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    23
impl LowerHex for Sha1Digest {
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    24
    fn fmt(&self, f: &mut Formatter) -> Result<(), std::fmt::Error> {
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    25
        for byte in &self.0 {
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    26
            write!(f, "{:02x}", byte)?;
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    27
        }
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    28
        Ok(())
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    29
    }
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    30
}
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    31
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    32
#[cfg(feature = "official-server")]
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    33
fn get_hash(client: &HWClient, salt1: &str, salt2: &str) -> Sha1Digest {
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    34
    let s = format!("{}{}{}{}{}", salt1, salt2,
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    35
                    client.web_password, client.protocol_number, "!hedgewars");
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    36
    Sha1Digest(sha1(s.as_bytes()))
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    37
}
12147
03ccb89820f3 Room creation halfplemented
unc0rr
parents:
diff changeset
    38
13419
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
    39
pub fn handle(server: & mut HWServer, client_id: ClientId, message: HWProtocolMessage) {
12147
03ccb89820f3 Room creation halfplemented
unc0rr
parents:
diff changeset
    40
    match message {
13416
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
    41
        HWProtocolMessage::Nick(nick) => {
13666
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    42
            let client = &mut server.clients[client_id];
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    43
            debug!("{} {}", nick, is_name_illegal(&nick));
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    44
            let actions = if client.room_id != None {
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    45
                unreachable!()
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    46
            }
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    47
            else if !client.nick.is_empty() {
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    48
                vec![ProtocolError("Nickname already provided.".to_string())]
13416
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
    49
            }
13800
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    50
            else if is_name_illegal(&nick) {
13666
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    51
                vec![ByeClient("Illegal nickname! Nicknames must be between 1-40 characters long, must not have a trailing or leading space and must not have any of these characters: $()*+?[]^{|}".to_string())]
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    52
            }
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    53
            else {
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    54
                client.nick = nick.clone();
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    55
                vec![Nick(nick).send_self().action(),
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    56
                     CheckRegistered]
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    57
            };
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    58
13419
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
    59
            server.react(client_id, actions);
13798
4664da990556 Add official server feature to cargo
alfadur
parents: 13666
diff changeset
    60
        }
12147
03ccb89820f3 Room creation halfplemented
unc0rr
parents:
diff changeset
    61
        HWProtocolMessage::Proto(proto) => {
13666
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    62
            let client = &mut server.clients[client_id];
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    63
            let actions = if client.protocol_number != 0 {
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    64
                vec![ProtocolError("Protocol already known.".to_string())]
13416
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
    65
            }
13666
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    66
            else if proto == 0 {
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    67
                vec![ProtocolError("Bad number.".to_string())]
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    68
            }
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    69
            else {
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    70
                client.protocol_number = proto;
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    71
                vec![Proto(proto).send_self().action(),
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    72
                     CheckRegistered]
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
    73
            };
13419
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
    74
            server.react(client_id, actions);
13798
4664da990556 Add official server feature to cargo
alfadur
parents: 13666
diff changeset
    75
        }
4664da990556 Add official server feature to cargo
alfadur
parents: 13666
diff changeset
    76
        #[cfg(feature = "official-server")]
13800
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    77
        HWProtocolMessage::Password(hash, salt) => {
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    78
            let c = &server.clients[client_id];
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    79
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    80
            let client_hash = get_hash(c, &salt, &c.server_salt);
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    81
            let server_hash = get_hash(c, &c.server_salt, &salt);
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    82
            let actions = if client_hash == server_hash {
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    83
                vec![ServerAuth(format!("{:x}", server_hash)).send_self().action(),
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    84
                     JoinLobby]
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    85
            } else {
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    86
                vec![ByeClient("Authentication failed".to_string())]
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    87
            };
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    88
            server.react(client_id, actions);
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    89
        }
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    90
        #[cfg(feature = "official-server")]
13798
4664da990556 Add official server feature to cargo
alfadur
parents: 13666
diff changeset
    91
        HWProtocolMessage::Checker(protocol, nick, password) => {
4664da990556 Add official server feature to cargo
alfadur
parents: 13666
diff changeset
    92
            let c = &mut server.clients[client_id];
4664da990556 Add official server feature to cargo
alfadur
parents: 13666
diff changeset
    93
            c.nick = nick;
4664da990556 Add official server feature to cargo
alfadur
parents: 13666
diff changeset
    94
            c.web_password = password;
4664da990556 Add official server feature to cargo
alfadur
parents: 13666
diff changeset
    95
            c.set_is_checker(true);
4664da990556 Add official server feature to cargo
alfadur
parents: 13666
diff changeset
    96
        }
12147
03ccb89820f3 Room creation halfplemented
unc0rr
parents:
diff changeset
    97
        _ => warn!("Incorrect command in logging-in state"),
03ccb89820f3 Room creation halfplemented
unc0rr
parents:
diff changeset
    98
    }
03ccb89820f3 Room creation halfplemented
unc0rr
parents:
diff changeset
    99
}