Compare commits
2 Commits
7099881173
...
c865c09649
Author | SHA1 | Date | |
---|---|---|---|
c865c09649 | |||
80fce3f115 |
@ -17,6 +17,7 @@ use yggdrasil::*;
|
|||||||
|
|
||||||
mod dump;
|
mod dump;
|
||||||
mod search;
|
mod search;
|
||||||
|
mod passwd;
|
||||||
mod add_account;
|
mod add_account;
|
||||||
mod add_profile;
|
mod add_profile;
|
||||||
mod del_account;
|
mod del_account;
|
||||||
@ -54,6 +55,10 @@ pub async fn start(db: &Database) -> Result<()> {
|
|||||||
|
|
||||||
"search" => search::Search::exec(args, &db).await?,
|
"search" => search::Search::exec(args, &db).await?,
|
||||||
|
|
||||||
|
"setpasswd" |
|
||||||
|
"set-passwd" |
|
||||||
|
"passwd" => passwd::Passwd::exec(args, &db).await?,
|
||||||
|
|
||||||
"addaccount" |
|
"addaccount" |
|
||||||
"add-account" => add_account::AddAccount::exec(args, &db).await?,
|
"add-account" => add_account::AddAccount::exec(args, &db).await?,
|
||||||
|
|
||||||
|
@ -0,0 +1,53 @@
|
|||||||
|
/*
|
||||||
|
* Yggdrasil: Minecraft authentication server
|
||||||
|
* Copyright (C) 2023 0xf8.dev@proton.me
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
use std::str::FromStr;
|
||||||
|
|
||||||
|
use anyhow::{bail, Result};
|
||||||
|
use log::{info, warn};
|
||||||
|
|
||||||
|
use yggdrasil::*;
|
||||||
|
use yggdrasil::structs::account::Account;
|
||||||
|
use yggdrasil::structs::profile::Profile;
|
||||||
|
use yggdrasil::structs::token::Token;
|
||||||
|
|
||||||
|
use crate::dbtool::Args;
|
||||||
|
|
||||||
|
pub struct Passwd {}
|
||||||
|
|
||||||
|
impl Passwd {
|
||||||
|
pub async fn exec(args: Args, db: &Database) -> Result<()> {
|
||||||
|
if args.arguments.len() < 1 { bail!("Not enough arguments. passwd <account-id>") }
|
||||||
|
|
||||||
|
// Get id
|
||||||
|
let id = i64::from_str(args.arguments.get(0).unwrap())?;
|
||||||
|
|
||||||
|
// Get account
|
||||||
|
let Some(account) = Account::from_id(db, id).await else {
|
||||||
|
bail!("Account(id = {id}) doesn't exist")
|
||||||
|
};
|
||||||
|
|
||||||
|
// Get password
|
||||||
|
let password = Input::password().await?;
|
||||||
|
|
||||||
|
info!("Password: ...{{{}}}", password.len());
|
||||||
|
|
||||||
|
// Change password
|
||||||
|
account.set_password(db, password).await?;
|
||||||
|
|
||||||
|
// Invalidate old tokens
|
||||||
|
Token::delete_all_from(db, account).await?;
|
||||||
|
|
||||||
|
info!("Changed successfully!");
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
}
|
@ -9,3 +9,15 @@
|
|||||||
* You should have received a copy of the GNU General Public License along with this program. If not, see <https://www.gnu.org/licenses/>.
|
* You should have received a copy of the GNU General Public License along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
pub use log::{info, log, warn};
|
||||||
|
pub use tide::{Middleware, prelude::*, Request, Response, Result, utils::After};
|
||||||
|
|
||||||
|
pub use yggdrasil::*;
|
||||||
|
|
||||||
|
pub fn nest(db: Database) -> tide::Server<Database> {
|
||||||
|
info!("Loading nest");
|
||||||
|
|
||||||
|
let mut nest = tide::with_state(db.to_owned());
|
||||||
|
|
||||||
|
nest
|
||||||
|
}
|
@ -19,6 +19,7 @@ pub mod authlib;
|
|||||||
pub mod profile;
|
pub mod profile;
|
||||||
pub mod session;
|
pub mod session;
|
||||||
pub mod aliases;
|
pub mod aliases;
|
||||||
|
pub mod admin;
|
||||||
|
|
||||||
pub async fn start(db: &Database) -> anyhow::Result<()> {
|
pub async fn start(db: &Database) -> anyhow::Result<()> {
|
||||||
let mut app = tide::with_state(db.to_owned());
|
let mut app = tide::with_state(db.to_owned());
|
||||||
@ -53,13 +54,14 @@ pub async fn start(db: &Database) -> anyhow::Result<()> {
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Routes
|
// Routes
|
||||||
|
app.at("/").nest(aliases::nest(db.to_owned()));
|
||||||
|
|
||||||
app.at("/auth/").nest(auth::nest(db.to_owned()));
|
app.at("/auth/").nest(auth::nest(db.to_owned()));
|
||||||
app.at("/session/").nest(session::nest(db.to_owned()));
|
app.at("/session/").nest(session::nest(db.to_owned()));
|
||||||
|
|
||||||
app.at("/authlib/").nest(authlib::nest(db.to_owned()));
|
app.at("/authlib/").nest(authlib::nest(db.to_owned()));
|
||||||
|
|
||||||
app.at("/").nest(aliases::nest(db.to_owned()));
|
app.at("/admin/").nest(admin::nest(db.to_owned()));
|
||||||
|
|
||||||
|
|
||||||
// Listen
|
// Listen
|
||||||
app.listen(format!("{}:{}", &db.config.address, &db.config.port)).await?;
|
app.listen(format!("{}:{}", &db.config.address, &db.config.port)).await?;
|
||||||
|
@ -15,9 +15,6 @@ use tide::{Request, Result};
|
|||||||
use yggdrasil::Database;
|
use yggdrasil::Database;
|
||||||
|
|
||||||
pub async fn delete_skin(req: Request<Database>) -> Result {
|
pub async fn delete_skin(req: Request<Database>) -> Result {
|
||||||
// let authorization = req.header("authorization");
|
|
||||||
// if (authorization.is_none()) { return Err(YggdrasilError::new_base().into()) }
|
|
||||||
|
|
||||||
Err(tide::Error::new(501, anyhow!("Not implemented yet")).into())
|
Err(tide::Error::new(501, anyhow!("Not implemented yet")).into())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -75,6 +75,16 @@ impl Account {
|
|||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub async fn set_password(&self, db: &Database, password: String) -> Result<()> {
|
||||||
|
let password_hash = bcrypt::hash(password, 12)?;
|
||||||
|
|
||||||
|
sqlx::query!("UPDATE accounts SET password_hash = $1 WHERE id = $2", password_hash, self.id)
|
||||||
|
.execute(&db.pool)
|
||||||
|
.await?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
pub async fn new(db: &Database, email: String, language: String, country: String, password: String) -> Result<Account> {
|
pub async fn new(db: &Database, email: String, language: String, country: String, password: String) -> Result<Account> {
|
||||||
let password_hash = bcrypt::hash(password, 12)?;
|
let password_hash = bcrypt::hash(password, 12)?;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user