rust/hedgewars-server/src/core/server.rs
author Wuzzy <Wuzzy2@mail.ru>
Sun, 30 Jun 2019 11:20:22 +0200
changeset 15206 d48eba5ac715
parent 15176 f6115638aa92
child 15439 a158ff8f84ef
permissions -rw-r--r--
Fix sidFPS not being properly right-aligned (again!) FPS display worked before, but it was accidentally un-done in bcecb3349948e2e00d3f2ee0c6497a24676a4efb.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
13416
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
     1
use super::{
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
     2
    client::HwClient,
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
     3
    indexslab::IndexSlab,
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
     4
    room::HwRoom,
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
     5
    types::{ClientId, RoomId},
13416
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
     6
};
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
     7
use crate::{protocol::messages::HwProtocolMessage::Greeting, utils};
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
     8
14786
8ecdb5c6bb2a implement info, registered only & super power messages
alfadur
parents: 14783
diff changeset
     9
use bitflags::*;
13805
0463a4221327 cleanup crate imports
alfadur
parents: 13798
diff changeset
    10
use log::*;
14457
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
    11
use slab;
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    12
use std::{borrow::BorrowMut, iter, num::NonZeroU16};
12126
4348997e502b Refactor code to add more structure to it
unc0rr
parents:
diff changeset
    13
12852
bd35cb2302b3 Quick dirty fix for building
unc0rr
parents: 12148
diff changeset
    14
type Slab<T> = slab::Slab<T>;
12127
36ac9c075d0d - Use netbuf buffers for client connection stream
unc0rr
parents: 12126
diff changeset
    15
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    16
pub struct HwAnteClient {
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    17
    pub nick: Option<String>,
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    18
    pub protocol_number: Option<NonZeroU16>,
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    19
    pub server_salt: String,
14781
01f8ab45f806 fix lobby joining
alfadur
parents: 14780
diff changeset
    20
    pub is_checker: bool,
15176
f6115638aa92 enable local admins for non-official servers
alfadur
parents: 15075
diff changeset
    21
    pub is_local_admin: bool,
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    22
}
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    23
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    24
pub struct HwAnteroom {
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    25
    pub clients: IndexSlab<HwAnteClient>,
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    26
}
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    27
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    28
impl HwAnteroom {
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    29
    pub fn new(clients_limit: usize) -> Self {
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    30
        let clients = IndexSlab::with_capacity(clients_limit);
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    31
        HwAnteroom { clients }
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    32
    }
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    33
15176
f6115638aa92 enable local admins for non-official servers
alfadur
parents: 15075
diff changeset
    34
    pub fn add_client(&mut self, client_id: ClientId, salt: String, is_local_admin: bool) {
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    35
        let client = HwAnteClient {
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    36
            nick: None,
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    37
            protocol_number: None,
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    38
            server_salt: salt,
14781
01f8ab45f806 fix lobby joining
alfadur
parents: 14780
diff changeset
    39
            is_checker: false,
15176
f6115638aa92 enable local admins for non-official servers
alfadur
parents: 15075
diff changeset
    40
            is_local_admin,
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    41
        };
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    42
        self.clients.insert(client_id, client);
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    43
    }
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    44
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    45
    pub fn remove_client(&mut self, client_id: ClientId) -> Option<HwAnteClient> {
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    46
        let mut client = self.clients.remove(client_id);
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    47
        client
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    48
    }
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    49
}
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    50
14783
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
    51
pub struct ServerGreetings {
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
    52
    pub for_latest_protocol: String,
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
    53
    pub for_old_protocols: String,
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
    54
}
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
    55
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
    56
impl ServerGreetings {
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
    57
    fn new() -> Self {
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
    58
        Self {
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
    59
            for_latest_protocol: "\u{1f994} is watching".to_string(),
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
    60
            for_old_protocols: "\u{1f994} is watching".to_string(),
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
    61
        }
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
    62
    }
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
    63
}
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
    64
14786
8ecdb5c6bb2a implement info, registered only & super power messages
alfadur
parents: 14783
diff changeset
    65
