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
61
62
63
64
65
66
67
68
69
70
71
use crate::{BuckyError, BuckyErrorCode, BuckyResult};
pub use base58::{FromBase58, ToBase58};
pub trait ToBase36 {
fn to_base36(&self) -> String;
}
pub trait FromBase36 {
fn from_base36(&self) -> BuckyResult<Vec<u8>>;
}
const ALPHABET: &[u8] = b"0123456789abcdefghijklmnopqrstuvwxyz";
impl ToBase36 for [u8] {
fn to_base36(&self) -> String {
base_x::encode(ALPHABET, self)
}
}
impl FromBase36 for str {
fn from_base36(&self) -> BuckyResult<Vec<u8>> {
base_x::decode(ALPHABET, &self.to_ascii_lowercase()).map_err(|e| {
let msg = format!("convert string to base36 error! {self}, {e}");
BuckyError::new(BuckyErrorCode::InvalidFormat, msg)
})
}
}
#[cfg(test)]
mod test {
use std::str::FromStr;
use crate::*;
fn test_convert(s: &str) -> (ObjectId, String) {
let id = ObjectId::from_str(s).unwrap();
let v = id.to_base36();
println!("{}", v);
let id2 = ObjectId::from_base36(&v).unwrap();
assert_eq!(id, id2);
let id3 = ObjectId::from_str(&v).unwrap();
assert_eq!(id, id3);
let id2 = ObjectId::from_base36(&v.to_uppercase()).unwrap();
assert_eq!(id, id2);
(id, v)
}
#[test]
fn test() {
let id = ObjectId::default();
let v = id.as_slice().to_base36();
println!("{}", v);
let s = "9tGpLNna8UVtPYCfV1LbRN2Bqa5G9vRBKhDhZiWjd7wA";
let (id1, id11) = test_convert(s);
let s = "9tGpLNna8P1hutR3y6i1gSGuosoLXLxa72HMrcEQnrgk";
let (id2, id22) = test_convert(s);
assert_ne!(id11, id22);
assert_ne!(id1, id2);
let s = "95RvaS5eWQsLpCGgkY773EKomgfa73EcmGP9VHWnwig3";
test_convert(s);
}
}