blastmud/blastmud_game/src/version_cutover.rs

45 lines
1.8 KiB
Rust
Raw Normal View History

2022-12-16 20:48:24 +11:00
use std::fs::{read_to_string, write};
use std::path::Path;
use std::error::Error;
use log::info;
use nix::{sys::signal::{kill, Signal}, unistd::{Pid, getpid}};
use crate::DResult;
2022-12-16 20:48:24 +11:00
pub fn replace_old_gameserver(pidfile: &str) -> DResult<()> {
2022-12-16 20:48:24 +11:00
match read_to_string(pidfile) {
Err(e) =>
if e.kind() == std::io::ErrorKind::NotFound {
info!("pidfile not found, assuming not already running");
Ok(())
} else {
info!("Error reading pidfile (other than NotFound): {}", e);
Err(Box::new(e) as Box::<dyn Error + Send + Sync>)
2022-12-16 20:48:24 +11:00
}
Ok(f) => {
let pid: Pid = Pid::from_raw(f.parse().map_err(|e| Box::new(e) as Box::<dyn Error + Send + Sync>)?);
if pid == getpid() {
info!("Pid in pidfile is me - ignoring");
return Ok(());
}
2022-12-16 20:48:24 +11:00
match read_to_string(format!("/proc/{}/cmdline", pid)) {
Ok(content) =>
if content.contains("blastmud_game") {
info!("pid in pidfile references blastmud_game; starting cutover");
kill(pid, Signal::SIGUSR1)
.map_err(|e| Box::new(e) as Box<dyn Error + Send + Sync>)
2022-12-16 20:48:24 +11:00
} else {
info!("Pid in pidfile is for process not including blastmud_game - ignoring pidfile");
Ok(())
}
Err(_) => {
info!("Pid in pidfile is gone - ignoring pidfile");
Ok(())
}
}
}
}?;
info!("Writing new pidfile");
write(Path::new(pidfile), format!("{}", std::process::id()))
.map_err(|e| Box::new(e) as Box::<dyn Error + Send + Sync>)
2022-12-16 20:48:24 +11:00
}