Files
ox_speak_server/src/app/app.rs
2025-07-29 20:20:02 +02:00

80 lines
2.1 KiB
Rust

use std::time::Duration;
use tokio::sync::mpsc;
use tokio::time::interval;
use crate::domain::client::ClientManager;
use crate::domain::event::{Event, EventBus};
use crate::network::http::HttpServer;
use crate::network::udp::UdpServer;
use crate::runtime::dispatcher::Dispatcher;
use crate::store::store_service::StoreService;
pub struct App {
// Communication inter-components
event_bus: EventBus,
dispatcher: Dispatcher,
event_rx: kanal::AsyncReceiver<Event>,
// Network
udp_server: UdpServer,
http_server: HttpServer,
// Clients
client_manager: ClientManager,
// store
store: StoreService,
}
impl App {
pub async fn new() -> Self {
let (event_bus, event_rx) = EventBus::new();
let store = StoreService::new("./db.sqlite").await.unwrap();
let udp_server = UdpServer::new(event_bus.clone(), "0.0.0.0:5000").await;
let http_server = HttpServer::new(event_bus.clone(), store.clone());
let client_manager = ClientManager::new();
let dispatcher = Dispatcher::new(event_bus.clone(), udp_server.clone(), client_manager.clone(), store.clone()).await;
Self {
event_bus,
dispatcher,
event_rx,
udp_server,
http_server,
client_manager,
store
}
}
pub async fn start(&mut self) {
for i in 0..4 {
let dispatcher = self.dispatcher.clone();
let event_rx = self.event_rx.clone();
tokio::spawn(async move {
dispatcher.start(event_rx).await;
});
}
let _ = self.udp_server.start().await;
let _ = self.http_server.start("0.0.0.0:5000").await;
let _ = self.tick_tasks().await;
println!("App started");
}
async fn tick_tasks(&self) {
let event_bus = self.event_bus.clone();
tokio::spawn(async move {
let mut interval = interval(Duration::from_secs(1));
loop {
// println!("Tick");
interval.tick().await;
let _ = event_bus.emit(Event::TickSeconds).await;
}
});
}
}