Skip to content
This repository has been archived by the owner on Jul 13, 2023. It is now read-only.

Commit

Permalink
feat: use chrono epoch times instead of time monotonic time
Browse files Browse the repository at this point in the history
Closes #1180
  • Loading branch information
bbangert committed Apr 27, 2018
1 parent a8a7d5b commit 5fc9927
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 8 deletions.
3 changes: 1 addition & 2 deletions autopush_rs/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ crate-type = ["cdylib"]
[dependencies]
bytes = "0.4.6"
cadence = "0.13.2"
chrono = "0.4.1"
chrono = "0.4.2"
env_logger = { version = "0.5.6", default-features = false }
error-chain = "0.11.0"
futures = "0.1.21"
Expand Down Expand Up @@ -42,7 +42,6 @@ slog-scope = "4.0.1"
slog-stdlog = "3.0.2"
# state_machine_future = { version = "0.1.6", features = ["debug_code_generation"] }
state_machine_future = "0.1.6"
time = "0.1.39"
tokio-core = "0.1.16"
tokio-io = "0.1.6"
tokio-openssl = "0.2.0"
Expand Down
11 changes: 5 additions & 6 deletions autopush_rs/src/client.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,15 +20,14 @@ use rusoto_dynamodb::{AttributeValue, DynamoDb};
use rusoto_dynamodb::{UpdateItemError, UpdateItemInput, UpdateItemOutput};
use state_machine_future::RentToOwn;
use tokio_core::reactor::Timeout;
use time;
use uuid::Uuid;
use woothee::parser::Parser;

use call;
use errors::*;
use protocol::{ClientMessage, Notification, ServerMessage, ServerNotification};
use server::Server;
use util::parse_user_agent;
use util::{ns_since_epoch, parse_user_agent, sec_since_epoch};
use util::megaphone::{ClientServices, Service, ServiceClientInit};

const MAX_EXPIRY: u64 = 2592000;
Expand Down Expand Up @@ -339,7 +338,7 @@ where
};

let AwaitHello { data, tx, rx, .. } = hello.take();
let connected_at = time::precise_time_ns() / 1000;
let connected_at = ns_since_epoch() / 1000;
transition!(AwaitProcessHello {
response: data.srv.hello(&connected_at, uaid.as_ref()),
data,
Expand Down Expand Up @@ -478,7 +477,7 @@ where
Err(_) => break,
}
}
let now = time::precise_time_ns() / 1000;
let now = ns_since_epoch() / 1000;
let elapsed = now - webpush.connected_at;
let parser = Parser::new();
let (ua_result, metrics_os, metrics_browser) = parse_user_agent(&parser, &user_agent);
Expand Down Expand Up @@ -833,7 +832,7 @@ where
let srv = increment_storage.data.srv.clone();
let ddb_response = retry_if(
move || {
let expiry = (time::get_time().sec as u64) + MAX_EXPIRY;
let expiry = sec_since_epoch() + MAX_EXPIRY;
let mut attr_values = HashMap::new();
attr_values.insert(
":timestamp".to_string(),
Expand Down Expand Up @@ -923,7 +922,7 @@ where
webpush.unacked_stored_highest = timestamp;
if messages.len() > 0 {
// Filter out TTL expired messages
let now = time::get_time().sec as u32;
let now = sec_since_epoch() as u32;
messages.retain(|ref msg| now < msg.ttl + msg.timestamp);
webpush.flags.increment_storage = !include_topic && timestamp.is_some();
// If there's still messages send them out
Expand Down
12 changes: 12 additions & 0 deletions autopush_rs/src/util/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
use std::io;
use std::time::Duration;

use chrono::Utc;
use hostname::get_hostname;
use futures::future::{Either, Future, IntoFuture};
use slog;
Expand Down Expand Up @@ -92,6 +93,17 @@ pub fn init_logging(json: bool) {
slog_stdlog::init().ok();
}

/// Get the time since the UNIX epoch in seconds
pub fn sec_since_epoch() -> u64 {
Utc::now().timestamp() as u64
}

/// Get the time since the UNIX epoch in nanoseconds
pub fn ns_since_epoch() -> u64 {
let now = Utc::now();
(now.timestamp() as u64) * 1_000_000_000 + (now.timestamp_subsec_nanos() as u64)
}

pub fn reset_logging() {
let logger = slog::Logger::root(slog::Discard, o!());
slog_scope::set_global_logger(logger).cancel_reset();
Expand Down

0 comments on commit 5fc9927

Please sign in to comment.