From 19871c1924a8569df741d4bf5f63943b6b646c16 Mon Sep 17 00:00:00 2001 From: rtkay123 Date: Thu, 14 Aug 2025 18:33:10 +0200 Subject: feat(config): rule http --- .../src/server/http_svc/routes/rule/create.rs | 38 ++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 crates/configuration/src/server/http_svc/routes/rule/create.rs (limited to 'crates/configuration/src/server/http_svc/routes/rule/create.rs') diff --git a/crates/configuration/src/server/http_svc/routes/rule/create.rs b/crates/configuration/src/server/http_svc/routes/rule/create.rs new file mode 100644 index 0000000..809c00b --- /dev/null +++ b/crates/configuration/src/server/http_svc/routes/rule/create.rs @@ -0,0 +1,38 @@ +use axum::{extract::State, response::IntoResponse}; +use warden_core::configuration::rule::{ + RuleConfiguration, mutate_rule_configuration_server::MutateRuleConfiguration, +}; + +use crate::{ + server::{error::AppError, http_svc::TAG_RULES, version::Version}, + state::AppHandle, +}; + +/// Create rule configuration +#[utoipa::path( + post, + path = "/{version}/rule", + params( + ("version" = Version, Path, description = "API version, e.g., v1, v2, v3"), + ), + responses(( + status = CREATED, + body = RuleConfiguration, + )), + operation_id = "create_rule_configuration", // https://github.com/juhaku/utoipa/issues/1170 + tag = TAG_RULES, + ) +] +#[axum::debug_handler] +#[tracing::instrument(skip(state))] +pub async fn create_rule( + version: Version, + State(state): State, + axum::Json(body): axum::Json, +) -> Result { + let response = state + .create_rule_configuration(tonic::Request::new(body)) + .await? + .into_inner(); + Ok((axum::http::StatusCode::CREATED, axum::Json(response))) +} -- cgit v1.2.3