rust/hedgewars-server/src/server/handlers/loggingin.rs
author alfadur
Tue, 09 Apr 2019 21:08:35 +0300
changeset 14784 f43ab2bd76ae
parent 14701 8a45c90f4580
child 14786 01f8ab45f806
permissions -rw-r--r--
add a thread for internal server IO and implement account checking with it
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
12152
03ccb89820f3 Room creation halfplemented
unc0rr
parents:
diff changeset
     1
use mio;
03ccb89820f3 Room creation halfplemented
unc0rr
parents:
diff changeset
     2
14784
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
     3
use crate::protocol::messages::HWProtocolMessage::LoadRoom;
13671
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13483
diff changeset
     4
use crate::{
14462
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14420
diff changeset
     5
    protocol::messages::{HWProtocolMessage, HWServerMessage::*},
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
     6
    server::{
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
     7
        core::{HWAnteClient, HWAnteroom},
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
     8
        coretypes::ClientId,
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
     9
    },
14462
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14420
diff changeset
    10
    utils::is_name_illegal,
13424
81e0ed105f5d implementation of team related messages
alfadur
parents: 13421
diff changeset
    11
};
14462
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14420
diff changeset
    12
use log::*;
13805
0118b7412570 use openssl for password message handling
alfadur
parents: 13803
diff changeset
    13
#[cfg(feature = "official-server")]
0118b7412570 use openssl for password message handling
alfadur
parents: 13803
diff changeset
    14
use openssl::sha::sha1;
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    15
use std::{
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    16
    fmt::{Formatter, LowerHex},
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    17
    num::NonZeroU16,
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    18
};
13805
0118b7412570 use openssl for password message handling
alfadur
parents: 13803
diff changeset
    19
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    20
pub enum LoginResult {
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    21
    Unchanged,
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    22
    Complete,
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    23
    Exit,
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    24
}
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    25
14784
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    26
fn completion_result(client: &HWAnteClient, response: &mut super::Response) -> LoginResult {
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    27
    #[cfg(feature = "official-server")]
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    28
    {
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    29
        response.add(AskPassword(client.server_salt.clone()).send_self());
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    30
        LoginResult::Unchanged
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    31
    }
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    32
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    33
    #[cfg(not(feature = "official-server"))]
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    34
    {
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    35
        LoginResult::Complete
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    36
    }
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    37
}
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    38
14676
455865ccd36c Server action refactoring part 2 of N
alfadur <mail@none>
parents: 14462
diff changeset
    39
