diff options
Diffstat (limited to 'atuin-server/src')
| -rw-r--r-- | atuin-server/src/handlers/history.rs | 2 | ||||
| -rw-r--r-- | atuin-server/src/handlers/mod.rs | 19 | ||||
| -rw-r--r-- | atuin-server/src/handlers/user.rs | 2 |
3 files changed, 11 insertions, 12 deletions
diff --git a/atuin-server/src/handlers/history.rs b/atuin-server/src/handlers/history.rs index 2b107907..d2fda772 100644 --- a/atuin-server/src/handlers/history.rs +++ b/atuin-server/src/handlers/history.rs @@ -7,7 +7,7 @@ use axum::{ use http::StatusCode; use tracing::{debug, error, instrument}; -use super::{ErrorResponse, ErrorResponseStatus}; +use super::{ErrorResponse, ErrorResponseStatus, RespExt}; use crate::{ calendar::{TimePeriod, TimePeriodInfo}, database::{Database, Postgres}, diff --git a/atuin-server/src/handlers/mod.rs b/atuin-server/src/handlers/mod.rs index 4aa7423e..4be3e388 100644 --- a/atuin-server/src/handlers/mod.rs +++ b/atuin-server/src/handlers/mod.rs @@ -1,5 +1,4 @@ -use std::borrow::Cow; - +use atuin_common::api::ErrorResponse; use axum::{response::IntoResponse, Json}; use serde::{Deserialize, Serialize}; @@ -23,11 +22,6 @@ pub async fn index() -> Json<IndexResponse> { }) } -#[derive(Debug, Serialize, Deserialize)] -pub struct ErrorResponse<'a> { - pub reason: Cow<'a, str>, -} - impl<'a> IntoResponse for ErrorResponseStatus<'a> { fn into_response(self) -> axum::response::Response { (self.status, Json(self.error)).into_response() @@ -39,15 +33,20 @@ pub struct ErrorResponseStatus<'a> { pub status: http::StatusCode, } -impl<'a> ErrorResponse<'a> { - pub fn with_status(self, status: http::StatusCode) -> ErrorResponseStatus<'a> { +pub trait RespExt<'a> { + fn with_status(self, status: http::StatusCode) -> ErrorResponseStatus<'a>; + fn reply(reason: &'a str) -> Self; +} + +impl<'a> RespExt<'a> for ErrorResponse<'a> { + fn with_status(self, status: http::StatusCode) -> ErrorResponseStatus<'a> { ErrorResponseStatus { error: self, status, } } - pub fn reply(reason: &'a str) -> ErrorResponse { + fn reply(reason: &'a str) -> ErrorResponse { Self { reason: reason.into(), } diff --git a/atuin-server/src/handlers/user.rs b/atuin-server/src/handlers/user.rs index 42e2b5c1..1bc9178b 100644 --- a/atuin-server/src/handlers/user.rs +++ b/atuin-server/src/handlers/user.rs @@ -6,7 +6,7 @@ use sodiumoxide::crypto::pwhash::argon2id13; use tracing::{debug, error, instrument}; use uuid::Uuid; -use super::{ErrorResponse, ErrorResponseStatus}; +use super::{ErrorResponse, ErrorResponseStatus, RespExt}; use crate::{ database::{Database, Postgres}, models::{NewSession, NewUser}, |
