Some checks failed
BotServer CI / build (push) Failing after 1m34s
Split 20+ files over 1000 lines into focused subdirectories for better maintainability and code organization. All changes maintain backward compatibility through re-export wrappers. Major splits: - attendance/llm_assist.rs (2074→7 modules) - basic/keywords/face_api.rs → face_api/ (7 modules) - basic/keywords/file_operations.rs → file_ops/ (8 modules) - basic/keywords/hear_talk.rs → hearing/ (6 modules) - channels/wechat.rs → wechat/ (10 modules) - channels/youtube.rs → youtube/ (5 modules) - contacts/mod.rs → contacts_api/ (6 modules) - core/bootstrap/mod.rs → bootstrap/ (5 modules) - core/shared/admin.rs → admin_*.rs (5 modules) - designer/canvas.rs → canvas_api/ (6 modules) - designer/mod.rs → designer_api/ (6 modules) - docs/handlers.rs → handlers_api/ (11 modules) - drive/mod.rs → drive_handlers.rs, drive_types.rs - learn/mod.rs → types.rs - main.rs → main_module/ (7 modules) - meet/webinar.rs → webinar_api/ (8 modules) - paper/mod.rs → (10 modules) - security/auth.rs → auth_api/ (7 modules) - security/passkey.rs → (4 modules) - sources/mod.rs → sources_api/ (5 modules) - tasks/mod.rs → task_api/ (5 modules) Stats: 38,040 deletions, 1,315 additions across 318 files Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
49 lines
1.7 KiB
Rust
49 lines
1.7 KiB
Rust
//! Instance locking functions for bootstrap
|
|
//!
|
|
//! Extracted from mod.rs
|
|
|
|
use crate::security::command_guard::SafeCommand;
|
|
use log::warn;
|
|
use std::fs;
|
|
use std::path::PathBuf;
|
|
|
|
/// Check if another instance is already running
|
|
pub fn check_single_instance() -> Result<bool, Box<dyn std::error::Error>> {
|
|
let stack_path = std::env::var("BOTSERVER_STACK_PATH")
|
|
.unwrap_or_else(|_| "./botserver-stack".to_string());
|
|
let lock_file = PathBuf::from(&stack_path).join(".lock");
|
|
if lock_file.exists() {
|
|
if let Ok(pid_str) = fs::read_to_string(&lock_file) {
|
|
if let Ok(pid) = pid_str.trim().parse::<i32>() {
|
|
let pid_str = pid.to_string();
|
|
if let Some(output) = SafeCommand::new("kill")
|
|
.and_then(|c| c.args(&["-0", &pid_str]))
|
|
.ok()
|
|
.and_then(|cmd| cmd.execute().ok())
|
|
{
|
|
if output.status.success() {
|
|
warn!("Another botserver process (PID {}) is already running on this stack", pid);
|
|
return Ok(false);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
let pid = std::process::id();
|
|
if let Some(parent) = lock_file.parent() {
|
|
fs::create_dir_all(parent).ok();
|
|
}
|
|
fs::write(&lock_file, pid.to_string()).ok();
|
|
Ok(true)
|
|
}
|
|
|
|
/// Release the instance lock
|
|
pub fn release_instance_lock() {
|
|
let stack_path = std::env::var("BOTSERVER_STACK_PATH")
|
|
.unwrap_or_else(|_| "./botserver-stack".to_string());
|
|
let lock_file = PathBuf::from(&stack_path).join(".lock");
|
|
if lock_file.exists() {
|
|
fs::remove_file(&lock_file).ok();
|
|
}
|
|
}
|