0x2::clock
APIs for accessing time from move calls, via the Clock
: a unique
shared object that is created at 0x6 during genesis.
use 0x2::object;
use 0x2::transfer;
use 0x2::tx_context;
Clock
Singleton shared object that exposes time to Move calls. This object is found at address 0x6, and can only be read (accessed via an immutable reference) by entry functions.
Entry Functions that attempt to accept Clock
by mutable
reference or value will fail to verify, and honest validators
will not sign or execute transactions that use Clock
as an
input parameter, unless it is passed by immutable reference.
struct Clock has key
id: object::UID
timestamp_ms: u64
sui::clock::increment_for_testing
during
testing.
Sender is not @0x0 the system address.
const ENotSystemAddress: u64 = 0;
timestamp_ms
The clock
’s current timestamp as a running total of
milliseconds since an arbitrary point in the past.
public fun timestamp_ms(clock: &clock::Clock): u64
public fun timestamp_ms(clock: &Clock): u64 {
clock.timestamp_ms
}
create
Create and share the singleton Clock – this function is called exactly once, during genesis.
fun create(ctx: &tx_context::TxContext)
fun create(ctx: &TxContext) {
assert!(ctx.sender() == @0x0, ENotSystemAddress);
transfer::share_object(Clock {
id: object::clock(),
// Initialised to zero, but set to a real timestamp by a
// system transaction before it can be witnessed by a move
// call.
timestamp_ms: 0,
})
}
consensus_commit_prologue
fun consensus_commit_prologue(clock: &mut clock::Clock, timestamp_ms: u64, ctx: &tx_context::TxContext)
fun consensus_commit_prologue(clock: &mut Clock, timestamp_ms: u64, ctx: &TxContext) {
// Validator will make a special system call with sender set as 0x0.
assert!(ctx.sender() == @0x0, ENotSystemAddress);
clock.timestamp_ms = timestamp_ms
}