More derives for types.
Addee new_safe constructor for Interval type
This commit is contained in:
parent
17c81f4da1
commit
762330189d
@ -2,7 +2,7 @@ use diesel::result::Error;
|
|||||||
use thiserror::Error;
|
use thiserror::Error;
|
||||||
|
|
||||||
/// Error type for CRUD operations
|
/// Error type for CRUD operations
|
||||||
#[derive(Debug, Error)]
|
#[derive(Debug, PartialEq, Error)]
|
||||||
pub enum CrudError {
|
pub enum CrudError {
|
||||||
#[error("Resource not found")]
|
#[error("Resource not found")]
|
||||||
NotFound,
|
NotFound,
|
||||||
|
@ -3,12 +3,14 @@ use derive_more::{Constructor, From};
|
|||||||
use into_response_derive::IntoResponse;
|
use into_response_derive::IntoResponse;
|
||||||
use serde::Serialize;
|
use serde::Serialize;
|
||||||
|
|
||||||
#[derive(Debug, Clone, Serialize, From, Constructor)]
|
#[derive(Debug, Clone, PartialEq, Default, Serialize, From, Constructor)]
|
||||||
pub struct Array<T: Serialize> {
|
pub struct Array<T: Serialize> {
|
||||||
pub data: Vec<T>,
|
pub data: Vec<T>,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Copy, Serialize, IntoResponse, From, Constructor)]
|
#[derive(
|
||||||
|
Debug, Clone, Copy, PartialEq, Eq, Default, Serialize, IntoResponse, From, Constructor,
|
||||||
|
)]
|
||||||
pub struct Count {
|
pub struct Count {
|
||||||
pub count: usize,
|
pub count: usize,
|
||||||
}
|
}
|
||||||
|
@ -1,9 +1,62 @@
|
|||||||
use chrono::NaiveDateTime;
|
use chrono::NaiveDateTime;
|
||||||
use derive_more::Constructor;
|
use derive_more::{Constructor, From};
|
||||||
|
|
||||||
#[derive(Debug, Clone, Copy, Default, PartialEq, Eq, Constructor)]
|
#[derive(Debug, Clone, Copy, Default, PartialEq, Eq, Constructor, From)]
|
||||||
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
|
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
|
||||||
pub struct DateTimeInterval {
|
pub struct DateTimeInterval {
|
||||||
pub start: NaiveDateTime,
|
pub start: NaiveDateTime,
|
||||||
pub end: NaiveDateTime,
|
pub end: NaiveDateTime,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl DateTimeInterval {
|
||||||
|
/// Creates a new `DateTimeInterval` from the given `start` and `end` `NaiveDateTime`s.
|
||||||
|
/// The `start` must be before the `end`.
|
||||||
|
/// If `start` is equal to or after `end`, this function will return `None`.
|
||||||
|
/// # Arguments
|
||||||
|
/// * `start` - The start of the interval.
|
||||||
|
/// * `end` - The end of the interval.
|
||||||
|
/// # Returns
|
||||||
|
/// A new `DateTimeInterval` if `start` is before `end`, otherwise `None`.
|
||||||
|
/// # Examples
|
||||||
|
/// ```
|
||||||
|
/// use chrono::{NaiveDateTime, Duration, Utc};
|
||||||
|
/// use lib::time::common::DateTimeInterval;
|
||||||
|
///
|
||||||
|
/// let start = Utc::now().naive_utc();
|
||||||
|
/// let end = start + Duration::days(1);
|
||||||
|
/// let interval = DateTimeInterval::new_safe(start, end);
|
||||||
|
/// assert_eq!(interval, Some((start, end).into()));
|
||||||
|
/// ```
|
||||||
|
/// Illegal interval:
|
||||||
|
/// ```
|
||||||
|
/// use chrono::{NaiveDateTime, Utc};
|
||||||
|
/// use lib::time::common::DateTimeInterval;
|
||||||
|
/// let start = Utc::now().naive_utc();
|
||||||
|
/// let end = start;
|
||||||
|
/// let interval = DateTimeInterval::new_safe(start, end);
|
||||||
|
/// assert_eq!(interval, None);
|
||||||
|
pub fn new_safe(start: NaiveDateTime, end: NaiveDateTime) -> Option<Self> {
|
||||||
|
if start < end {
|
||||||
|
Some(Self::new(start, end))
|
||||||
|
} else {
|
||||||
|
None
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use super::*;
|
||||||
|
use chrono::DateTime;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_new_safe() {
|
||||||
|
let start = DateTime::from_timestamp(0, 0).unwrap().naive_utc();
|
||||||
|
let end = DateTime::from_timestamp(1, 0).unwrap().naive_utc();
|
||||||
|
assert_eq!(
|
||||||
|
DateTimeInterval::new_safe(start, end),
|
||||||
|
Some(DateTimeInterval::new(start, end))
|
||||||
|
);
|
||||||
|
assert_eq!(DateTimeInterval::new_safe(end, start), None);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user