1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
//! Time related functions and types.
//!
//! It's usually a good idea to control where the time comes from
//! in an application so that it can be mocked for testing and it can be
//! controlled in production so we get the intended behavior without
//! relying on the specific time zone for the underlying system.
//!
//! Clocks use the type `DurationSinceUnixEpoch` which is a
//! `std::time::Duration` since the Unix Epoch (timestamp).
//!
//! ```text
//! Local time: lun 2023-03-27 16:12:00 WEST
//! Universal time: lun 2023-03-27 15:12:00 UTC
//! Time zone: Atlantic/Canary (WEST, +0100)
//! Timestamp: 1679929914
//! Duration: 1679929914.10167426
//! ```
//!
//! > **NOTICE**: internally the `Duration` is stores it's main unit as seconds in a `u64` and it will
//! > overflow in 584.9 billion years.
//!
//! > **NOTICE**: the timestamp does not depend on the time zone. That gives you
//! > the ability to use the clock regardless of the underlying system time zone
//! > configuration. See [Unix time Wikipedia entry](https://en.wikipedia.org/wiki/Unix_time).
use instrument;
/// A duration measured from the Unix Epoch (1970-01-01 00:00:00 UTC).
///
/// This is a type alias for [`std::time::Duration`]. It carries no
/// tracker-specific logic and lives here so that `torrust-clock`
/// has no dependency on `torrust-tracker-primitives`.
pub type DurationSinceUnixEpoch = Duration;
/// This code needs to be copied into each crate.
/// Working version, for production.
pub type CurrentClock = Working;
/// Stopped version, for testing.
pub type CurrentClock = Stopped;
/// It initializes the application static values.
///
/// These values are accessible throughout the entire application:
///
/// - The time when the application started.
/// - An ephemeral instance random seed. This seed is used for encryption and
/// it's changed when the main application process is restarted.