Private
Public Access
1
0

daemon: reorg

This commit is contained in:
2025-05-01 20:45:20 -07:00
parent 2314713bb4
commit 2106bce755
2 changed files with 78 additions and 64 deletions

View File

@@ -0,0 +1,65 @@
use crate::daemon::SettingsKey;
use std::sync::Arc;
use tokio::sync::Mutex;
use kordophone::api::{AuthenticationStore, http_client::Credentials};
use kordophone::model::JwtToken;
use kordophone_db::database::{Database, DatabaseAccess};
use async_trait::async_trait;
pub struct DatabaseAuthenticationStore {
database: Arc<Mutex<Database>>,
}
impl DatabaseAuthenticationStore {
pub fn new(database: Arc<Mutex<Database>>) -> Self {
Self { database }
}
}
#[async_trait]
impl AuthenticationStore for DatabaseAuthenticationStore {
async fn get_credentials(&mut self) -> Option<Credentials> {
self.database.lock().await.with_settings(|settings| {
let username: Option<String> = settings.get::<String>(SettingsKey::USERNAME)
.unwrap_or_else(|e| {
log::warn!("error getting username from database: {}", e);
None
});
// TODO: This would be the point where we map from credential item to password.
let password: String = settings.get::<String>(SettingsKey::CREDENTIAL_ITEM)
.unwrap_or_else(|e| {
log::warn!("error getting password from database: {}", e);
None
})
.unwrap_or_else(|| {
log::warn!("warning: no password in database, [DEBUG] using default password");
"test".to_string()
});
if username.is_none() {
log::warn!("Username not present in database");
}
match (username, password) {
(Some(username), password) => Some(Credentials { username, password }),
_ => None,
}
}).await
}
async fn get_token(&mut self) -> Option<JwtToken> {
self.database.lock().await
.with_settings(|settings| settings.get::<JwtToken>(SettingsKey::TOKEN).unwrap_or_default()).await
}
async fn set_token(&mut self, token: JwtToken) {
self.database.lock().await
.with_settings(|settings| settings.put(SettingsKey::TOKEN, &token)).await.unwrap_or_else(|e| {
log::error!("Failed to set token: {}", e);
});
}
}

View File

