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
extern crate uuid;
extern crate crypto;
use uuid::Uuid;
use std::fmt;
use std::ops::Deref;
use crypto::digest::Digest;
use crypto::sha2::Sha256;
#[derive(Eq, PartialEq, Debug, Clone, Hash)]
pub struct Token {
key: String,
}
impl Token {
pub fn new(secret: &str) -> Token {
let mut hasher = Sha256::new();
hasher.input_str(secret);
hasher.input_str(Uuid::new_v4().to_string().deref());
Token {
key: hasher.result_str(),
}
}
pub fn new_from_str(key: &str) -> Token {
Token {
key: key.to_string(),
}
}
}
impl fmt::Display for Token {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "{}", self.key)
}
}