junobuild-satellite 0.6.0

Core implementation of a Juno Satellite.
Documentation
use crate::auth::assert::increment_and_assert_user_rate;
use crate::auth::delegation;
use crate::auth::register::register_user;
use crate::auth::strategy_impls::AuthHeap;
use crate::types::interface::{Authentication, AuthenticationError, AuthenticationResult};
use junobuild_auth::delegation::types::{
    GetDelegationResult, OpenIdGetDelegationArgs, OpenIdPrepareDelegationArgs,
};
use junobuild_auth::state::get_auth_providers;

pub async fn openid_authenticate(
    args: &OpenIdPrepareDelegationArgs,
) -> Result<AuthenticationResult, String> {
    let providers = get_auth_providers(&AuthHeap)?;

    // We assert early on to avoid generating a delegation which won't be used
    // in case the user cannot be created. We also want to prevent creating delegations
    // while the rate limiter is reached.
    increment_and_assert_user_rate()?;

    let prepared_delegation = delegation::openid_prepare_delegation(args, &providers).await;

    let result = match prepared_delegation {
        Ok((delegation, provider, credential)) => {
            let key = &delegation.user_key;

            register_user(key, &provider, &credential)
                .map(|doc| Authentication { delegation, doc })
                .map_err(AuthenticationError::RegisterUser)
        }
        Err(err) => Err(AuthenticationError::PrepareDelegation(err)),
    };

    Ok(result)
}

pub fn openid_get_delegation(
    args: &OpenIdGetDelegationArgs,
) -> Result<GetDelegationResult, String> {
    let providers = get_auth_providers(&AuthHeap)?;

    let result = delegation::openid_get_delegation(args, &providers);

    Ok(result)
}