mirror of
https://github.com/BeamMP/BeamMP-Server.git
synced 2025-07-04 00:36:14 +00:00
key check
This commit is contained in:
parent
d9e0761e07
commit
259f3de774
2
.gitignore
vendored
2
.gitignore
vendored
@ -1,2 +1,4 @@
|
|||||||
/target
|
/target
|
||||||
|
/.idea
|
||||||
ServerConfig.toml
|
ServerConfig.toml
|
||||||
|
beammp_rust_server.iml
|
@ -43,3 +43,21 @@ pub struct GeneralSettings {
|
|||||||
#[serde(rename = "ResourceFolder")]
|
#[serde(rename = "ResourceFolder")]
|
||||||
pub resource_folder: String,
|
pub resource_folder: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl GeneralSettings {
|
||||||
|
pub fn is_auth_key_valid(&self) -> bool {
|
||||||
|
// Valid key format
|
||||||
|
// xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
|
||||||
|
// -8--------4----4----4----12---------
|
||||||
|
if self.auth_key.is_none() {return false}
|
||||||
|
let key = self.auth_key.clone().unwrap();
|
||||||
|
let key_check: Vec<&str> = key.split("-").collect();
|
||||||
|
if key_check.len() != 5 {return false}
|
||||||
|
else if key_check[0].len() != 8 {return false}
|
||||||
|
else if key_check[1].len() != 4 {return false}
|
||||||
|
else if key_check[2].len() != 4 {return false}
|
||||||
|
else if key_check[3].len() != 4 {return false}
|
||||||
|
else if key_check[4].len() != 12 {return false}
|
||||||
|
true
|
||||||
|
}
|
||||||
|
}
|
@ -20,6 +20,10 @@ struct HeartbeatInfo {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub async fn backend_heartbeat(config: std::sync::Arc<crate::config::Config>, mut hb_rx: Receiver<crate::server::ServerStatus>) {
|
pub async fn backend_heartbeat(config: std::sync::Arc<crate::config::Config>, mut hb_rx: Receiver<crate::server::ServerStatus>) {
|
||||||
|
if !config.general.is_auth_key_valid() {
|
||||||
|
debug!{"auth_key has invalid format. canceling hearbeat init"};
|
||||||
|
return;
|
||||||
|
}
|
||||||
let mut info = HeartbeatInfo {
|
let mut info = HeartbeatInfo {
|
||||||
uuid: config.general.auth_key.clone().unwrap_or(String::from("Unknown name!")),
|
uuid: config.general.auth_key.clone().unwrap_or(String::from("Unknown name!")),
|
||||||
players: 0,
|
players: 0,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user