Skip to main content

ApiResponse

Struct ApiResponse 

Source
pub struct ApiResponse<T> {
    pub success: bool,
    pub data: Option<T>,
    pub error: Option<ApiError>,
    pub message: Option<String>,
}
Expand description

Standard API response wrapper.

Encapsulates success/error status, optional data payload, optional error details, and an optional human-readable message.

§Example

use auth_framework::api::responses::ApiResponse;

let resp = ApiResponse::success("hello");
assert!(resp.success);
assert_eq!(resp.data, Some("hello"));

Fields§

§success: bool§data: Option<T>§error: Option<ApiError>§message: Option<String>

Implementations§

Source§

impl<T> ApiResponse<T>

Source

pub fn success(data: T) -> Self

Create a successful response carrying data.

§Example
use auth_framework::api::responses::ApiResponse;

let resp = ApiResponse::success(42u32);
assert!(resp.success);
assert_eq!(resp.data, Some(42));
Source

pub fn cast<U>(self) -> ApiResponse<U>

Convert this response to another data type, discarding the payload.

Useful for propagating error responses where the data type differs.

§Example
use auth_framework::api::responses::ApiResponse;

let err = ApiResponse::<()>::error("FAIL", "oops");
let typed: ApiResponse<String> = err.cast();
assert!(!typed.success);
Source

pub fn forbidden_typed() -> ApiResponse<T>

Create a forbidden (403) response for any data type T.

§Example
use auth_framework::api::responses::ApiResponse;

let resp: ApiResponse<String> = ApiResponse::forbidden_typed();
assert!(!resp.success);
Source

pub fn unauthorized_typed() -> ApiResponse<T>

Create an unauthorized (401) response for any data type T.

§Example
use auth_framework::api::responses::ApiResponse;

let resp: ApiResponse<Vec<u8>> = ApiResponse::unauthorized_typed();
assert!(!resp.success);
Source

pub fn error_typed(code: &str, message: impl Into<String>) -> ApiResponse<T>

Create an error response for any data type T.

§Example
use auth_framework::api::responses::ApiResponse;

let resp: ApiResponse<i32> = ApiResponse::error_typed("FAIL", "bad input");
assert!(!resp.success);
Source

pub fn validation_error_typed(message: impl Into<String>) -> ApiResponse<T>

Create a validation error (400) response for any data type T.

§Example
use auth_framework::api::responses::ApiResponse;

let resp: ApiResponse<()> = ApiResponse::validation_error_typed("bad field");
assert!(!resp.success);
Source

pub fn not_found_typed(message: impl Into<String>) -> ApiResponse<T>

Create a not-found (404) response for any data type T.

§Example
use auth_framework::api::responses::ApiResponse;

let resp: ApiResponse<String> = ApiResponse::not_found_typed("user");
assert!(!resp.success);
Source

pub fn forbidden_with_message_typed( message: impl Into<String>, ) -> ApiResponse<T>

Create a forbidden (403) response with a custom message for any data type T.

§Example
use auth_framework::api::responses::ApiResponse;

let resp: ApiResponse<()> = ApiResponse::forbidden_with_message_typed("admin only");
assert!(!resp.success);
Source

pub fn error_with_message_typed( code: &str, message: impl Into<String>, ) -> ApiResponse<T>

Create an error response with a custom code and message for any data type T.

§Example
use auth_framework::api::responses::ApiResponse;

let resp: ApiResponse<()> = ApiResponse::error_with_message_typed("QUOTA", "exceeded");
assert_eq!(resp.error.unwrap().code, "QUOTA");
Source

pub fn not_found_with_message_typed( message: impl Into<String>, ) -> ApiResponse<T>

Create a not-found (404) response with a custom message for any data type T.

§Example
use auth_framework::api::responses::ApiResponse;

let resp: ApiResponse<()> = ApiResponse::not_found_with_message_typed("gone");
assert!(!resp.success);
Source

pub fn internal_error_typed() -> ApiResponse<T>

Create an internal server error (500) response for any data type T.

§Example
use auth_framework::api::responses::ApiResponse;

let resp: ApiResponse<()> = ApiResponse::internal_error_typed();
assert!(!resp.success);
Source

pub fn success_with_message(data: T, message: impl Into<String>) -> Self

Create a successful response with data and a human-readable message.

§Example
use auth_framework::api::responses::ApiResponse;

let resp = ApiResponse::success_with_message("done", "operation complete");
assert!(resp.success);
assert_eq!(resp.message, Some("operation complete".into()));
Source

pub fn ok() -> ApiResponse<()>

Create a simple success response with no data.

§Example
use auth_framework::api::responses::ApiResponse;

let resp = ApiResponse::<()>::ok();
assert!(resp.success);
assert!(resp.data.is_none());
Source

pub fn ok_with_message(message: impl Into<String>) -> ApiResponse<()>

Create a success response with a message but no data.

§Example
use auth_framework::api::responses::ApiResponse;

