blastmud/blastmud_game/src/version_cutover.rs

53 lines
1.9 KiB
Rust
Raw Normal View History

use crate::DResult;
use log::info;
use nix::{
sys::signal::{kill, Signal},
unistd::{getpid, Pid},
};
use std::error::Error;
2022-12-16 20:48:24 +11:00
use std::fs::{read_to_string, write};
use std::path::Path;
pub fn replace_old_gameserver(pidfile: &str) -> DResult<()> {
2022-12-16 20:48:24 +11:00
match read_to_string(pidfile) {
Err(e) => {
2022-12-16 20:48:24 +11:00
if e.kind() == std::io::ErrorKind::NotFound {
info!("pidfile not found, assuming not already running");
Ok(())
} else {
2022-12-16 20:48:24 +11:00
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
}
}
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) => {
2022-12-16 20:48:24 +11:00
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(())
}
}
2022-12-16 20:48:24 +11:00
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
}