Fix hash_joined.rs
This commit is contained in:
parent
49f462370a
commit
4e3bfad908
@ -10,16 +10,17 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
use anyhow::anyhow;
|
use anyhow::anyhow;
|
||||||
|
use log::info;
|
||||||
use tide::{prelude::*, Request, Result};
|
use tide::{prelude::*, Request, Result};
|
||||||
|
|
||||||
use yggdrasil::Database;
|
use yggdrasil::Database;
|
||||||
use yggdrasil::errors::YggdrasilError;
|
use yggdrasil::errors::YggdrasilError;
|
||||||
|
use yggdrasil::structs::game_profile::GameProfile;
|
||||||
use yggdrasil::structs::profile::Profile;
|
use yggdrasil::structs::profile::Profile;
|
||||||
use yggdrasil::structs::session::Session;
|
use yggdrasil::structs::session::Session;
|
||||||
use yggdrasil::structs::game_profile::GameProfile;
|
|
||||||
|
|
||||||
#[derive(Deserialize, Debug)]
|
#[derive(Deserialize, Debug)]
|
||||||
struct HasJoinedBody {
|
struct HasJoinedQuery {
|
||||||
pub username: String,
|
pub username: String,
|
||||||
|
|
||||||
#[serde(rename = "serverId")]
|
#[serde(rename = "serverId")]
|
||||||
@ -29,13 +30,13 @@ struct HasJoinedBody {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub async fn has_joined(mut req: Request<Database>) -> Result {
|
pub async fn has_joined(mut req: Request<Database>) -> Result {
|
||||||
let Ok(body) = req.body_json::<HasJoinedBody>().await else {
|
let Ok(query) = req.query::<HasJoinedQuery>() else {
|
||||||
// No args
|
// No args
|
||||||
return Err(YggdrasilError::new_bad_request("One or more required fields was missing.").into())
|
return Err(YggdrasilError::new_bad_request("One or more required fields was missing.").into())
|
||||||
};
|
};
|
||||||
|
|
||||||
// Get profile
|
// Get profile
|
||||||
let Some(profile) = Profile::from_name(req.state(), body.username).await else {
|
let Some(profile) = Profile::from_name(req.state(), query.username.to_string()).await else {
|
||||||
return Err(YggdrasilError::new_bad_request("Profile does not exist.").into())
|
return Err(YggdrasilError::new_bad_request("Profile does not exist.").into())
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -45,12 +46,18 @@ pub async fn has_joined(mut req: Request<Database>) -> Result {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// Check IP if requested
|
// Check IP if requested
|
||||||
if let Some(ip) = body.ip {
|
if let Some(ip) = query.ip {
|
||||||
if ip != session.ip_addr {
|
if ip != session.ip_addr {
|
||||||
return Err(YggdrasilError::new_forbidden("IP address does not match.").into())
|
return Err(YggdrasilError::new_forbidden("IP address does not match.").into())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: what is server id and why doesn't it match?
|
||||||
|
// Check server id
|
||||||
|
// if query.server_id != session.server_id {
|
||||||
|
// return Err(YggdrasilError::new_forbidden("Server ID does not match.").into())
|
||||||
|
// }
|
||||||
|
|
||||||
// Remove session
|
// Remove session
|
||||||
session.delete(req.state()).await?;
|
session.delete(req.state()).await?;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user