let resp = ApiResponse::<()>::ok_with_message("saved");
assert!(resp.success);
assert_eq!(resp.message, Some("saved".into()));
Source§

impl ApiResponse<()>

Source

pub fn error(code: impl Into<String>, message: impl Into<String>) -> Self

Create an error response with a code and message.

§Example
use auth_framework::api::responses::ApiResponse;

let resp = ApiResponse::<()>::error("BAD_REQUEST", "missing param");
assert!(!resp.success);
assert_eq!(resp.error.as_ref().unwrap().code, "BAD_REQUEST");
Source

pub fn error_with_details( code: impl Into<String>, message: impl Into<String>, details: Value, ) -> Self

Create an error response with structured details.

§Example
use auth_framework::api::responses::ApiResponse;

let details = serde_json::json!({"fields": ["name"]});
let resp = ApiResponse::<()>::error_with_details("VALIDATION", "invalid", details);
assert!(resp.error.as_ref().unwrap().details.is_some());
Source

pub fn validation_error(message: impl Into<String>) -> Self

Create a validation error (400) response.

§Example
use auth_framework::api::responses::ApiResponse;

let resp = ApiResponse::<()>::validation_error("email is invalid");
assert_eq!(resp.error.as_ref().unwrap().code, "VALIDATION_ERROR");
Source

pub fn unauthorized() -> Self

Create an unauthorized (401) error response.

§Example
use auth_framework::api::responses::ApiResponse;

let resp = ApiResponse::<()>::unauthorized();
assert_eq!(resp.error.as_ref().unwrap().code, "UNAUTHORIZED");
Source

pub fn forbidden() -> Self

Create a forbidden (403) error response.

§Example
use auth_framework::api::responses::ApiResponse;

let resp = ApiResponse::<()>::forbidden();
assert_eq!(resp.error.as_ref().unwrap().code, "FORBIDDEN");
Source

pub fn forbidden_with_message(message: impl Into<String>) -> Self

Create a forbidden (403) error with a custom message.

§Example
use auth_framework::api::responses::ApiResponse;

let resp = ApiResponse::<()>::forbidden_with_message("admin area");
assert_eq!(resp.error.as_ref().unwrap().message, "admin area");
Source

pub fn not_found(resource: impl Into<String>) -> Self

Create a not-found (404) error naming the missing resource.

§Example
use auth_framework::api::responses::ApiResponse;

let resp = ApiResponse::<()>::not_found("User");
assert!(resp.error.as_ref().unwrap().message.contains("not found"));
Source

pub fn not_found_with_message(message: impl Into<String>) -> Self

Create a not-found (404) error with a custom message.

§Example
use auth_framework::api::responses::ApiResponse;

let resp = ApiResponse::<()>::not_found_with_message("deleted");
assert_eq!(resp.error.as_ref().unwrap().code, "NOT_FOUND");
Source

pub fn error_with_message( code: impl Into<String>, message: impl Into<String>, ) -> Self

Create an error response with a custom code and message (alias for error).

§Example
use auth_framework::api::responses::ApiResponse;

let resp = ApiResponse::<()>::error_with_message("LIMIT", "rate exceeded");
assert_eq!(resp.error.as_ref().unwrap().code, "LIMIT");
Source

pub fn internal_error() -> Self

Create an internal server error (500) response.

§Example
use auth_framework::api::responses::ApiResponse;

let resp = ApiResponse::<()>::internal_error();
assert_eq!(resp.error.as_ref().unwrap().code, "SERVER_ERROR");

Trait Implementations§

Source§

impl<T: Debug> Debug for ApiResponse<T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl From<AuthError> for ApiResponse<()>

Convert an AuthError into an appropriate API error response.

Maps error variants to HTTP-semantic error codes:

  • TokenINVALID_TOKEN
  • ValidationVALIDATION_ERROR
  • AuthMethodINVALID_CREDENTIALS
  • UserNotFoundNOT_FOUND
  • PermissionFORBIDDEN
  • RateLimitRATE_LIMITED
  • everything else → SERVER_ERROR
Source§

fn from(error: AuthError) -> Self

Converts to this type from the input type.
Source§

impl<T> IntoResponse for ApiResponse<T>
where T: Serialize,

Source§

fn into_response(self) -> Response

Create a response.
Source§

impl<T> Serialize for ApiResponse<T>
where T: Serialize,

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more

Auto Trait Implementations§

§

impl<T> Freeze for ApiResponse<T>
where T: Freeze,

§

impl<T> RefUnwindSafe for ApiResponse<T>
where T: RefUnwindSafe,

§

impl<T> Send for ApiResponse<T>
where T: Send,

§

impl<T> Sync for ApiResponse<T>
where T: Sync,

§

impl<T> Unpin for ApiResponse<T>
where T: Unpin,

§

impl<T> UnsafeUnpin for ApiResponse<T>
where T: UnsafeUnpin,

§

impl<T> UnwindSafe for ApiResponse<T>
where T: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

Source§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

Source§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

Source§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more