aboutsummaryrefslogtreecommitdiffstats
path: root/lib/warden-core/src
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/src
parent9e3e07220ef10d2b8e5251c4871d54f9c5a1e9d0 (diff)
downloadwarden-d50185df5a5870498b6c7e6b51e0368d051743ca.tar.bz2
warden-d50185df5a5870498b6c7e6b51e0368d051743ca.zip
feat: money type
Diffstat (limited to 'lib/warden-core/src')
-rw-r--r--lib/warden-core/src/google/parser.rs2
-rw-r--r--lib/warden-core/src/google/parser/money.rs110
2 files changed, 2 insertions, 110 deletions
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),
- )
- }
-}