anzar-shared 0.9.15

Anzar is a lightweight authentication and authorization framework that runs as a separate microservice
Documentation
use std::sync::Arc;

use sqlx::{Pool, Postgres, Sqlite};

use crate::domain::database::DatabaseAdapter;
use crate::domain::model::{
    Account, EmailVerificationToken, PasswordResetToken, Permission, RefreshToken, Role,
    RolePermission, Session, SigningKey, User, UserRole,
};

use super::{mongodb::MongodbAdapter, postgres::PostgreSQLAdapter, sqlite::SQLiteAdapter};

const USER: &str = "users";
const ACCOUNT: &str = "accounts";
const REFRESH_TOKEN: &str = "refresh_tokens";
const PASSWORD_RESET_TOKEN: &str = "password_reset_tokens";
const EMAIL_VERIFICATION_TOKEN: &str = "email_verification_tokens";
const SESSION: &str = "sessions";
const ROLE: &str = "roles";
const USER_ROLE: &str = "user_roles";
const PERMISSIONS: &str = "permissions";
const ROLE_PERMISSIONS: &str = "role_permissions";
const SIGNING_KEYS: &str = "signing_keys";

pub struct DatabaseAdapters {
    pub user_adapter: Arc<dyn DatabaseAdapter<User>>,
    pub account_adapter: Arc<dyn DatabaseAdapter<Account>>,
    pub jwt_adapter: Arc<dyn DatabaseAdapter<RefreshToken>>,
    pub session_adapter: Arc<dyn DatabaseAdapter<Session>>,
    pub reset_token_adapter: Arc<dyn DatabaseAdapter<PasswordResetToken>>,
    pub email_verification_token: Arc<dyn DatabaseAdapter<EmailVerificationToken>>,
    pub role_adapter: Arc<dyn DatabaseAdapter<Role>>,
    pub user_role_adapter: Arc<dyn DatabaseAdapter<UserRole>>,
    pub permission_adapter: Arc<dyn DatabaseAdapter<Permission>>,
    pub role_permission_adapter: Arc<dyn DatabaseAdapter<RolePermission>>,
    pub signing_keys_adapter: Arc<dyn DatabaseAdapter<SigningKey>>,
    // pub transaction_adapter: MongodbTransaction,
}

impl DatabaseAdapters {
    pub fn mongodb(client: &mongodb::Client, conn_string: &str) -> Self {
        Self {
            user_adapter: Arc::new(MongodbAdapter::<User>::new(client, conn_string, USER)),
            account_adapter: Arc::new(MongodbAdapter::<Account>::new(client, conn_string, ACCOUNT)),
            jwt_adapter: Arc::new(MongodbAdapter::<RefreshToken>::new(
                client,
                conn_string,
                REFRESH_TOKEN,
            )),
            session_adapter: Arc::new(MongodbAdapter::<Session>::new(client, conn_string, SESSION)),
            reset_token_adapter: Arc::new(MongodbAdapter::<PasswordResetToken>::new(
                client,
                conn_string,
                PASSWORD_RESET_TOKEN,
            )),
            email_verification_token: Arc::new(MongodbAdapter::<EmailVerificationToken>::new(
                client,
                conn_string,
                EMAIL_VERIFICATION_TOKEN,
            )),
            role_adapter: Arc::new(MongodbAdapter::<Role>::new(client, conn_string, ROLE)),
            user_role_adapter: Arc::new(MongodbAdapter::<UserRole>::new(
                client,
                conn_string,
                USER_ROLE,
            )),

            permission_adapter: Arc::new(MongodbAdapter::<Permission>::new(
                client,
                conn_string,
                PERMISSIONS,
            )),
            role_permission_adapter: Arc::new(MongodbAdapter::<RolePermission>::new(
                client,
                conn_string,
                ROLE_PERMISSIONS,
            )),
            signing_keys_adapter: Arc::new(MongodbAdapter::<SigningKey>::new(
                client,
                conn_string,
                SIGNING_KEYS,
            )),
            // transaction_adapter: MongodbTransaction::new(client),
        }
    }

    pub fn sqlite(pool: &Pool<Sqlite>) -> Self {
        Self {
            user_adapter: Arc::new(SQLiteAdapter::<User>::new(pool, USER)),
            account_adapter: Arc::new(SQLiteAdapter::<Account>::new(pool, ACCOUNT)),
            jwt_adapter: Arc::new(SQLiteAdapter::<RefreshToken>::new(pool, REFRESH_TOKEN)),
            session_adapter: Arc::new(SQLiteAdapter::<Session>::new(pool, SESSION)),
            reset_token_adapter: Arc::new(SQLiteAdapter::<PasswordResetToken>::new(
                pool,
                PASSWORD_RESET_TOKEN,
            )),
            email_verification_token: Arc::new(SQLiteAdapter::<EmailVerificationToken>::new(
                pool,
                EMAIL_VERIFICATION_TOKEN,
            )),
            role_adapter: Arc::new(SQLiteAdapter::<Role>::new(pool, ROLE)),
            user_role_adapter: Arc::new(SQLiteAdapter::<UserRole>::new(pool, USER_ROLE)),
            permission_adapter: Arc::new(SQLiteAdapter::<Permission>::new(pool, PERMISSIONS)),
            role_permission_adapter: Arc::new(SQLiteAdapter::<RolePermission>::new(
                pool,
                ROLE_PERMISSIONS,
            )),
            signing_keys_adapter: Arc::new(SQLiteAdapter::<SigningKey>::new(pool, SIGNING_KEYS)),
            // transaction_adapter: todo!(),
        }
    }

    pub fn postgres(pool: &Pool<Postgres>) -> Self {
        Self {
            user_adapter: Arc::new(PostgreSQLAdapter::<User>::new(pool, USER)),
            account_adapter: Arc::new(PostgreSQLAdapter::<Account>::new(pool, ACCOUNT)),
            jwt_adapter: Arc::new(PostgreSQLAdapter::<RefreshToken>::new(pool, REFRESH_TOKEN)),
            session_adapter: Arc::new(PostgreSQLAdapter::<Session>::new(pool, SESSION)),
            reset_token_adapter: Arc::new(PostgreSQLAdapter::<PasswordResetToken>::new(
                pool,
                PASSWORD_RESET_TOKEN,
            )),
            email_verification_token: Arc::new(PostgreSQLAdapter::<EmailVerificationToken>::new(
                pool,
                EMAIL_VERIFICATION_TOKEN,
            )),
            role_adapter: Arc::new(PostgreSQLAdapter::<Role>::new(pool, ROLE)),
            user_role_adapter: Arc::new(PostgreSQLAdapter::<UserRole>::new(pool, USER_ROLE)),
            permission_adapter: Arc::new(PostgreSQLAdapter::<Permission>::new(pool, PERMISSIONS)),
            role_permission_adapter: Arc::new(PostgreSQLAdapter::<RolePermission>::new(
                pool,
                ROLE_PERMISSIONS,
            )),
            signing_keys_adapter: Arc::new(PostgreSQLAdapter::<SigningKey>::new(
                pool,
                SIGNING_KEYS,
            )),
            // transaction_adapter: todo!(),
        }
    }
}