Skip to main content

TimeHandler

Struct TimeHandler 

Source
pub struct TimeHandler;
Expand description

Time validation handler

Validates and canonicalizes time values. Supports multiple input formats:

  • Single or double-digit hours: 0, 1, 01, 23 (converted to HH00 format)
  • HH:MM format: Standard time with colon separator (e.g., “14:30”)
  • HHMM format: Compact time without separator (e.g., “1430”)

All valid inputs are canonicalized to HHMM format (4-digit string) for consistent representation in topics and storage systems.

Implementations§

Source§

impl TimeHandler

Source

pub fn validate_and_canonicalize( value: &str, field_name: &str, ) -> Result<String>

Validate and canonicalize a time value to HHMM format

This method handles multiple time input formats and converts them to the standard HHMM format used throughout the system:

§Supported Input Formats
  1. Single or double-digit hours: “0”, “1”, “01”, “23” → “0000”, “0100”, “0100”, “2300”
  2. HH:MM format: “14:30” → “1430”, “9:15” → “0915”
  3. HHMM format: “1430” → “1430” (validated and normalized)
§Arguments
  • value - The time string to validate (in any supported format)
  • field_name - Name of the field being validated (for error messages)
§Returns
  • Ok(String) - The time in canonical HHMM format
  • Err(anyhow::Error) - Invalid time format or impossible time
§Time Validation Rules
  • Hours must be 0-23 (24-hour format)
  • Minutes must be 0-59
  • Leading zeros are added as needed for consistent 4-digit format

Auto Trait Implementations§

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<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, 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<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