Browse Source

Merge #383

383: Make `OrderId` always represent as `Hyphenated` in DB r=da-kami a=thomaseizinger



Co-authored-by: Thomas Eizinger <thomas@eizinger.io>
debug-statements
bors[bot] 3 years ago
committed by GitHub
parent
commit
5bdd42081e
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 40
      daemon/src/model/cfd.rs

40
daemon/src/model/cfd.rs

@ -11,21 +11,44 @@ use rocket::request::FromParam;
use rust_decimal::prelude::{FromPrimitive, ToPrimitive}; use rust_decimal::prelude::{FromPrimitive, ToPrimitive};
use rust_decimal::Decimal; use rust_decimal::Decimal;
use rust_decimal_macros::dec; use rust_decimal_macros::dec;
use serde::de::Error as _;
use serde::{Deserialize, Serialize}; use serde::{Deserialize, Serialize};
use std::collections::HashMap; use std::collections::HashMap;
use std::fmt; use std::fmt;
use std::ops::{Neg, RangeInclusive}; use std::ops::{Neg, RangeInclusive};
use std::time::SystemTime; use std::time::SystemTime;
use time::Duration; use time::Duration;
use uuid::adapter::Hyphenated;
use uuid::Uuid; use uuid::Uuid;
#[derive(Debug, Copy, Clone, Serialize, Deserialize, PartialEq, Eq, Hash, sqlx::Type)] #[derive(Debug, Copy, Clone, PartialEq, Eq, Hash, sqlx::Type)]
#[sqlx(transparent)] #[sqlx(transparent)]
pub struct OrderId(Uuid); pub struct OrderId(Hyphenated);
impl Serialize for OrderId {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where
S: serde::Serializer,
{
serializer.serialize_str(&self.0.to_string())
}
}
impl<'de> Deserialize<'de> for OrderId {
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
where
D: serde::Deserializer<'de>,
{
let uuid = String::deserialize(deserializer)?;
let uuid = uuid.parse::<Uuid>().map_err(D::Error::custom)?;
Ok(Self(uuid.to_hyphenated()))
}
}
impl Default for OrderId { impl Default for OrderId {
fn default() -> Self { fn default() -> Self {
Self(Uuid::new_v4()) Self(Uuid::new_v4().to_hyphenated())
} }
} }
@ -40,7 +63,7 @@ impl<'v> FromParam<'v> for OrderId {
fn from_param(param: &'v str) -> Result<Self, Self::Error> { fn from_param(param: &'v str) -> Result<Self, Self::Error> {
let uuid = param.parse::<Uuid>()?; let uuid = param.parse::<Uuid>()?;
Ok(OrderId(uuid)) Ok(OrderId(uuid.to_hyphenated()))
} }
} }
@ -1615,6 +1638,15 @@ mod tests {
Decimal::ZERO Decimal::ZERO
); );
} }
#[test]
fn order_id_serde_roundtrip() {
let id = OrderId::default();
let deserialized = serde_json::from_str(&serde_json::to_string(&id).unwrap()).unwrap();
assert_eq!(id, deserialized);
}
} }
#[derive(Debug, Clone, Serialize, Deserialize, PartialEq)] #[derive(Debug, Clone, Serialize, Deserialize, PartialEq)]

Loading…
Cancel
Save