ACCOUNT CREATION AND LOGIN
This commit is contained in:
@@ -7,14 +7,14 @@ use net::{ClientSender, ConAccepter, listen};
|
||||
use openworm::{
|
||||
net::{
|
||||
ClientMsg, ClientRequestMsg, CreateAccount, CreateAccountResp, DisconnectReason, LoadMsg,
|
||||
RecvHandler, ServerError, ServerMsg, install_crypto_provider,
|
||||
Login, LoginResp, RecvHandler, ServerError, ServerMsg, install_crypto_provider,
|
||||
},
|
||||
rsc::DataDir,
|
||||
};
|
||||
use rand::distr::{Alphanumeric, SampleString};
|
||||
use scrypt::{
|
||||
Scrypt,
|
||||
password_hash::{PasswordHasher, SaltString, rand_core::OsRng},
|
||||
password_hash::{PasswordHash, PasswordHasher, PasswordVerifier, SaltString, rand_core::OsRng},
|
||||
};
|
||||
use std::{
|
||||
collections::HashMap,
|
||||
@@ -41,9 +41,8 @@ fn main() {
|
||||
|
||||
#[tokio::main]
|
||||
pub async fn run_server(port: u16) {
|
||||
let dir = DataDir::default();
|
||||
let path = dir.get().join("server");
|
||||
let db = Db::open(path.join("db"));
|
||||
let dir = DataDir::new(Some("server"));
|
||||
let db = Db::open(dir.path.join("db"));
|
||||
let handler = ServerListener {
|
||||
senders: Default::default(),
|
||||
count: 0.into(),
|
||||
@@ -53,7 +52,7 @@ pub async fn run_server(port: u16) {
|
||||
let token = account_token(&db, ServerPerms::ACCOUNT_TOKENS);
|
||||
println!("no users found, token for admin: {token}");
|
||||
}
|
||||
let (endpoint, handle) = listen(port, &path, handler);
|
||||
let (endpoint, handle) = listen(port, &dir.path, handler);
|
||||
let _ = ctrl_c().await;
|
||||
println!("stopping server");
|
||||
println!("closing connections...");
|
||||
@@ -171,7 +170,6 @@ impl RecvHandler<ClientRequestMsg> for ClientHandler {
|
||||
token,
|
||||
username,
|
||||
password,
|
||||
login_key,
|
||||
} = &info;
|
||||
let salt = SaltString::generate(&mut OsRng);
|
||||
let params = scrypt::Params::new(11, 8, 1, 32).unwrap();
|
||||
@@ -214,24 +212,26 @@ impl RecvHandler<ClientRequestMsg> for ClientHandler {
|
||||
println!("account created: \"{username}\"");
|
||||
*self.state.write().await = ClientState::Authed(id);
|
||||
let _ = replier.send(CreateAccountResp::Ok { id }).await;
|
||||
} // ClientMsgType::Login { username, password } => {
|
||||
// let Some(id) = self.db.usernames.get(&username) else {
|
||||
// let _ = self.send.send(ServerError::UnknownUsername).await;
|
||||
// return;
|
||||
// };
|
||||
// let Some(user) = self.db.users.get(&id) else {
|
||||
// panic!("invalid state! (should be a user)");
|
||||
// };
|
||||
// let hash = PasswordHash::new(&user.password_hash).unwrap();
|
||||
// if Scrypt.verify_password(password.as_bytes(), &hash).is_err() {
|
||||
// println!("invalid password: \"{username}\"");
|
||||
// let _ = self.send.send(ServerError::InvalidPassword).await;
|
||||
// return;
|
||||
// }
|
||||
// println!("login: \"{username}\"");
|
||||
// *self.state.write().await = ClientState::Authed(id);
|
||||
// let _ = self.send.send(ServerMsgType::Login { username }).await;
|
||||
// }
|
||||
}
|
||||
ClientMsg::Login(info) => {
|
||||
let Login { username, password } = &info;
|
||||
let Some(id) = self.db.usernames.get(username) else {
|
||||
let _ = replier.send(LoginResp::UnknownUsername).await;
|
||||
return;
|
||||
};
|
||||
let Some(user) = self.db.users.get(&id) else {
|
||||
panic!("invalid state! (should be a user)");
|
||||
};
|
||||
let hash = PasswordHash::new(&user.password_hash).unwrap();
|
||||
if Scrypt.verify_password(password.as_bytes(), &hash).is_err() {
|
||||
println!("invalid password: \"{username}\"");
|
||||
let _ = replier.send(LoginResp::InvalidPassword).await;
|
||||
return;
|
||||
}
|
||||
println!("login: \"{username}\"");
|
||||
*self.state.write().await = ClientState::Authed(id);
|
||||
let _ = replier.send(LoginResp::Ok { id }).await;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -39,7 +39,7 @@ pub fn init_endpoint(port: u16, data_path: &Path) -> Endpoint {
|
||||
};
|
||||
print!("cert hex: ");
|
||||
for x in cert.iter() {
|
||||
print!("{:x}", x);
|
||||
print!("{:02x}", x);
|
||||
}
|
||||
println!();
|
||||
let server_config = ServerConfig::with_single_cert(vec![cert], key).unwrap();
|
||||
|
||||
Reference in New Issue
Block a user