diff --git a/proto/Cargo.toml b/proto/Cargo.toml index 0008338..b5e1fcd 100644 --- a/proto/Cargo.toml +++ b/proto/Cargo.toml @@ -56,7 +56,7 @@ time = { version = "0.3", default-features = false, features = [ "parsing", ] } flex-error = { version = "0.4.4", default-features = false } -chrono = { version = "0.4.24", default-features = false } +chrono = { version = "0.4.35", default-features = false } derive_more = { version = "0.99.17" } diff --git a/proto/src/serializers/timestamp.rs b/proto/src/serializers/timestamp.rs index 945f881..41bf1f0 100644 --- a/proto/src/serializers/timestamp.rs +++ b/proto/src/serializers/timestamp.rs @@ -47,8 +47,9 @@ pub trait ToMilis { impl ToMilis for Timestamp { /// Convert protobuf timestamp into miliseconds since epoch fn to_milis(&self) -> u64 { - chrono::NaiveDateTime::from_timestamp_opt(self.seconds, self.nanos as u32) + chrono::DateTime::from_timestamp(self.seconds, self.nanos as u32) .unwrap() + .to_utc() .timestamp_millis() .try_into() .expect("timestamp value out of u64 range") @@ -75,12 +76,13 @@ impl FromMilis for Timestamp { /// /// Panics when `millis` don't fit `i64` type fn from_milis(millis: u64) -> Self { - let dt = chrono::NaiveDateTime::from_timestamp_millis( + let dt = chrono::DateTime::from_timestamp_millis( millis .try_into() .expect("milliseconds timestamp out of i64 range"), ) - .expect("cannot parse timestamp"); + .expect("cannot parse timestamp") + .to_utc(); Self { nanos: dt.timestamp_subsec_nanos() as i32,