From e26d87f4fa18999c6bcfbcf32cfa85adab11acdd Mon Sep 17 00:00:00 2001 From: rtkay123 Date: Sat, 26 Jul 2025 19:24:38 +0200 Subject: feat(auth): create user call --- crates/auth/src/state.rs | 85 ------------------------------------------------ 1 file changed, 85 deletions(-) delete mode 100644 crates/auth/src/state.rs (limited to 'crates/auth/src/state.rs') diff --git a/crates/auth/src/state.rs b/crates/auth/src/state.rs deleted file mode 100644 index 5905948..0000000 --- a/crates/auth/src/state.rs +++ /dev/null @@ -1,85 +0,0 @@ -use std::{ops::Deref, sync::Arc}; - -use sellershut_core::profile::profile_client::ProfileClient; -use sqlx::PgPool; -use stack_up::Configuration; -use tokio::task::JoinHandle; -use tonic::transport::Endpoint; -use tower_sessions::{CachingSessionStore, ExpiredDeletion, session_store}; -use tower_sessions_moka_store::MokaStore; -use tower_sessions_sqlx_store::PostgresStore; -use tracing::error; - -use crate::{ - client::{OauthClient, discord::discord_client}, - cnfg::LocalConfig, - error::AppError, - server::grpc::interceptor::{Intercepted, MyInterceptor}, -}; - -#[derive(Clone)] -pub struct AppHandle(Arc); - -impl Deref for AppHandle { - type Target = Arc; - - fn deref(&self) -> &Self::Target { - &self.0 - } -} - -#[derive(Clone)] -pub struct Services { - pub postgres: PgPool, -} - -pub struct AppState { - pub services: Services, - pub local_config: LocalConfig, - pub discord_client: OauthClient, - pub http_client: reqwest::Client, - pub session_store: CachingSessionStore, - pub profile_client: ProfileClient, -} - -impl AppState { - pub async fn create( - services: Services, - configuration: &Configuration, - ) -> Result<(AppHandle, JoinHandle>), AppError> { - let local_config: LocalConfig = serde_json::from_value(configuration.misc.clone())?; - - let session_store_db = - tower_sessions_sqlx_store::PostgresStore::new(services.postgres.clone()); - session_store_db.migrate().await?; - let deletion_task = tokio::task::spawn( - session_store_db - .clone() - .continuously_delete_expired(tokio::time::Duration::from_secs(60)), - ); - let session_store_mem = MokaStore::new(Some(100)); - - let store = CachingSessionStore::new(session_store_mem, session_store_db); - - let discord_client = discord_client(&local_config.oauth.discord)?; - - let channel = Endpoint::new(local_config.profile_endpoint.to_string())? - .connect() - .await - .inspect_err(|e| error!("could not connect to profile service: {e}"))?; - - let profile_client = ProfileClient::with_interceptor(channel, MyInterceptor); - - Ok(( - AppHandle(Arc::new(Self { - services, - local_config, - discord_client, - http_client: reqwest::Client::new(), - session_store: store, - profile_client, - })), - deletion_task, - )) - } -} -- cgit v1.2.3