pub fn handle(
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    40
    anteroom: &mut HWAnteroom,
14676
455865ccd36c Server action refactoring part 2 of N
alfadur <mail@none>
parents: 14462
diff changeset
    41
    client_id: ClientId,
455865ccd36c Server action refactoring part 2 of N
alfadur <mail@none>
parents: 14462
diff changeset
    42
    response: &mut super::Response,
455865ccd36c Server action refactoring part 2 of N
alfadur <mail@none>
parents: 14462
diff changeset
    43
    message: HWProtocolMessage,
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    44
) -> LoginResult {
12152
03ccb89820f3 Room creation halfplemented
unc0rr
parents:
diff changeset
    45
    match message {
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    46
        HWProtocolMessage::Quit(_) => {
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    47
            response.add(Bye("User quit".to_string()).send_self());
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    48
            LoginResult::Exit
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    49
        }
13421
cdf69667593b partial room implementation
alfadur
parents: 13124
diff changeset
    50
        HWProtocolMessage::Nick(nick) => {
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    51
            let client = &mut anteroom.clients[client_id];
13671
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13483
diff changeset
    52
            debug!("{} {}", nick, is_name_illegal(&nick));
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    53
            if !client.nick.is_some() {
14677
6e6632068a33 Server action refactoring part 3 of N
alfadur <mail@none>
parents: 14676
diff changeset
    54
                response.add(Error("Nickname already provided.".to_string()).send_self());
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    55
                LoginResult::Unchanged
14462
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14420
diff changeset
    56
            } else if is_name_illegal(&nick) {
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    57
                response.add(Bye("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()).send_self());
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    58
                LoginResult::Exit
14462
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14420
diff changeset
    59
            } else {
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    60
                client.nick = Some(nick.clone());
14677
6e6632068a33 Server action refactoring part 3 of N
alfadur <mail@none>
parents: 14676
diff changeset
    61
                response.add(Nick(nick).send_self());
14678
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14677
diff changeset
    62
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    63
                if client.protocol_number.is_some() {
14784
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    64
                    completion_result(&client, response)
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    65
                } else {
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    66
                    LoginResult::Unchanged
14678
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14677
diff changeset
    67
                }
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14677
diff changeset
    68
            }
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14677
diff changeset
    69
        }
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14677
diff changeset
    70
        HWProtocolMessage::Proto(proto) => {
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    71
            let client = &mut anteroom.clients[client_id];
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    72
            if client.protocol_number.is_some() {
14678
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14677
diff changeset
    73
                response.add(Error("Protocol already known.".to_string()).send_self());
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    74
                LoginResult::Unchanged
14678
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14677
diff changeset
    75
            } else if proto == 0 {
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14677
diff changeset
    76
                response.add(Error("Bad number.".to_string()).send_self());
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    77
                LoginResult::Unchanged
14678
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14677
diff changeset
    78
            } else {
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    79
                client.protocol_number = NonZeroU16::new(proto);
14678
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14677
diff changeset
    80
                response.add(Proto(proto).send_self());
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14677
diff changeset
    81
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    82
                if client.nick.is_some() {
14784
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    83
                    completion_result(&client, response)
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    84
                } else {
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    85
                    LoginResult::Unchanged
14678
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14677
diff changeset
    86
                }
14677
6e6632068a33 Server action refactoring part 3 of N
alfadur <mail@none>
parents: 14676
diff changeset
    87
            }
13803
4664da990556 Add official server feature to cargo
alfadur
parents: 13671
diff changeset
    88
        }
4664da990556 Add official server feature to cargo
alfadur
parents: 13671
diff changeset
    89
        #[cfg(feature = "official-server")]
13805
0118b7412570 use openssl for password message handling
alfadur
parents: 13803
diff changeset
    90
        HWProtocolMessage::Password(hash, salt) => {
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
    91
            let client = &anteroom.clients[client_id];
13805
0118b7412570 use openssl for password message handling
alfadur
parents: 13803
diff changeset
    92
14784
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    93
            if let (Some(nick), Some(protocol)) = (client.nick.as_ref(), client.protocol_number) {
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    94
                response.request_io(super::IoTask::GetAccount {
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    95
                    nick: nick.clone(),
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    96
                    protocol: protocol.get(),
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    97
                    server_salt: client.server_salt.clone(),
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    98
                    client_salt: salt,
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
    99
                    password_hash: hash,
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
   100
                });
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
   101
            };
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
   102
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14701
diff changeset
   103
            LoginResult::Unchanged
14677
6e6632068a33 Server action refactoring part 3 of N
alfadur <mail@none>
parents: 14676
diff changeset
   104
        }
13805
0118b7412570 use openssl for password message handling
alfadur
parents: 13803
diff changeset
   105
        #[cfg(feature = "official-server")]
13803
4664da990556 Add official server feature to cargo
alfadur
parents: 13671
diff changeset
   106
        HWProtocolMessage::Checker(protocol, nick, password) => {
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
   107
            let client = &mut anteroom.clients[client_id];
14700
216d39de1a44 fix official server build & bump dependencies
alfadur
parents: 14698
diff changeset
   108
            client.protocol_number = NonZeroU16::new(protocol);
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
   109
            client.nick = Some(nick);
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
   110
            //client.set_is_checker(true);
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
   111
            LoginResult::Complete
13803
4664da990556 Add official server feature to cargo
alfadur
parents: 13671
diff changeset
   112
        }
14698
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
   113
        _ => {
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
   114
            warn!("Incorrect command in logging-in state");
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
   115
            LoginResult::Unchanged
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14695
diff changeset
   116
        }
12152
03ccb89820f3 Room creation halfplemented
unc0rr
parents:
diff changeset
   117
    }
03ccb89820f3 Room creation halfplemented
unc0rr
parents:
diff changeset
   118
}