bitflags! {
8ecdb5c6bb2a implement info, registered only & super power messages
alfadur
parents: 14783
diff changeset
    66
    pub struct ServerFlags: u8 {
8ecdb5c6bb2a implement info, registered only & super power messages
alfadur
parents: 14783
diff changeset
    67
        const REGISTERED_ONLY = 0b0000_1000;
8ecdb5c6bb2a implement info, registered only & super power messages
alfadur
parents: 14783
diff changeset
    68
    }
8ecdb5c6bb2a implement info, registered only & super power messages
alfadur
parents: 14783
diff changeset
    69
}
8ecdb5c6bb2a implement info, registered only & super power messages
alfadur
parents: 14783
diff changeset
    70
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    71
pub struct HwServer {
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    72
    pub clients: IndexSlab<HwClient>,
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    73
    pub rooms: Slab<HwRoom>,
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    74
    pub anteroom: HwAnteroom,
14783
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
    75
    pub latest_protocol: u16,
14786
8ecdb5c6bb2a implement info, registered only & super power messages
alfadur
parents: 14783
diff changeset
    76
    pub flags: ServerFlags,
14783
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
    77
    pub greetings: ServerGreetings,
12126
4348997e502b Refactor code to add more structure to it
unc0rr
parents:
diff changeset
    78
}
4348997e502b Refactor code to add more structure to it
unc0rr
parents:
diff changeset
    79
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    80
impl HwServer {
14780
65861ba8b4e8 move room saves to IO thread
alfadur
parents: 14779
diff changeset
    81
    pub fn new(clients_limit: usize, rooms_limit: usize) -> Self {
13119
1e39b8749072 separated the server logic from all the async io mess.
alfadur
parents: 12852
diff changeset
    82
        let rooms = Slab::with_capacity(rooms_limit);
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    83
        let clients = IndexSlab::with_capacity(clients_limit);
14694
25c564f77b7d remove lobby room
alfadur <mail@none>
parents: 14693
diff changeset
    84
        Self {
14457
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
    85
            clients,
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
    86
            rooms,
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    87
            anteroom: HwAnteroom::new(clients_limit),
14783
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
    88
            greetings: ServerGreetings::new(),
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
    89
            latest_protocol: 58,
14786
8ecdb5c6bb2a implement info, registered only & super power messages
alfadur
parents: 14783
diff changeset
    90
            flags: ServerFlags::empty(),
14694
25c564f77b7d remove lobby room
alfadur <mail@none>
parents: 14693
diff changeset
    91
        }
12126
4348997e502b Refactor code to add more structure to it
unc0rr
parents:
diff changeset
    92
    }
4348997e502b Refactor code to add more structure to it
unc0rr
parents:
diff changeset
    93
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    94
    pub fn add_client(&mut self, client_id: ClientId, data: HwAnteClient) {
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
    95
        if let (Some(protocol), Some(nick)) = (data.protocol_number, data.nick) {
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
    96
            let mut client = HwClient::new(client_id, protocol.get(), nick);
14781
01f8ab45f806 fix lobby joining
alfadur
parents: 14780
diff changeset
    97
            client.set_is_checker(data.is_checker);
15176
f6115638aa92 enable local admins for non-official servers
alfadur
parents: 15075
diff changeset
    98
            #[cfg(not(feature = "official-server"))]
f6115638aa92 enable local admins for non-official servers
alfadur
parents: 15075
diff changeset
    99
            client.set_is_admin(data.is_local_admin);
f6115638aa92 enable local admins for non-official servers
alfadur
parents: 15075
diff changeset
   100
14693
6a2e13e36b7f add server anteroom
alfadur <mail@none>
parents: 14686
diff changeset
   101
            self.clients.insert(client_id, client);
13119
1e39b8749072 separated the server logic from all the async io mess.
alfadur
parents: 12852
diff changeset
   102
        }
12126
4348997e502b Refactor code to add more structure to it
unc0rr
parents:
diff changeset
   103
    }
12127
36ac9c075d0d - Use netbuf buffers for client connection stream
unc0rr
parents: 12126
diff changeset
   104
14673
08a8605bafaf Server action refactoring part 4 of N
alfadur <mail@none>
parents: 14672
diff changeset
   105
    pub fn remove_client(&mut self, client_id: ClientId) {
14696
8a45c90f4580 fix client removal
alfadur
parents: 14695
diff changeset
   106
        self.clients.remove(client_id);
12127
36ac9c075d0d - Use netbuf buffers for client connection stream
unc0rr
parents: 12126
diff changeset
   107
    }
36ac9c075d0d - Use netbuf buffers for client connection stream
unc0rr
parents: 12126
diff changeset
   108
14783
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
   109
    pub fn get_greetings(&self, client_id: ClientId) -> &str {
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
   110
        if self.clients[client_id].protocol_number < self.latest_protocol {
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
   111
            &self.greetings.for_old_protocols
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
   112
        } else {
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
   113
            &self.greetings.for_latest_protocol
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
   114
        }
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
   115
    }
b3adc030104b implement server vars
alfadur
parents: 14781
diff changeset
   116
14504
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   117
    #[inline]
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   118
    pub fn create_room(
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   119
        &mut self,
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   120
        creator_id: ClientId,
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   121
        name: String,
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   122
        password: Option<String>,
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   123
    ) -> RoomId {
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   124
        create_room(
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   125
            &mut self.clients[creator_id],
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   126
            &mut self.rooms,
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   127
            name,
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   128
            password,
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   129
        )
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   130
    }
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   131
14671
455865ccd36c Server action refactoring part 2 of N
alfadur <mail@none>
parents: 14504
diff changeset
   132
    #[inline]
455865ccd36c Server action refactoring part 2 of N
alfadur <mail@none>
parents: 14504
diff changeset
   133
    pub fn move_to_room(&mut self, client_id: ClientId, room_id: RoomId) {
455865ccd36c Server action refactoring part 2 of N
alfadur <mail@none>
parents: 14504
diff changeset
   134
        move_to_room(&mut self.clients[client_id], &mut self.rooms[room_id])
455865ccd36c Server action refactoring part 2 of N
alfadur <mail@none>
parents: 14504
diff changeset
   135
    }
455865ccd36c Server action refactoring part 2 of N
alfadur <mail@none>
parents: 14504
diff changeset
   136
13416
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
   137
    pub fn has_room(&self, name: &str) -> bool {
14697
f64e21f164a5 fix some warnings
alfadur
parents: 14696
diff changeset
   138
        self.find_room(name).is_some()
13416
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
   139
    }
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
   140
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
   141
    pub fn find_room(&self, name: &str) -> Option<&HwRoom> {
14457
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
   142
        self.rooms
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
   143
            .iter()
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
   144
            .find_map(|(_, r)| Some(r).filter(|r| r.name == name))
13416
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
   145
    }
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
   146
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
   147
    pub fn find_room_mut(&mut self, name: &str) -> Option<&mut HwRoom> {
14457
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
   148
        self.rooms
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
   149
            .iter_mut()
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
   150
            .find_map(|(_, r)| Some(r).filter(|r| r.name == name))
13416
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
   151
    }
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
   152
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
   153
    pub fn find_client(&self, nick: &str) -> Option<&HwClient> {
14457
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
   154
        self.clients
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
   155
            .iter()
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
   156
            .find_map(|(_, c)| Some(c).filter(|c| c.nick == nick))
13478
d79795acaa73 Mostly implement voting
alfadur
parents: 13445
diff changeset
   157
    }
d79795acaa73 Mostly implement voting
alfadur
parents: 13445
diff changeset
   158
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
   159
    pub fn find_client_mut(&mut self, nick: &str) -> Option<&mut HwClient> {
14457
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
   160
        self.clients
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
   161
            .iter_mut()
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
   162
            .find_map(|(_, c)| Some(c).filter(|c| c.nick == nick))
13478
d79795acaa73 Mostly implement voting
alfadur
parents: 13445
diff changeset
   163
    }
d79795acaa73 Mostly implement voting
alfadur
parents: 13445
diff changeset
   164
14789
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   165
    pub fn all_clients(&self) -> impl Iterator<Item = ClientId> + '_ {
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   166
        self.clients.iter().map(|(id, _)| id)
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   167
    }
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   168
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   169
    pub fn filter_clients<'a, F>(&'a self, f: F) -> impl Iterator<Item = ClientId> + 'a
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   170
    where
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
   171
        F: Fn(&(usize, &HwClient)) -> bool + 'a,
