aboutsummaryrefslogtreecommitdiffstats
path: root/lib/warden-core
diff options
context:
space:
mode:
authorrtkay123 <dev@kanjala.com>2025-08-09 11:45:07 +0200
committerrtkay123 <dev@kanjala.com>2025-08-09 11:45:18 +0200
commitd50185df5a5870498b6c7e6b51e0368d051743ca (patch)
tree2820c340d86650efdc2e231b4190bddcd54c9f73 /lib/warden-core
parent9e3e07220ef10d2b8e5251c4871d54f9c5a1e9d0 (diff)
downloadwarden-d50185df5a5870498b6c7e6b51e0368d051743ca.tar.bz2
warden-d50185df5a5870498b6c7e6b51e0368d051743ca.zip
feat: money type
Diffstat (limited to 'lib/warden-core')
-rw-r--r--lib/warden-core/build.rs3
-rw-r--r--lib/warden-core/src/google/parser.rs2
-rw-r--r--lib/warden-core/src/google/parser/money.rs110
3 files changed, 4 insertions, 111 deletions
diff --git a/lib/warden-core/build.rs b/lib/warden-core/build.rs
index 1998137..46793ed 100644
--- a/lib/warden-core/build.rs
+++ b/lib/warden-core/build.rs
@@ -14,6 +14,7 @@ impl Entity {
vec![
"proto/iso20022/pacs_008_001_12.proto",
"proto/iso20022/pacs_002_001_12.proto",
+ "proto/googleapis/google/type/money.proto",
"proto/warden_message.proto",
]
}
@@ -84,7 +85,7 @@ fn add_serde(config: tonic_prost_build::Builder) -> tonic_prost_build::Builder {
"#[derive(serde::Serialize, serde::Deserialize)] #[serde(rename_all = \"snake_case\")]",
);
- #[cfg(feature = "time")]
+ #[cfg(feature = "serde-time")]
let config = config.type_attribute(
".google.protobuf.Timestamp",
"#[serde(try_from = \"time::OffsetDateTime\")] #[serde(into = \"String\")]",
diff --git a/lib/warden-core/src/google/parser.rs b/lib/warden-core/src/google/parser.rs
index 7405077..f2fe5bc 100644
--- a/lib/warden-core/src/google/parser.rs
+++ b/lib/warden-core/src/google/parser.rs
@@ -1,4 +1,4 @@
#[cfg(feature = "time")]
mod dt;
-//mod money;
+mod money;
diff --git a/lib/warden-core/src/google/parser/money.rs b/lib/warden-core/src/google/parser/money.rs
index 54ed5fa..a703a4a 100644
--- a/lib/warden-core/src/google/parser/money.rs
+++ b/lib/warden-core/src/google/parser/money.rs
@@ -1,4 +1,4 @@
-use crate::google::r#type::Date;
+use crate::google::r#type::Money;
/// If money cannot be created
#[derive(Debug, PartialEq)]
@@ -183,111 +183,3 @@ mod tests {
);
}
}
-
-#[cfg(feature = "time")]
-impl From<time::OffsetDateTime> for Date {
- fn from(dt: time::OffsetDateTime) -> Self {
- Self {
- year: dt.year(),
- month: dt.month() as i32,
- day: dt.day() as i32,
- }
- }
-}
-
-#[cfg(feature = "time")]
-impl From<time::Date> for Date {
- fn from(value: time::Date) -> Self {
- Self {
- year: value.year(),
- month: value.month() as i32,
- day: value.day() as i32,
- }
- }
-}
-
-#[cfg(feature = "time")]
-impl TryFrom<Date> for time::Date {
- type Error = time::Error;
-
- fn try_from(value: Date) -> Result<Self, Self::Error> {
- Ok(Self::from_calendar_date(
- value.year,
- time::Month::try_from(value.month as u8)?,
- value.day as u8,
- )?)
- }
-}
-
-#[cfg(feature = "time")]
-impl std::str::FromStr for Date {
- type Err = time::Error;
-
- fn from_str(s: &str) -> Result<Self, Self::Err> {
- let date = time::OffsetDateTime::parse(&s, &time::format_description::well_known::Rfc3339)
- .map(Date::from);
-
- match date {
- Ok(dt) => Ok(dt),
- Err(_e) => {
- let my_format = time::macros::format_description!("[year]-[month]-[day]");
- let date = time::Date::parse(&s, &my_format)?;
- Ok(Date::from(date))
- }
- }
- }
-}
-
-#[cfg(feature = "time")]
-impl TryFrom<String> for Date {
- type Error = time::Error;
-
- fn try_from(value: String) -> Result<Self, Self::Error> {
- <Date as std::str::FromStr>::from_str(&value)
- }
-}
-
-#[cfg(feature = "time")]
-impl TryFrom<super::helpers::time_util::DateItem> for Date {
- type Error = time::Error;
-
- fn try_from(value: super::helpers::time_util::DateItem) -> Result<Self, Self::Error> {
- match value {
- super::helpers::time_util::DateItem::String(ref string) => {
- <Date as std::str::FromStr>::from_str(string)
- }
- #[cfg(feature = "iso20022")]
- super::helpers::time_util::DateItem::Date { year, month, day } => {
- Ok(Date { year, month, day })
- }
- super::helpers::time_util::DateItem::Timestamp { seconds, nanos } => {
- let odt = time::OffsetDateTime::try_from(crate::google::protobuf::Timestamp {
- seconds,
- nanos,
- })?;
- Ok(Self {
- year: odt.year(),
- month: odt.month() as i32,
- day: odt.day() as i32,
- })
- }
- }
- }
-}
-
-impl From<Date> for String {
- fn from(value: Date) -> Self {
- let prepend = |value: i32| -> String {
- match value.lt(&10) {
- true => format!("0{}", value),
- false => value.to_string(),
- }
- };
- format!(
- "{}-{}-{}",
- value.year,
- prepend(value.month),
- prepend(value.day),
- )
- }
-}