2020-03-30 14:46:18 +03:00
|
|
|
use std::{
|
|
|
|
convert::TryInto,
|
|
|
|
time::{SystemTime, UNIX_EPOCH},
|
|
|
|
};
|
2020-03-29 14:48:44 +03:00
|
|
|
|
|
|
|
pub fn millis_since_unix_epoch() -> js_int::UInt {
|
|
|
|
(SystemTime::now()
|
|
|
|
.duration_since(UNIX_EPOCH)
|
|
|
|
.unwrap()
|
|
|
|
.as_millis() as u32)
|
|
|
|
.into()
|
|
|
|
}
|
2020-03-29 22:05:20 +03:00
|
|
|
|
2020-03-30 14:46:18 +03:00
|
|
|
pub fn increment(old: Option<&[u8]>) -> Option<Vec<u8>> {
|
|
|
|
let number = match old {
|
|
|
|
Some(bytes) => {
|
|
|
|
let array: [u8; 8] = bytes.try_into().unwrap();
|
|
|
|
let number = u64::from_be_bytes(array);
|
|
|
|
number + 1
|
|
|
|
}
|
|
|
|
None => 0,
|
|
|
|
};
|
2020-03-29 22:05:20 +03:00
|
|
|
|
2020-03-30 14:46:18 +03:00
|
|
|
Some(number.to_be_bytes().to_vec())
|
2020-03-29 22:05:20 +03:00
|
|
|
}
|
|
|
|
|
2020-04-03 18:27:08 +03:00
|
|
|
pub fn u64_from_bytes(bytes: &[u8]) -> u64 {
|
|
|
|
let array: [u8; 8] = bytes.try_into().expect("bytes are valid u64");
|
|
|
|
u64::from_be_bytes(array)
|
|
|
|
}
|
|
|
|
|
2020-03-30 14:46:18 +03:00
|
|
|
pub fn string_from_bytes(bytes: &[u8]) -> String {
|
|
|
|
String::from_utf8(bytes.to_vec()).expect("bytes are valid utf8")
|
2020-03-29 22:05:20 +03:00
|
|
|
}
|