14789
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   172
    {
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   173
        self.clients.iter().filter(f).map(|(_, c)| c.id)
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   174
    }
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   175
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   176
    pub fn filter_rooms<'a, F>(&'a self, f: F) -> impl Iterator<Item = RoomId> + 'a
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   177
    where
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
   178
        F: Fn(&(usize, &HwRoom)) -> bool + 'a,
14789
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   179
    {
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   180
        self.rooms.iter().filter(f).map(|(_, c)| c.id)
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   181
    }
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   182
14781
01f8ab45f806 fix lobby joining
alfadur
parents: 14780
diff changeset
   183
    pub fn collect_clients<F>(&self, f: F) -> Vec<ClientId>
14457
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
   184
    where
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
   185
        F: Fn(&(usize, &HwClient)) -> bool,
14457
98ef2913ec73 Apply rustfmt to all files
unc0rr
parents: 14415
diff changeset
   186
    {
14789
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   187
        self.filter_clients(f).collect()
13416
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
   188
    }
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
   189
14781
01f8ab45f806 fix lobby joining
alfadur
parents: 14780
diff changeset
   190
    pub fn collect_nicks<F>(&self, f: F) -> Vec<String>
01f8ab45f806 fix lobby joining
alfadur
parents: 14780
diff changeset
   191
    where
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
   192
        F: Fn(&(usize, &HwClient)) -> bool,
