mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
:/ and reactivated the password field
This commit is contained in:
parent
3672f4916e
commit
50b845d1c3
652
Cargo.lock
generated
652
Cargo.lock
generated
File diff suppressed because it is too large
Load Diff
@ -8,6 +8,7 @@ pub enum Error {
|
||||
ServerShutdown,
|
||||
TooManyPlayers,
|
||||
InvalidAuth,
|
||||
AlreadyLoggedIn,
|
||||
//TODO: InvalidAlias,
|
||||
Other(String),
|
||||
}
|
||||
|
@ -105,6 +105,8 @@ impl Client {
|
||||
);
|
||||
}
|
||||
|
||||
log::error!("Auth Server: {:?}", server_info.auth_provider);
|
||||
|
||||
// Initialize `State`
|
||||
let mut state = State::default();
|
||||
let entity = state.ecs_mut().apply_entity_package(entity_package);
|
||||
@ -549,6 +551,7 @@ impl Client {
|
||||
ServerMsg::Error(e) => match e {
|
||||
ServerError::TooManyPlayers => return Err(Error::ServerWentMad),
|
||||
ServerError::InvalidAuth => return Err(Error::InvalidAuth),
|
||||
ServerError::AlreadyLoggedIn => return Err(Error::AlreadyLoggedIn),
|
||||
//TODO: ServerError::InvalidAlias => return Err(Error::InvalidAlias),
|
||||
},
|
||||
ServerMsg::Shutdown => return Err(Error::ServerShutdown),
|
||||
|
@ -21,6 +21,7 @@ pub struct ServerInfo {
|
||||
pub description: String,
|
||||
pub git_hash: String,
|
||||
pub git_date: String,
|
||||
pub auth_provider: Option<String>,
|
||||
}
|
||||
|
||||
#[derive(Debug, Clone, Serialize, Deserialize)]
|
||||
@ -86,6 +87,7 @@ pub enum ServerMsg {
|
||||
pub enum ServerError {
|
||||
TooManyPlayers,
|
||||
InvalidAuth,
|
||||
AlreadyLoggedIn,
|
||||
//TODO: InvalidAlias,
|
||||
}
|
||||
|
||||
|
@ -31,3 +31,4 @@ prometheus = "0.7"
|
||||
prometheus-static-metric = "0.2"
|
||||
rouille = "3.0.0"
|
||||
portpicker = { git = "https://github.com/wusyong/portpicker-rs", branch = "fix_ipv6" }
|
||||
authc = { git = "https://gitlab.com/veloren/auth.git" }
|
@ -1,32 +1,59 @@
|
||||
use authc::{AuthClient, AuthToken};
|
||||
use common::msg::ServerError;
|
||||
use hashbrown::HashMap;
|
||||
use log::{info, warn};
|
||||
use std::str::FromStr;
|
||||
|
||||
pub struct AuthProvider {
|
||||
accounts: HashMap<String, String>,
|
||||
auth_server: Option<AuthClient>,
|
||||
}
|
||||
|
||||
impl AuthProvider {
|
||||
pub fn new() -> Self {
|
||||
pub fn new(auth_addr: Option<String>) -> Self {
|
||||
let auth_server = match auth_addr {
|
||||
Some(addr) => Some(AuthClient::new(addr)),
|
||||
None => None,
|
||||
};
|
||||
|
||||
AuthProvider {
|
||||
accounts: HashMap::new(),
|
||||
auth_server,
|
||||
}
|
||||
}
|
||||
|
||||
pub fn query(&mut self, username: String, password: String) -> bool {
|
||||
let pwd = password.clone();
|
||||
if self.accounts.entry(username.clone()).or_insert_with(|| {
|
||||
info!("Registered new user '{}'", &username);
|
||||
pwd
|
||||
}) == &password
|
||||
{
|
||||
info!("User '{}' successfully authenticated", username);
|
||||
true
|
||||
} else {
|
||||
warn!(
|
||||
"User '{}' attempted to log in with invalid password '{}'!",
|
||||
username, password
|
||||
);
|
||||
false
|
||||
pub fn query(&mut self, username_or_token: String) -> Result<bool, ServerError> {
|
||||
// Based on whether auth server is provided or not we expect an username or
|
||||
// token
|
||||
match &self.auth_server {
|
||||
// Token from auth server expected
|
||||
Some(srv) => {
|
||||
// TODO: Check if already logged in!
|
||||
log::info!("Validating '{}' token.", &username_or_token);
|
||||
match srv.validate(
|
||||
AuthToken::from_str(&username_or_token).expect("Failed parsing token"), // TODO: POSSIBLE DOS, handle result!
|
||||
) {
|
||||
Ok(id) => {
|
||||
// TODO: Get username!
|
||||
self.accounts.insert("peter".into(), id.to_string());
|
||||
Ok(true)
|
||||
}
|
||||
Err(e) => {
|
||||
log::error!("{}", e);
|
||||
Ok(false)
|
||||
}
|
||||
}
|
||||
},
|
||||
// Username is expected
|
||||
None => {
|
||||
if !self.accounts.contains_key(&username_or_token) {
|
||||
log::info!("New User '{}'", username_or_token);
|
||||
self.accounts
|
||||
.insert(username_or_token, "whateverUUID".into()); // TODO: generate UUID
|
||||
Ok(true)
|
||||
} else {
|
||||
Err(ServerError::AlreadyLoggedIn)
|
||||
}
|
||||
},
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -86,7 +86,9 @@ impl Server {
|
||||
let mut state = State::default();
|
||||
state.ecs_mut().insert(EventBus::<ServerEvent>::default());
|
||||
// TODO: anything but this
|
||||
state.ecs_mut().insert(AuthProvider::new());
|
||||
state
|
||||
.ecs_mut()
|
||||
.insert(AuthProvider::new(settings.auth_server_address.clone()));
|
||||
state.ecs_mut().insert(Tick(0));
|
||||
state.ecs_mut().insert(ChunkGenerator::new());
|
||||
// System timers for performance monitoring
|
||||
@ -196,6 +198,7 @@ impl Server {
|
||||
description: settings.server_description.clone(),
|
||||
git_hash: common::util::GIT_HASH.to_string(),
|
||||
git_date: common::util::GIT_DATE.to_string(),
|
||||
auth_provider: settings.auth_server_address.clone(),
|
||||
},
|
||||
metrics: ServerMetrics::new(settings.metrics_address)
|
||||
.expect("Failed to initialize server metrics submodule."),
|
||||
|
@ -10,12 +10,12 @@ const DEFAULT_WORLD_SEED: u32 = 5284;
|
||||
pub struct ServerSettings {
|
||||
pub gameserver_address: SocketAddr,
|
||||
pub metrics_address: SocketAddr,
|
||||
pub auth_server_address: Option<String>,
|
||||
pub max_players: usize,
|
||||
pub world_seed: u32,
|
||||
//pub pvp_enabled: bool,
|
||||
pub server_name: String,
|
||||
pub server_description: String,
|
||||
//pub login_server: whatever
|
||||
pub start_time: f64,
|
||||
pub admins: Vec<String>,
|
||||
/// When set to None, loads the default map file (if available); otherwise,
|
||||
@ -28,6 +28,7 @@ impl Default for ServerSettings {
|
||||
Self {
|
||||
gameserver_address: SocketAddr::from(([0; 4], 14004)),
|
||||
metrics_address: SocketAddr::from(([0; 4], 14005)),
|
||||
auth_server_address: Some("https://auth.veloren.net".into()),
|
||||
world_seed: DEFAULT_WORLD_SEED,
|
||||
server_name: "Veloren Alpha".to_owned(),
|
||||
server_description: "This is the best Veloren server.".to_owned(),
|
||||
@ -107,6 +108,7 @@ impl ServerSettings {
|
||||
[127, 0, 0, 1],
|
||||
pick_unused_port().expect("Failed to find unused port!"),
|
||||
)),
|
||||
auth_server_address: None,
|
||||
// If loading the default map file, make sure the seed is also default.
|
||||
world_seed: if load.map_file.is_some() {
|
||||
load.world_seed
|
||||
|
@ -124,7 +124,12 @@ impl<'a> System<'a> for Sys {
|
||||
},
|
||||
// Valid player
|
||||
ClientMsg::Register { player, password } if player.is_valid() => {
|
||||
if !accounts.query(player.alias.clone(), password) {
|
||||
if !accounts
|
||||
.query(password.clone())
|
||||
.expect("Handle this error!")
|
||||
{
|
||||
// TODO: Graceful error handling!
|
||||
// TODO: Graceful error handling! (e.g. AlreadyLoggedIn)
|
||||
client.error_state(RequestStateError::Denied);
|
||||
break;
|
||||
}
|
||||
|
@ -64,6 +64,7 @@ rust-argon2 = "0.5"
|
||||
bincode = "1.2"
|
||||
deunicode = "1.0"
|
||||
uvth = "3.1.1"
|
||||
authc = { git = "https://gitlab.com/veloren/auth.git" }
|
||||
|
||||
[target.'cfg(target_os = "macos")'.dependencies]
|
||||
dispatch = "0.1.4"
|
||||
|
@ -68,13 +68,40 @@ impl ClientInit {
|
||||
{
|
||||
match Client::new(socket_addr, player.view_distance) {
|
||||
Ok(mut client) => {
|
||||
// Authentication
|
||||
let username_or_token = match &client.server_info.auth_provider
|
||||
{
|
||||
Some(addr) => {
|
||||
let auth_client = authc::AuthClient::new(addr);
|
||||
// TODO: PROMPT USER INCASE OF THE AUTH SERVER BEING
|
||||
// UNKNOWN!
|
||||
log::error!(
|
||||
"Logging in with '{}', '{}'.",
|
||||
&player.alias,
|
||||
&password
|
||||
);
|
||||
match auth_client.sign_in(
|
||||
&player.alias,
|
||||
&password,
|
||||
socket_addr.ip(),
|
||||
) {
|
||||
Ok(token) => token.serialize(),
|
||||
// TODO: Properly deal with it
|
||||
Err(e) => panic!(
|
||||
"Failed to sign in to auth server '{}'! {}",
|
||||
addr, e
|
||||
),
|
||||
}
|
||||
},
|
||||
None => player.alias.clone(),
|
||||
};
|
||||
|
||||
if let Err(ClientError::InvalidAuth) =
|
||||
client.register(player.clone(), password.clone())
|
||||
client.register(player.clone(), username_or_token.clone())
|
||||
{
|
||||
last_err = Some(Error::InvalidAuth);
|
||||
break;
|
||||
}
|
||||
//client.register(player, password);
|
||||
let _ = tx.send(Ok(client));
|
||||
return;
|
||||
},
|
||||
|
@ -8,7 +8,6 @@ use crate::{
|
||||
window::Event,
|
||||
Direction, GlobalState, PlayState, PlayStateResult,
|
||||
};
|
||||
use argon2::{self, Config};
|
||||
use client_init::{ClientInit, Error as InitError};
|
||||
use common::{assets::load_expect, clock::Clock, comp};
|
||||
use log::warn;
|
||||
@ -202,9 +201,10 @@ fn attempt_login(
|
||||
(server_address, server_port, false),
|
||||
player,
|
||||
{
|
||||
let salt = b"staticsalt_zTuGkGvybZIjZbNUDtw15";
|
||||
password
|
||||
/*let salt = b"staticsalt_zTuGkGvybZIjZbNUDtw15";
|
||||
let config = Config::default();
|
||||
argon2::hash_encoded(password.as_bytes(), salt, &config).unwrap()
|
||||
argon2::hash_encoded(password.as_bytes(), salt, &config).unwrap()*/
|
||||
},
|
||||
));
|
||||
}
|
||||
|
@ -90,7 +90,7 @@ image_ids! {
|
||||
button_hover: "voxygen.element.buttons.button_hover",
|
||||
button_press: "voxygen.element.buttons.button_press",
|
||||
input_bg_top: "voxygen.element.misc_bg.textbox_top",
|
||||
//input_bg_mid: "voxygen.element.misc_bg.textbox_mid", <-- For password input
|
||||
input_bg_mid: "voxygen.element.misc_bg.textbox_mid",
|
||||
input_bg_bot: "voxygen.element.misc_bg.textbox_bot",
|
||||
|
||||
|
||||
@ -461,14 +461,14 @@ impl MainMenuUi {
|
||||
}
|
||||
}
|
||||
// Password
|
||||
// TODO: REACTIVATE THIS WHEN A PROPER ACCOUNT SYSTEM IS IN PLACE
|
||||
/*Rectangle::fill_with([320.0, 50.0], color::rgba(0.0, 0.0, 0.0, 0.97))
|
||||
// TODO: Why isn't it showing up?
|
||||
// Password
|
||||
Rectangle::fill_with([320.0, 50.0], color::rgba(0.0, 0.0, 0.0, 0.97))
|
||||
.down_from(self.ids.usrnm_bg, 30.0)
|
||||
.set(self.ids.passwd_bg, ui_widgets);
|
||||
Image::new(self.imgs.input_bg_mid)
|
||||
.w_h(337.0, 67.0)
|
||||
.middle_of(self.ids.passwd_bg)
|
||||
.color(Some(INACTIVE))
|
||||
.set(self.ids.password_bg, ui_widgets);
|
||||
for event in TextBox::new(&self.password)
|
||||
.w_h(290.0, 30.0)
|
||||
@ -485,12 +485,13 @@ impl MainMenuUi {
|
||||
TextBoxEvent::Update(password) => {
|
||||
// Note: TextBox limits the input string length to what fits in it
|
||||
self.password = password;
|
||||
}
|
||||
},
|
||||
TextBoxEvent::Enter => {
|
||||
login!();
|
||||
}
|
||||
},
|
||||
}
|
||||
}*/
|
||||
}
|
||||
|
||||
if self.show_servers {
|
||||
Image::new(self.imgs.info_frame)
|
||||
.mid_top_with_margin_on(self.ids.username_bg, -320.0)
|
||||
@ -556,7 +557,7 @@ impl MainMenuUi {
|
||||
}
|
||||
// Server address
|
||||
Rectangle::fill_with([320.0, 50.0], color::rgba(0.0, 0.0, 0.0, 0.97))
|
||||
.down_from(self.ids.usrnm_bg, 30.0)
|
||||
.down_from(self.ids.passwd_bg, 30.0)
|
||||
.set(self.ids.srvr_bg, ui_widgets);
|
||||
Image::new(self.imgs.input_bg_bot)
|
||||
.w_h(337.0, 67.0)
|
||||
@ -582,6 +583,7 @@ impl MainMenuUi {
|
||||
},
|
||||
}
|
||||
}
|
||||
|
||||
// Login button
|
||||
if Button::image(self.imgs.button)
|
||||
.hover_image(self.imgs.button_hover)
|
||||
|
Loading…
Reference in New Issue
Block a user