@@ -16,23 +16,21 @@ use thiserror::Error;
use tokio::sync::mpsc::{Sender, Receiver}; use tokio::sync::mpsc::{Sender, Receiver};
use std::sync::Arc; use std::sync::Arc;
use tokio::sync::Mutex; use tokio::sync::Mutex;
use async_trait::async_trait;
use kordophone_db::{ use kordophone_db::{
database::{Database, DatabaseAccess}, database::{Database, DatabaseAccess},
models::{Conversation, Message}, models::{Conversation, Message},
}; };
use kordophone::model::JwtToken; use kordophone::api::APIInterface;
use kordophone::api::{ use kordophone::api::http_client::HTTPAPIClient;
http_client::{Credentials, HTTPAPIClient},
APIInterface,
AuthenticationStore,
};
mod update_monitor; mod update_monitor;
use update_monitor::UpdateMonitor; use update_monitor::UpdateMonitor;
mod auth_store;
use auth_store::DatabaseAuthenticationStore;
#[derive(Debug, Error)] #[derive(Debug, Error)]
pub enum DaemonError { pub enum DaemonError {
#[error("Client Not Configured")] #[error("Client Not Configured")]
@@ -41,58 +39,10 @@ pub enum DaemonError {
pub type DaemonResult<T> = Result<T, Box<dyn Error + Send + Sync>>; pub type DaemonResult<T> = Result<T, Box<dyn Error + Send + Sync>>;
struct DatabaseAuthenticationStore {
database: Arc<Mutex<Database>>,
}
#[async_trait]
impl AuthenticationStore for DatabaseAuthenticationStore {
async fn get_credentials(&mut self) -> Option<Credentials> {
self.database.lock().await.with_settings(|settings| {
let username: Option<String> = settings.get::<String>(SettingsKey::USERNAME)
.unwrap_or_else(|e| {
log::warn!("error getting username from database: {}", e);
None
});
// TODO: This would be the point where we map from credential item to password.
let password: String = settings.get::<String>(SettingsKey::CREDENTIAL_ITEM)
.unwrap_or_else(|e| {
log::warn!("error getting password from database: {}", e);
None
})
.unwrap_or_else(|| {
log::warn!("warning: no password in database, [DEBUG] using default password");
"test".to_string()
});
if username.is_none() {
log::warn!("Username not present in database");
}
match (username, password) {
(Some(username), password) => Some(Credentials { username, password }),
_ => None,
}
}).await
}
async fn get_token(&mut self) -> Option<JwtToken> {
self.database.lock().await
.with_settings(|settings| settings.get::<JwtToken>(SettingsKey::TOKEN).unwrap_or_default()).await
}
async fn set_token(&mut self, token: JwtToken) {
self.database.lock().await
.with_settings(|settings| settings.put(SettingsKey::TOKEN, &token)).await.unwrap_or_else(|e| {
log::error!("Failed to set token: {}", e);
});
}
}
pub mod target { pub mod target {
pub static SYNC: &str = "sync"; pub static SYNC: &str = "sync";
pub static EVENT: &str = "event"; pub static EVENT: &str = "event";
pub static SETTINGS: &str = "settings";
pub static UPDATES: &str = "updates"; pub static UPDATES: &str = "updates";
} }
pub struct Daemon { pub struct Daemon {
@@ -145,7 +95,6 @@ impl Daemon {
let mut update_monitor = UpdateMonitor::new(self.database.clone(), self.event_sender.clone()); let mut update_monitor = UpdateMonitor::new(self.database.clone(), self.event_sender.clone());
tokio::spawn(async move { tokio::spawn(async move {
log::info!(target: target::UPDATES, "Starting update monitor");
update_monitor.run().await; // should run indefinitely update_monitor.run().await; // should run indefinitely
}); });
@@ -167,7 +116,7 @@ impl Daemon {
self.runtime.spawn(async move { self.runtime.spawn(async move {
let result = Self::sync_conversation_list(&mut db_clone, &signal_sender).await; let result = Self::sync_conversation_list(&mut db_clone, &signal_sender).await;
if let Err(e) = result { if let Err(e) = result {
log::error!("Error handling sync event: {}", e); log::error!(target: target::SYNC, "Error handling sync event: {}", e);
} }
}); });
@@ -181,7 +130,7 @@ impl Daemon {
self.runtime.spawn(async move { self.runtime.spawn(async move {
let result = Self::sync_all_conversations_impl(&mut db_clone, &signal_sender).await; let result = Self::sync_all_conversations_impl(&mut db_clone, &signal_sender).await;
if let Err(e) = result { if let Err(e) = result {
log::error!("Error handling sync event: {}", e); log::error!(target: target::SYNC, "Error handling sync event: {}", e);
} }
}); });
@@ -195,7 +144,7 @@ impl Daemon {
self.runtime.spawn(async move { self.runtime.spawn(async move {
let result = Self::sync_conversation_impl(&mut db_clone, &signal_sender, conversation_id).await; let result = Self::sync_conversation_impl(&mut db_clone, &signal_sender, conversation_id).await;
if let Err(e) = result { if let Err(e) = result {
log::error!("Error handling sync event: {}", e); log::error!(target: target::SYNC, "Error handling sync event: {}", e);
} }
}); });
@@ -210,7 +159,7 @@ impl Daemon {
Event::GetAllSettings(reply) => { Event::GetAllSettings(reply) => {
let settings = self.get_settings().await let settings = self.get_settings().await
.unwrap_or_else(|e| { .unwrap_or_else(|e| {
log::error!("Failed to get settings: {:#?}", e); log::error!(target: target::SETTINGS, "Failed to get settings: {:#?}", e);
Settings::default() Settings::default()
}); });
@@ -220,7 +169,7 @@ impl Daemon {
Event::UpdateSettings(settings, reply) => { Event::UpdateSettings(settings, reply) => {
self.update_settings(&settings).await self.update_settings(&settings).await
.unwrap_or_else(|e| { .unwrap_or_else(|e| {
log::error!("Failed to update settings: {}", e); log::error!(target: target::SETTINGS, "Failed to update settings: {}", e);
}); });
reply.send(()).unwrap(); reply.send(()).unwrap();
@@ -234,7 +183,7 @@ impl Daemon {
Event::DeleteAllConversations(reply) => { Event::DeleteAllConversations(reply) => {
self.delete_all_conversations().await self.delete_all_conversations().await
.unwrap_or_else(|e| { .unwrap_or_else(|e| {
log::error!("Failed to delete all conversations: {}", e); log::error!(target: target::SYNC, "Failed to delete all conversations: {}", e);
}); });
reply.send(()).unwrap(); reply.send(()).unwrap();
@@ -371,7 +320,7 @@ impl Daemon {
let client = HTTPAPIClient::new( let client = HTTPAPIClient::new(
server_url.parse().unwrap(), server_url.parse().unwrap(),
DatabaseAuthenticationStore { database: database.clone() } DatabaseAuthenticationStore::new(database.clone())
); );
Ok(client) Ok(client)