use crate::api::http::token::{TokenCreateRequestAxum, TokenCreateResponseAxum};
use crate::api::{HttpError, StateKeeper};
use crate::auth::policy::FullAccessPolicy;
use axum::extract::{Path, State};
use axum_extra::headers::HeaderMap;
use std::sync::Arc;
pub(super) async fn create_token(
State(keeper): State<Arc<StateKeeper>>,
Path(token_name): Path<String>,
headers: HeaderMap,
body: TokenCreateRequestAxum,
) -> Result<TokenCreateResponseAxum, HttpError> {
let components = keeper
.get_with_permissions(&headers, FullAccessPolicy {})
.await?;
let token = components
.token_repo
.write()
.await?
.generate_token(&token_name, body.0)
.await?;
Ok(TokenCreateResponseAxum(token))
}
#[cfg(test)]
mod tests {
use super::*;
use crate::api::http::tests::{headers, keeper};
use reduct_base::error::ErrorCode;
use reduct_base::msg::token_api::{Permissions, TokenCreateRequest};
use rstest::rstest;
#[rstest]
#[tokio::test]
async fn test_create_token(#[future] keeper: Arc<StateKeeper>, headers: HeaderMap) {
let token = create_token(
State(keeper.await),
Path("new-token".to_string()),
headers,
TokenCreateRequestAxum(TokenCreateRequest {
permissions: Permissions::default(),
..Default::default()
}),
)
.await
.unwrap()
.0;
assert!(token.value.starts_with("new-token"));
}
#[rstest]
#[tokio::test]
async fn test_create_token_already_exists(
#[future] keeper: Arc<StateKeeper>,
headers: HeaderMap,
) {
let err = create_token(
State(keeper.await),
Path("test".to_string()),
headers,
TokenCreateRequestAxum(TokenCreateRequest {
permissions: Permissions::default(),
..Default::default()
}),
)
.await
.err()
.unwrap();
assert_eq!(
err,
HttpError::new(ErrorCode::Conflict, "Token 'test' already exists")
);
}
}