author | alfadur |
Tue, 28 May 2019 19:04:18 +0300 | |
changeset 15079 | c5a6e8566425 |
parent 14912 | rust/hedgewars-server/src/server/handlers.rs@c156273b57de |
child 15080 | e935b1ad23f3 |
permissions | -rw-r--r-- |
12154 | 1 |
use mio; |
14784
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
2 |
use std::{collections::HashMap, io, io::Write}; |
12154 | 3 |
|
15079 | 4 |
use self::{ |
5 |
actions::{Destination, DestinationGroup, PendingMessage}, |
|
6 |
inanteroom::LoginResult |
|
14699 | 7 |
}; |
14676
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
8 |
use crate::{ |
15079 | 9 |
core::{ |
10 |
server::HWServer, |
|
11 |
types::{ClientId, Replay, RoomId, GameCfg, TeamInfo}, |
|
12 |
room::RoomSave |
|
13 |
}, |
|
14 |
protocol::messages::{ |
|
15 |
server_chat, |
|
16 |
HWProtocolMessage, |
|
17 |
HWServerMessage, |
|
18 |
HWServerMessage::*, |
|
19 |
global_chat, |
|
20 |
HWProtocolMessage::EngineMessage |
|
21 |
}, |
|
14698 | 22 |
utils, |
14676
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
23 |
}; |
14698 | 24 |
use base64::encode; |
13810 | 25 |
use log::*; |
14698 | 26 |
use rand::{thread_rng, RngCore}; |
13671 | 27 |
|
15079 | 28 |
mod actions; |
14462 | 29 |
mod checker; |
30 |
mod common; |
|
12154 | 31 |
mod inroom; |
15079 | 32 |
mod inlobby; |
33 |
mod inanteroom; |
|
12154 | 34 |
|
14784
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
35 |
use std::fmt::{Formatter, LowerHex}; |
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 |
#[derive(PartialEq)] |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
38 |
pub struct Sha1Digest([u8; 20]); |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
39 |
|
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
40 |
impl Sha1Digest { |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
41 |
pub fn new(digest: [u8; 20]) -> Self { |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
42 |
Self(digest) |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
43 |
} |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
44 |
} |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
45 |
|
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
46 |
impl LowerHex for Sha1Digest { |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
47 |
fn fmt(&self, f: &mut Formatter) -> Result<(), std::fmt::Error> { |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
48 |
for byte in &self.0 { |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
49 |
write!(f, "{:02x}", byte)?; |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
50 |
} |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
51 |
Ok(()) |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
52 |
} |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
53 |
} |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
54 |
|
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
55 |
pub struct AccountInfo { |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
56 |
pub is_registered: bool, |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
57 |
pub is_admin: bool, |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
58 |
pub is_contributor: bool, |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
59 |
pub server_hash: Sha1Digest, |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
60 |
} |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
61 |
|
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
62 |
pub enum IoTask { |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
63 |
GetAccount { |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
64 |
nick: String, |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
65 |
protocol: u16, |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
66 |
password_hash: String, |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
67 |
client_salt: String, |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
68 |
server_salt: String, |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
69 |
}, |
14790
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
70 |
GetReplay { |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
71 |
id: u32, |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
72 |
}, |
14785 | 73 |
SaveRoom { |
74 |
room_id: RoomId, |
|
75 |
filename: String, |
|
76 |
contents: String, |
|
77 |
}, |
|
78 |
LoadRoom { |
|
79 |
room_id: RoomId, |
|
14786 | 80 |
filename: String, |
81 |
}, |
|
14784
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
82 |
} |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
83 |
|
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
84 |
pub enum IoResult { |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
85 |
Account(Option<AccountInfo>), |
14790
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
86 |
Replay(Option<Replay>), |
14785 | 87 |
SaveRoom(RoomId, bool), |
14786 | 88 |
LoadRoom(RoomId, Option<String>), |
14784
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
89 |
} |
14698 | 90 |
|
14676
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
91 |
pub struct Response { |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
92 |
client_id: ClientId, |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
93 |
messages: Vec<PendingMessage>, |
14784
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
94 |
io_tasks: Vec<IoTask>, |
14701 | 95 |
removed_clients: Vec<ClientId>, |
14676
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
96 |
} |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
97 |
|
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
98 |
impl Response { |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
99 |
pub fn new(client_id: ClientId) -> Self { |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
100 |
Self { |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
101 |
client_id, |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
102 |
messages: vec![], |
14784
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
103 |
io_tasks: vec![], |
14701 | 104 |
removed_clients: vec![], |
14676
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
105 |
} |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
106 |
} |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
107 |
|
14677
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
108 |
#[inline] |
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
109 |
pub fn is_empty(&self) -> bool { |
14784
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
110 |
self.messages.is_empty() && self.removed_clients.is_empty() && self.io_tasks.is_empty() |
14677
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
111 |
} |
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
112 |
|
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
113 |
#[inline] |
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
114 |
pub fn len(&self) -> usize { |
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
115 |
self.messages.len() |
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
116 |
} |
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
117 |
|
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
118 |
#[inline] |
14676
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
119 |
pub fn client_id(&self) -> ClientId { |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
120 |
self.client_id |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
121 |
} |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
122 |
|
14677
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
123 |
#[inline] |
14676
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
124 |
pub fn add(&mut self, message: PendingMessage) { |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
125 |
self.messages.push(message) |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
126 |
} |
14677
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
127 |
|
14784
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
128 |
#[inline] |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
129 |
pub fn request_io(&mut self, task: IoTask) { |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
130 |
self.io_tasks.push(task) |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
131 |
} |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
132 |
|
14677
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
133 |
pub fn extract_messages<'a, 'b: 'a>( |
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
134 |
&'b mut self, |
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
135 |
server: &'a HWServer, |
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
136 |
) -> impl Iterator<Item = (Vec<ClientId>, HWServerMessage)> + 'a { |
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
137 |
let client_id = self.client_id; |
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
138 |
self.messages.drain(..).map(move |m| { |
14793 | 139 |
let ids = get_recipients(server, client_id, m.destination); |
14677
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
140 |
(ids, m.message) |
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
141 |
}) |
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
142 |
} |
14701 | 143 |
|
144 |
pub fn remove_client(&mut self, client_id: ClientId) { |
|
145 |
self.removed_clients.push(client_id); |
|
146 |
} |
|
147 |
||
148 |
pub fn extract_removed_clients(&mut self) -> impl Iterator<Item = ClientId> + '_ { |
|
149 |
self.removed_clients.drain(..) |
|
150 |
} |
|
14784
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
151 |
|
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
152 |
pub fn extract_io_tasks(&mut self) -> impl Iterator<Item = IoTask> + '_ { |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
153 |
self.io_tasks.drain(..) |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
154 |
} |
14677
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
155 |
} |
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
156 |
|
14692
5122c584804e
Server action refactoring part A of N
alfadur <mail@none>
parents:
14678
diff
changeset
|
157 |
impl Extend<PendingMessage> for Response { |
5122c584804e
Server action refactoring part A of N
alfadur <mail@none>
parents:
14678
diff
changeset
|
158 |
fn extend<T: IntoIterator<Item = PendingMessage>>(&mut self, iter: T) { |
5122c584804e
Server action refactoring part A of N
alfadur <mail@none>
parents:
14678
diff
changeset
|
159 |
for msg in iter { |
5122c584804e
Server action refactoring part A of N
alfadur <mail@none>
parents:
14678
diff
changeset
|
160 |
self.add(msg) |
5122c584804e
Server action refactoring part A of N
alfadur <mail@none>
parents:
14678
diff
changeset
|
161 |
} |
5122c584804e
Server action refactoring part A of N
alfadur <mail@none>
parents:
14678
diff
changeset
|
162 |
} |
5122c584804e
Server action refactoring part A of N
alfadur <mail@none>
parents:
14678
diff
changeset
|
163 |
} |
5122c584804e
Server action refactoring part A of N
alfadur <mail@none>
parents:
14678
diff
changeset
|
164 |
|
14677
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
165 |
fn get_recipients( |
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
166 |
server: &HWServer, |
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
167 |
client_id: ClientId, |
14793 | 168 |
destination: Destination, |
14677
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
169 |
) -> Vec<ClientId> { |
14793 | 170 |
match destination { |
14677
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
171 |
Destination::ToSelf => vec![client_id], |
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
172 |
Destination::ToId(id) => vec![id], |
14793 | 173 |
Destination::ToIds(ids) => ids, |
174 |
Destination::ToAll { group, skip_self } => { |
|
14794 | 175 |
let mut ids: Vec<_> = match group { |
176 |
DestinationGroup::All => server.all_clients().collect(), |
|
177 |
DestinationGroup::Lobby => server.lobby_clients().collect(), |
|
178 |
DestinationGroup::Protocol(proto) => server.protocol_clients(proto).collect(), |
|
179 |
DestinationGroup::Room(id) => server.room_clients(id).collect(), |
|
14793 | 180 |
}; |
181 |
||
182 |
if skip_self { |
|
183 |
if let Some(index) = ids.iter().position(|id| *id == client_id) { |
|
184 |
ids.remove(index); |
|
185 |
} |
|
186 |
} |
|
187 |
||
188 |
ids |
|
14677
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
189 |
} |
6e6632068a33
Server action refactoring part 3 of N
alfadur <mail@none>
parents:
14676
diff
changeset
|
190 |
} |
14676
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
191 |
} |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
192 |
|
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
193 |
pub fn handle( |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
194 |
server: &mut HWServer, |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
195 |
client_id: ClientId, |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
196 |
response: &mut Response, |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
197 |
message: HWProtocolMessage, |
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
198 |
) { |
12154 | 199 |
match message { |
14698 | 200 |
HWProtocolMessage::Ping => response.add(Pong.send_self()), |
201 |
_ => { |
|
202 |
if server.anteroom.clients.contains(client_id) { |
|
15079 | 203 |
match inanteroom::handle(server, client_id, response, message) { |
14698 | 204 |
LoginResult::Unchanged => (), |
205 |
LoginResult::Complete => { |
|
206 |
if let Some(client) = server.anteroom.remove_client(client_id) { |
|
207 |
server.add_client(client_id, client); |
|
14786 | 208 |
common::join_lobby(server, response); |
14698 | 209 |
} |
210 |
} |
|
211 |
LoginResult::Exit => { |
|
212 |
server.anteroom.remove_client(client_id); |
|
14701 | 213 |
response.remove_client(client_id); |
14698 | 214 |
} |
215 |
} |
|
14801 | 216 |
} else if server.clients.contains(client_id) { |
14698 | 217 |
match message { |
218 |
HWProtocolMessage::Quit(Some(msg)) => { |
|
219 |
common::remove_client(server, response, "User quit: ".to_string() + &msg); |
|
220 |
} |
|
221 |
HWProtocolMessage::Quit(None) => { |
|
222 |
common::remove_client(server, response, "User quit".to_string()); |
|
223 |
} |
|
14791
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
224 |
HWProtocolMessage::Info(nick) => { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
225 |
if let Some(client) = server.find_client(&nick) { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
226 |
let admin_sign = if client.is_admin() { "@" } else { "" }; |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
227 |
let master_sign = if client.is_master() { "+" } else { "" }; |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
228 |
let room_info = match client.room_id { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
229 |
Some(room_id) => { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
230 |
let room = &server.rooms[room_id]; |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
231 |
let status = match room.game_info { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
232 |
Some(_) if client.teams_in_game == 0 => "(spectating)", |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
233 |
Some(_) => "(playing)", |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
234 |
None => "", |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
235 |
}; |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
236 |
format!( |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
237 |
"[{}{}room {}]{}", |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
238 |
admin_sign, master_sign, room.name, status |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
239 |
) |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
240 |
} |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
241 |
None => format!("[{}lobby]", admin_sign), |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
242 |
}; |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
243 |
|
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
244 |
let info = vec![ |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
245 |
client.nick.clone(), |
14807 | 246 |
"[]".to_string(), |
14791
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
247 |
utils::protocol_version_string(client.protocol_number).to_string(), |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
248 |
room_info, |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
249 |
]; |
14807 | 250 |
response.add(Info(info).send_self()) |
14791
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
251 |
} else { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
252 |
response |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
253 |
.add(server_chat("Player is not online.".to_string()).send_self()) |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
254 |
} |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
255 |
} |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
256 |
HWProtocolMessage::ToggleServerRegisteredOnly => { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
257 |
if !server.clients[client_id].is_admin() { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
258 |
response.add(Warning("Access denied.".to_string()).send_self()); |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
259 |
} else { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
260 |
server.set_is_registered_only(server.is_registered_only()); |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
261 |
let msg = if server.is_registered_only() { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
262 |
"This server no longer allows unregistered players to join." |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
263 |
} else { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
264 |
"This server now allows unregistered players to join." |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
265 |
}; |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
266 |
response.add(server_chat(msg.to_string()).send_all()); |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
267 |
} |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
268 |
} |
14790
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
269 |
HWProtocolMessage::Global(msg) => { |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
270 |
if !server.clients[client_id].is_admin() { |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
271 |
response.add(Warning("Access denied.".to_string()).send_self()); |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
272 |
} else { |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
273 |
response.add(global_chat(msg).send_all()) |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
274 |
} |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
275 |
} |
14791
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
276 |
HWProtocolMessage::SuperPower => { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
277 |
if !server.clients[client_id].is_admin() { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
278 |
response.add(Warning("Access denied.".to_string()).send_self()); |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
279 |
} else { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
280 |
server.clients[client_id].set_has_super_power(true); |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
281 |
response |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
282 |
.add(server_chat("Super power activated.".to_string()).send_self()) |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
283 |
} |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
284 |
} |
14790
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
285 |
HWProtocolMessage::Watch(id) => { |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
286 |
#[cfg(feature = "official-server")] |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
287 |
{ |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
288 |
response.request_io(IoTask::GetReplay { id }) |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
289 |
} |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
290 |
|
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
291 |
#[cfg(not(feature = "official-server"))] |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
292 |
{ |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
293 |
response.add( |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
294 |
Warning("This server does not support replays!".to_string()) |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
295 |
.send_self(), |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
296 |
); |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
297 |
} |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
298 |
} |
14698 | 299 |
_ => match server.clients[client_id].room_id { |
15079 | 300 |
None => inlobby::handle(server, client_id, response, message), |
14698 | 301 |
Some(room_id) => { |
302 |
inroom::handle(server, client_id, response, room_id, message) |
|
303 |
} |
|
304 |
}, |
|
305 |
} |
|
14676
455865ccd36c
Server action refactoring part 2 of N
alfadur <mail@none>
parents:
14462
diff
changeset
|
306 |
} |
14698 | 307 |
} |
12154 | 308 |
} |
309 |
} |
|
14678
08a8605bafaf
Server action refactoring part 4 of N
alfadur <mail@none>
parents:
14677
diff
changeset
|
310 |
|
14698 | 311 |
pub fn handle_client_accept(server: &mut HWServer, client_id: ClientId, response: &mut Response) { |
312 |
let mut salt = [0u8; 18]; |
|
313 |
thread_rng().fill_bytes(&mut salt); |
|
314 |
||
315 |
server.anteroom.add_client(client_id, encode(&salt)); |
|
316 |
||
14788 | 317 |
response.add(HWServerMessage::Connected(utils::SERVER_VERSION).send_self()); |
14698 | 318 |
} |
319 |
||
14678
08a8605bafaf
Server action refactoring part 4 of N
alfadur <mail@none>
parents:
14677
diff
changeset
|
320 |
pub fn handle_client_loss(server: &mut HWServer, client_id: ClientId, response: &mut Response) { |
14701 | 321 |
if server.anteroom.remove_client(client_id).is_none() { |
322 |
common::remove_client(server, response, "Connection reset".to_string()); |
|
323 |
} |
|
14678
08a8605bafaf
Server action refactoring part 4 of N
alfadur <mail@none>
parents:
14677
diff
changeset
|
324 |
} |
14784
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
325 |
|
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
326 |
pub fn handle_io_result( |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
327 |
server: &mut HWServer, |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
328 |
client_id: ClientId, |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
329 |
response: &mut Response, |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
330 |
io_result: IoResult, |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
331 |
) { |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
332 |
match io_result { |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
333 |
IoResult::Account(Some(info)) => { |
14791
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
334 |
if !info.is_registered && server.is_registered_only() { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
335 |
response.add( |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
336 |
Bye("This server only allows registered users to join.".to_string()) |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
337 |
.send_self(), |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
338 |
); |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
339 |
response.remove_client(client_id); |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
340 |
} else { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
341 |
response.add(ServerAuth(format!("{:x}", info.server_hash)).send_self()); |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
342 |
if let Some(client) = server.anteroom.remove_client(client_id) { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
343 |
server.add_client(client_id, client); |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
344 |
let client = &mut server.clients[client_id]; |
14796 | 345 |
client.set_is_registered(info.is_registered); |
14791
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
346 |
client.set_is_admin(info.is_admin); |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
347 |
client.set_is_contributor(info.is_admin) |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14790
diff
changeset
|
348 |
} |
14784
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
349 |
} |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
350 |
} |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
351 |
IoResult::Account(None) => { |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
352 |
response.add(Error("Authentication failed.".to_string()).send_self()); |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
353 |
response.remove_client(client_id); |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
354 |
} |
14790
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
355 |
IoResult::Replay(Some(replay)) => { |
14912 | 356 |
let protocol = server.clients[client_id].protocol_number; |
357 |
let start_msg = if protocol < 58 { |
|
358 |
RoomJoined(vec![server.clients[client_id].nick.clone()]) |
|
359 |
} else { |
|
360 |
ReplayStart |
|
361 |
}; |
|
362 |
response.add(start_msg.send_self()); |
|
363 |
||
14790
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
364 |
common::get_room_config_impl(&replay.config, client_id, response); |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
365 |
common::get_teams(replay.teams.iter(), client_id, response); |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
366 |
response.add(RunGame.send_self()); |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
367 |
response.add(ForwardEngineMessage(replay.message_log).send_self()); |
14912 | 368 |
|
369 |
if protocol < 58 { |
|
370 |
response.add(Kicked.send_self()); |
|
371 |
} |
|
14790
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
372 |
} |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
373 |
IoResult::Replay(None) => { |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
374 |
response.add(Warning("Could't load the replay".to_string()).send_self()) |
a1077e8d26f4
implement watch message apart from replay deserializing
alfadur
parents:
14789
diff
changeset
|
375 |
} |
14785 | 376 |
IoResult::SaveRoom(_, true) => { |
377 |
response.add(server_chat("Room configs saved successfully.".to_string()).send_self()); |
|
378 |
} |
|
379 |
IoResult::SaveRoom(_, false) => { |
|
14786 | 380 |
response.add(Warning("Unable to save the room configs.".to_string()).send_self()); |
14785 | 381 |
} |
382 |
IoResult::LoadRoom(room_id, Some(contents)) => { |
|
383 |
if let Some(ref mut room) = server.rooms.get_mut(room_id) { |
|
384 |
match room.set_saves(&contents) { |
|
385 |
Ok(_) => response.add( |
|
14786 | 386 |
server_chat("Room configs loaded successfully.".to_string()).send_self(), |
14785 | 387 |
), |
388 |
Err(e) => { |
|
389 |
warn!("Error while deserializing the room configs: {}", e); |
|
390 |
response.add( |
|
391 |
Warning("Unable to deserialize the room configs.".to_string()) |
|
392 |
.send_self(), |
|
393 |
); |
|
394 |
} |
|
395 |
} |
|
396 |
} |
|
397 |
} |
|
14786 | 398 |
IoResult::LoadRoom(_, None) => { |
399 |
response.add(Warning("Unable to load the room configs.".to_string()).send_self()); |
|
14785 | 400 |
} |
14784
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
401 |
} |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14701
diff
changeset
|
402 |
} |