rust/hedgewars-server/src/handlers/inanteroom.rs
author unc0rr
Wed, 23 Jun 2021 23:41:51 +0200
changeset 15804 747278149393
parent 15540 479911540e17
child 15831 7d0f747afcb8
permissions -rw-r--r--
Extract network protocol into a separate crate
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
15532
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
     3
use super::strings::*;
15804
747278149393 Extract network protocol into a separate crate
unc0rr
parents: 15540
diff changeset
     4
use crate::handlers::actions::ToPendingMessage;
13666
09f4a30e50cc Rust 2018 conversion
alfadur
parents: 13478
diff changeset
     5
use crate::{
15074
c5a6e8566425 shuffle server files
alfadur
parents: 14870
diff changeset
     6
    core::{
15520
fd3a20e9d095 move the anteroom out of the server
alfadur <mail@none>
parents: 15103
diff changeset
     7
        anteroom::{HwAnteroom, HwAnteroomClient},
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
     8
        client::HwClient,
15520
fd3a20e9d095 move the anteroom out of the server
alfadur <mail@none>
parents: 15103
diff changeset
     9
        server::HwServer,
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    10
        types::ClientId,
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    11
    },
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    12
    utils::is_name_illegal,
13419
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
    13
};
15804
747278149393 Extract network protocol into a separate crate
unc0rr
parents: 15540
diff changeset
    14
use hedgewars_network_protocol::messages::{
747278149393 Extract network protocol into a separate crate
unc0rr
parents: 15540
diff changeset
    15
    HwProtocolMessage, HwProtocolMessage::LoadRoom, HwServerMessage::*,
747278149393 Extract network protocol into a separate crate
unc0rr
parents: 15540
diff changeset
    16
};
14457
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
    17
use log::*;
13800
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    18
#[cfg(feature = "official-server")]
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    19
use openssl::sha::sha1;
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    20
use std::{
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    21
    fmt::{Formatter, LowerHex},
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    22
    num::NonZeroU16,
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    23
};
13800
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
    24
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    25
pub enum LoginResult {
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    26
    Unchanged,
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    27
    Complete,
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    28
    Exit,
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    29
}
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    30
14781
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
    31
fn completion_result<'a, I>(
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
    32
    mut other_clients: I,
15520
fd3a20e9d095 move the anteroom out of the server
alfadur <mail@none>
parents: 15103
diff changeset
    33
    client: &mut HwAnteroomClient,
14781
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
    34
    response: &mut super::Response,
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
    35
) -> LoginResult
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
    36
where
15520
fd3a20e9d095 move the anteroom out of the server
alfadur <mail@none>
parents: 15103
diff changeset
    37
    I: Iterator<Item = &'a HwClient>,
14781
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
    38
{
15532
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
    39
    let has_nick_clash = other_clients.any(|c| c.nick == *client.nick.as_ref().unwrap());
14779
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14696
diff changeset
    40
14781
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
    41
    if has_nick_clash {
15532
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
    42
        client.nick = None;
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
    43
        response.add(Notice("NickAlreadyInUse".to_string()).send_self());
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
    44
        LoginResult::Unchanged
14781
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
    45
    } else {
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
    46
        #[cfg(feature = "official-server")]
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
    47
        {
15103
823052e66611 check for account existence before asking passwords
alfadur
parents: 15075
diff changeset
    48
            response.request_io(super::IoTask::CheckRegistered {
823052e66611 check for account existence before asking passwords
alfadur
parents: 15075
diff changeset
    49
                nick: client.nick.as_ref().unwrap().clone(),
823052e66611 check for account existence before asking passwords
alfadur
parents: 15075
diff changeset
    50
            });
14781
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
    51
            LoginResult::Unchanged
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
    52
        }
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
    53
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
    54
        #[cfg(not(feature = "official-server"))]
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
    55
        {
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
    56
            LoginResult::Complete
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
    57
        }
14779
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14696
diff changeset
    58
    }
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14696
diff changeset
    59
}
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14696
diff changeset
    60
14671
455865ccd36c Server action refactoring part 2 of N
alfadur <mail@none>
parents: 14457
diff changeset
    61
