Files
yourpart-daemon/src/worker/house.rs
Torsten Schulz (local) 10bc1e5a52 Refactor SQL queries into a dedicated module
- Moved SQL queries from multiple worker files into `src/worker/sql.rs` for better organization and maintainability.
- Updated references in `stockage_manager.rs`, `transport.rs`, `underground.rs`, `user_character.rs`, and `value_recalculation.rs` to use the new centralized SQL queries.
- Improved code readability by replacing `.get(0)` with `.first()` for better clarity when retrieving the first row from query results.
- Cleaned up unnecessary comments and consolidated related SQL queries.
2025-12-13 11:57:28 +01:00

127 lines
3.8 KiB
Rust

use crate::db::{ConnectionPool, DbError};
use crate::message_broker::MessageBroker;
use std::sync::atomic::Ordering;
use std::sync::Arc;
use std::time::{Duration, Instant};
use super::base::{BaseWorker, Worker, WorkerState};
use crate::worker::sql::{
QUERY_GET_NEW_HOUSE_DATA,
QUERY_ADD_NEW_BUYABLE_HOUSE,
QUERY_UPDATE_BUYABLE_HOUSE_STATE,
QUERY_UPDATE_USER_HOUSE_STATE,
};
pub struct HouseWorker {
base: BaseWorker,
}
impl HouseWorker {
pub fn new(pool: ConnectionPool, broker: MessageBroker) -> Self {
Self {
base: BaseWorker::new("HouseWorker", pool, broker),
}
}
fn run_loop(pool: ConnectionPool, _broker: MessageBroker, state: Arc<WorkerState>) {
let mut last_hourly_run: Option<Instant> = None;
let mut last_daily_run: Option<Instant> = None;
while state.running_worker.load(Ordering::Relaxed) {
let now = Instant::now();
// Stündliche Aufgaben: neue Häuser erzeugen
let should_run_hourly = match last_hourly_run {
None => true,
Some(last) => now.saturating_duration_since(last) >= Duration::from_secs(3600),
};
if should_run_hourly {
if let Err(err) = Self::perform_task_inner(&pool) {
eprintln!("[HouseWorker] Fehler in performTask: {err}");
}
last_hourly_run = Some(now);
}
// Tägliche Aufgaben: Hauszustände verschlechtern
let should_run_daily = match last_daily_run {
None => true,
Some(last) => now.saturating_duration_since(last) >= Duration::from_secs(24 * 3600),
};
if should_run_daily {
if let Err(err) = Self::perform_house_state_change_inner(&pool) {
eprintln!("[HouseWorker] Fehler in performHouseStateChange: {err}");
}
last_daily_run = Some(now);
}
std::thread::sleep(Duration::from_secs(1));
}
}
fn perform_task_inner(pool: &ConnectionPool) -> Result<(), DbError> {
let mut conn = pool
.get()
.map_err(|e| DbError::new(format!("[HouseWorker] DB-Verbindung fehlgeschlagen: {e}")))?;
conn.prepare("get_new_house_data", QUERY_GET_NEW_HOUSE_DATA)?;
let rows = conn.execute("get_new_house_data", &[])?;
conn.prepare("add_new_buyable_house", QUERY_ADD_NEW_BUYABLE_HOUSE)?;
for row in rows {
if let Some(house_id) = row
.get("house_id")
.and_then(|v| v.parse::<i32>().ok())
{
conn.execute("add_new_buyable_house", &[&house_id])?;
}
}
Ok(())
}
fn perform_house_state_change_inner(pool: &ConnectionPool) -> Result<(), DbError> {
let mut conn = pool
.get()
.map_err(|e| DbError::new(format!("[HouseWorker] DB-Verbindung fehlgeschlagen: {e}")))?;
conn.prepare(
"update_buyable_house_state",
QUERY_UPDATE_BUYABLE_HOUSE_STATE,
)?;
conn.prepare(
"update_user_house_state",
QUERY_UPDATE_USER_HOUSE_STATE,
)?;
conn.execute("update_buyable_house_state", &[])?;
conn.execute("update_user_house_state", &[])?;
Ok(())
}
}
impl Worker for HouseWorker {
fn start_worker_thread(&mut self) {
let pool = self.base.pool.clone();
let broker = self.base.broker.clone();
self.base
.start_worker_with_loop(move |state: Arc<WorkerState>| {
Self::run_loop(pool.clone(), broker.clone(), state);
});
}
fn stop_worker_thread(&mut self) {
self.base.stop_worker();
}
fn enable_watchdog(&mut self) {
self.base.start_watchdog();
}
}