1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
/*
* This file is part of laurelin/client
* Copyright (C) 2023 Jonni Liljamo <jonni@liljamo.com>
*
* Licensed under GPL-3.0-only.
* See LICENSE for licensing information.
*/
use bevy::prelude::*;
use laurelin_shared::server::{channels::AfterAuthChannel, messages::AfterAuth};
use naia_bevy_client::{
events::{ClientTickEvent, ConnectEvent, DisconnectEvent, MessageEvents, RejectEvent},
Client,
};
use crate::{
cfg::CfgUser,
plugins::menu::{
ui::connect::{ConnectScreenData, ConnectState},
MenuState,
},
};
pub fn connect_events(mut ev: EventReader<ConnectEvent>, client: Client) {
for _ in ev.iter() {
if let Ok(server_address) = client.server_address() {
info!("Laurelin client connected to: '{}'", server_address);
}
}
}
pub fn reject_events(mut ev: EventReader<RejectEvent>, mut data: ResMut<ConnectScreenData>) {
for _ in ev.iter() {
warn!("Laurelin client rejected from connecting to server!");
data.error = "rejected from connecting".to_string();
data.state = if data.state == ConnectState::LoggingIn {
ConnectState::Login
} else {
ConnectState::Register
}
}
}
pub fn disconnect_events(mut ev: EventReader<DisconnectEvent>) {
for _ in ev.iter() {
info!("Laurelin client disconnected from server.");
}
}
pub fn message_events(
mut commands: Commands,
mut ev: EventReader<MessageEvents>,
mut cfg_user: ResMut<CfgUser>,
mut data: ResMut<ConnectScreenData>,
) {
for events in ev.iter() {
for aa_message in events.read::<AfterAuthChannel, AfterAuth>() {
// TODO: move handling to a separate function?
// save details from AfterAuth
cfg_user.username = aa_message.username;
cfg_user.cookie = aa_message.cookie;
// reset the connection screen to login
data.state = ConnectState::Login;
// take us to the main menu
commands.insert_resource(NextState(Some(MenuState::Menu)));
}
}
}
pub fn tick_events(mut ev: EventReader<ClientTickEvent>, client: Client) {
if !client.is_connected() {
return;
}
for ClientTickEvent(_tick) in ev.iter() {}
}