14781
01f8ab45f806 fix lobby joining
alfadur
parents: 14780
diff changeset
   193
    {
01f8ab45f806 fix lobby joining
alfadur
parents: 14780
diff changeset
   194
        self.clients
01f8ab45f806 fix lobby joining
alfadur
parents: 14780
diff changeset
   195
            .iter()
01f8ab45f806 fix lobby joining
alfadur
parents: 14780
diff changeset
   196
            .filter(f)
01f8ab45f806 fix lobby joining
alfadur
parents: 14780
diff changeset
   197
            .map(|(_, c)| c.nick.clone())
01f8ab45f806 fix lobby joining
alfadur
parents: 14780
diff changeset
   198
            .collect()
14694
25c564f77b7d remove lobby room
alfadur <mail@none>
parents: 14693
diff changeset
   199
    }
25c564f77b7d remove lobby room
alfadur <mail@none>
parents: 14693
diff changeset
   200
14789
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   201
    pub fn lobby_clients(&self) -> impl Iterator<Item = ClientId> + '_ {
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   202
        self.filter_clients(|(_, c)| c.room_id == None)
14781
01f8ab45f806 fix lobby joining
alfadur
parents: 14780
diff changeset
   203
    }
01f8ab45f806 fix lobby joining
alfadur
parents: 14780
diff changeset
   204
14789
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   205
    pub fn room_clients(&self, room_id: RoomId) -> impl Iterator<Item = ClientId> + '_ {
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   206
        self.filter_clients(move |(_, c)| c.room_id == Some(room_id))
13416
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
   207
    }
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
   208
14789
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   209
    pub fn protocol_clients(&self, protocol: u16) -> impl Iterator<Item = ClientId> + '_ {
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   210
        self.filter_clients(move |(_, c)| c.protocol_number == protocol)
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   211
    }
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   212
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   213
    pub fn protocol_rooms(&self, protocol: u16) -> impl Iterator<Item = RoomId> + '_ {
18240b308505 implement stats message
alfadur
parents: 14786
diff changeset
   214
        self.filter_rooms(move |(_, r)| r.protocol_number == protocol)