pub fn handle(
15520
fd3a20e9d095 move the anteroom out of the server
alfadur <mail@none>
parents: 15103
diff changeset
    62
    server_state: &mut super::ServerState,
14671
455865ccd36c Server action refactoring part 2 of N
alfadur <mail@none>
parents: 14457
diff changeset
    63
    client_id: ClientId,
455865ccd36c Server action refactoring part 2 of N
alfadur <mail@none>
parents: 14457
diff changeset
    64
    response: &mut super::Response,
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    65
    message: HwProtocolMessage,
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    66
) -> LoginResult {
12147
03ccb89820f3 Room creation halfplemented
unc0rr
parents:
diff changeset
    67
    match message {
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    68
        HwProtocolMessage::Quit(_) => {
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    69
            response.add(Bye("User quit".to_string()).send_self());
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    70
            LoginResult::Exit
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    71
        }
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    72
        HwProtocolMessage::Nick(nick) => {
15520
fd3a20e9d095 move the anteroom out of the server
alfadur <mail@none>
parents: 15103
diff changeset
    73
            let client = &mut server_state.anteroom.clients[client_id];
14870
ce98c37826a7 fix accepting on wrong server socket
alfadur
parents: 14781
diff changeset
    74
14781
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
    75
            if client.nick.is_some() {
15532
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
    76
                response.error(NICKNAME_PROVIDED);
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    77
                LoginResult::Unchanged
14457
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
    78
            } else if is_name_illegal(&nick) {
15532
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
    79
                response.add(Bye(ILLEGAL_CLIENT_NAME.to_string()).send_self());
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    80
                LoginResult::Exit
14457
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
    81
            } else {
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    82
                client.nick = Some(nick.clone());
14672
6e6632068a33 Server action refactoring part 3 of N
alfadur <mail@none>
parents: 14671
diff changeset
    83
                response.add(Nick(nick).send_self());
14673
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14672
diff changeset
    84
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    85
                if client.protocol_number.is_some() {
15520
fd3a20e9d095 move the anteroom out of the server
alfadur <mail@none>
parents: 15103
diff changeset
    86
                    completion_result(server_state.server.iter_clients(), client, response)
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    87
                } else {
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    88
                    LoginResult::Unchanged
14673
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14672
diff changeset
    89
                }
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14672
diff changeset
    90
            }
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14672
diff changeset
    91
        }
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    92
        HwProtocolMessage::Proto(proto) => {
15520
fd3a20e9d095 move the anteroom out of the server
alfadur <mail@none>
parents: 15103
diff changeset
    93
            let client = &mut server_state.anteroom.clients[client_id];
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    94
            if client.protocol_number.is_some() {
15532
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
    95
                response.error(PROTOCOL_PROVIDED);
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
    96
                LoginResult::Unchanged
15540
479911540e17 backout a798e6441a36
alfadur <mail@none>
parents: 15536
diff changeset
    97
            } else if proto < 48 {
15532
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
    98
                response.add(Bye(PROTOCOL_TOO_OLD.to_string()).send_self());
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
    99
                LoginResult::Exit
14673
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14672
diff changeset
   100
            } else {
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
   101
                client.protocol_number = NonZeroU16::new(proto);
14673
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14672
diff changeset
   102
                response.add(Proto(proto).send_self());
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14672
diff changeset
   103
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
   104
                if client.nick.is_some() {
15520
fd3a20e9d095 move the anteroom out of the server
alfadur <mail@none>
parents: 15103
diff changeset
   105
                    completion_result(server_state.server.iter_clients(), client, response)
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
   106
                } else {
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
   107
                    LoginResult::Unchanged
14673
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14672
diff changeset
   108
                }
14672
6e6632068a33 Server action refactoring part 3 of N
alfadur <mail@none>
parents: 14671
diff changeset
   109
            }
13798
4664da990556 Add official server feature to cargo
alfadur
parents: 13666
diff changeset
   110
        }
4664da990556 Add official server feature to cargo
alfadur
parents: 13666
diff changeset
   111
        #[cfg(feature = "official-server")]
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
   112
        HwProtocolMessage::Password(hash, salt) => {
15520
fd3a20e9d095 move the anteroom out of the server
alfadur <mail@none>
parents: 15103
diff changeset
   113
            let client = &server_state.anteroom.clients[client_id];
13800
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
   114
14779
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14696
diff changeset
   115
            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: 14696
diff changeset
   116
                response.request_io(super::IoTask::GetAccount {
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14696
diff changeset
   117
                    nick: nick.clone(),
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14696
diff changeset
   118
                    protocol: protocol.get(),
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14696
diff changeset
   119
                    server_salt: client.server_salt.clone(),
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14696
diff changeset
   120
                    client_salt: salt,
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14696
diff changeset
   121
                    password_hash: hash,
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14696
diff changeset
   122
                });
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14696
diff changeset
   123
            };
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14696
diff changeset
   124
f43ab2bd76ae add a thread for internal server IO and implement account checking with it
alfadur
parents: 14696
diff changeset
   125
            LoginResult::Unchanged
14672
6e6632068a33 Server action refactoring part 3 of N
alfadur <mail@none>
parents: 14671
diff changeset
   126
        }
13800
0118b7412570 use openssl for password message handling
alfadur
parents: 13798
diff changeset
   127
        #[cfg(feature = "official-server")]
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
   128
        HwProtocolMessage::Checker(protocol, nick, password) => {
15520
fd3a20e9d095 move the anteroom out of the server
alfadur <mail@none>
parents: 15103
diff changeset
   129
            let client = &mut server_state.anteroom.clients[client_id];
14781
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
   130
            if protocol == 0 {
15532
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
   131
                response.error("Bad number.");
14781
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
   132
                LoginResult::Unchanged
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
   133
            } else {
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
   134
                client.protocol_number = NonZeroU16::new(protocol);
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
   135
                client.is_checker = true;
15532
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
   136
                #[cfg(not(feature = "official-server"))]
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
   137
                {
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
   138
                    response.request_io(super::IoTask::GetCheckerAccount {
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
   139
                        nick: nick,
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
   140
                        password: password,
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
   141
                    });
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
   142
                    LoginResult::Unchanged
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
   143
                }
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
   144
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
   145
                #[cfg(feature = "official-server")]
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
   146
                {
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
   147
                    response.add(LogonPassed.send_self());
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
   148
                    LoginResult::Complete
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
   149
                }
14781
01f8ab45f806 fix lobby joining
alfadur
parents: 14779
diff changeset
   150
            }
13798
4664da990556 Add official server feature to cargo
alfadur
parents: 13666
diff changeset
   151
        }
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
   152
        _ => {
15532
f1205f33bf5b complete checker login handling
alfadur <mail@none>
parents: 15520
diff changeset
   153
            warn!("Incorrect command in anteroom");
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
   154
            LoginResult::Unchanged
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14690
diff changeset
   155
        }
12147
03ccb89820f3 Room creation halfplemented
unc0rr
parents:
diff changeset
   156
    }
03ccb89820f3 Room creation halfplemented
unc0rr
parents:
diff changeset
   157
}