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
use {
anchor_lang::{
prelude::borsh::BorshSchema,
prelude::*,
solana_program::{clock::UnixTimestamp, slot_history::Slot, stake_history::Epoch},
AnchorDeserialize,
},
std::convert::TryFrom,
};
#[derive(AnchorDeserialize, AnchorSerialize, BorshSchema, Clone, Debug, PartialEq)]
pub struct ClockData {
pub slot: Slot,
pub epoch_start_timestamp: UnixTimestamp,
pub epoch: Epoch,
pub leader_schedule_epoch: Epoch,
pub unix_timestamp: UnixTimestamp,
}
impl From<Clock> for ClockData {
fn from(clock: Clock) -> Self {
ClockData {
slot: clock.slot,
epoch_start_timestamp: clock.epoch_start_timestamp,
epoch: clock.epoch,
leader_schedule_epoch: clock.leader_schedule_epoch,
unix_timestamp: clock.unix_timestamp,
}
}
}
impl From<&ClockData> for Clock {
fn from(clock: &ClockData) -> Self {
Clock {
slot: clock.slot,
epoch_start_timestamp: clock.epoch_start_timestamp,
epoch: clock.epoch,
leader_schedule_epoch: clock.leader_schedule_epoch,
unix_timestamp: clock.unix_timestamp,
}
}
}
impl TryFrom<Vec<u8>> for ClockData {
type Error = Error;
fn try_from(data: Vec<u8>) -> std::result::Result<Self, Self::Error> {
Ok(
borsh::try_from_slice_with_schema::<ClockData>(data.as_slice())
.map_err(|_err| ErrorCode::AccountDidNotDeserialize)?,
)
}
}