13416
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
   215
    }
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
   216
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
   217
    pub fn other_clients_in_room(&self, self_id: ClientId) -> Vec<ClientId> {
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
   218
        let room_id = self.clients[self_id].room_id;
14781
01f8ab45f806 fix lobby joining
alfadur
parents: 14780
diff changeset
   219
        self.collect_clients(|(id, c)| *id != self_id && c.room_id == room_id)
13416
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
   220
    }
14786
8ecdb5c6bb2a implement info, registered only & super power messages
alfadur
parents: 14783
diff changeset
   221
8ecdb5c6bb2a implement info, registered only & super power messages
alfadur
parents: 14783
diff changeset
   222
    pub fn is_registered_only(&self) -> bool {
8ecdb5c6bb2a implement info, registered only & super power messages
alfadur
parents: 14783
diff changeset
   223
        self.flags.contains(ServerFlags::REGISTERED_ONLY)
8ecdb5c6bb2a implement info, registered only & super power messages
alfadur
parents: 14783
diff changeset
   224
    }
8ecdb5c6bb2a implement info, registered only & super power messages
alfadur
parents: 14783
diff changeset
   225
8ecdb5c6bb2a implement info, registered only & super power messages
alfadur
parents: 14783
diff changeset
   226
    pub fn set_is_registered_only(&mut self, value: bool) {
8ecdb5c6bb2a implement info, registered only & super power messages
alfadur
parents: 14783
diff changeset
   227
        self.flags.set(ServerFlags::REGISTERED_ONLY, value)
8ecdb5c6bb2a implement info, registered only & super power messages
alfadur
parents: 14783
diff changeset
   228
    }
13445
d3c86ade3d4d Send the rnd reply to the room only.
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13442
diff changeset
   229
}
14504
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   230
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
   231
fn allocate_room(rooms: &mut Slab<HwRoom>) -> &mut HwRoom {
14504
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   232
    let entry = rooms.vacant_entry();
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
   233
    let room = HwRoom::new(entry.key());
14504
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   234
    entry.insert(room)
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   235
}
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   236
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   237
fn create_room(
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
   238
    client: &mut HwClient,
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
   239
    rooms: &mut Slab<HwRoom>,
14504
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   240
    name: String,
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   241
    password: Option<String>,
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   242
) -> RoomId {
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   243
    let room = allocate_room(rooms);
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   244
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   245
    room.master_id = Some(client.id);
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   246
    room.name = name;
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   247
    room.password = password;
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   248
    room.protocol_number = client.protocol_number;
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   249
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   250
    room.players_number = 1;
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   251
    room.ready_players_number = 1;
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   252
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   253
    client.room_id = Some(room.id);
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   254
    client.set_is_master(true);
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   255
    client.set_is_ready(true);
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   256
    client.set_is_joined_mid_game(false);
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   257
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   258
    room.id
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   259
}
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   260
15075
e935b1ad23f3 normalize type names
alfadur
parents: 15074
diff changeset
   261
fn move_to_room(client: &mut HwClient, room: &mut HwRoom) {
14504
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   262
    debug_assert!(client.room_id != Some(room.id));
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   263
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   264
    room.players_number += 1;
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   265
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   266
    client.room_id = Some(room.id);
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   267
    client.set_is_joined_mid_game(room.game_info.is_some());
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   268
    client.set_is_in_game(room.game_info.is_some());
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   269
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   270
    if let Some(ref mut info) = room.game_info {
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   271
        let teams = info.client_teams(client.id);
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   272
        client.teams_in_game = teams.clone().count() as u8;
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   273
        client.clan = teams.clone().next().map(|t| t.color);
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   274
        let team_names: Vec<_> = teams.map(|t| t.name.clone()).collect();
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   275
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   276
        if !team_names.is_empty() {
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   277
            info.left_teams.retain(|name| !team_names.contains(&name));
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   278
            info.teams_in_game += team_names.len() as u8;
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   279
            room.teams = info
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   280
                .teams_at_start
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   281
                .iter()
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   282
                .filter(|(_, t)| !team_names.contains(&t.name))
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   283
                .cloned()
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   284
                .collect();
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   285
        }
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   286
    }
6cc0fce249f9 Server action refactoring part 1 of N
alfadur <mail@none>
parents: 14457
diff changeset
   287
}