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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
use std::fmt;
use digest::{Digest, DynDigest};
use rand::RngCore;
use crate::hash::Hash;
pub enum PaddingScheme {
PKCS1v15Encrypt,
PKCS1v15Sign { hash: Option<Hash> },
OAEP {
digest: Box<dyn DynDigest>,
label: Option<String>,
},
PSS {
salt_rng: Box<dyn RngCore>,
digest: Box<dyn DynDigest>,
salt_len: Option<usize>,
},
}
impl fmt::Debug for PaddingScheme {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
match self {
PaddingScheme::PKCS1v15Encrypt => write!(f, "PaddingScheme::PKCS1v15Encrypt"),
PaddingScheme::PKCS1v15Sign { ref hash } => {
write!(f, "PaddingScheme::PKCS1v15Sign({:?})", hash)
}
PaddingScheme::OAEP { ref label, .. } => {
write!(f, "PaddingScheme::OAEP({:?})", label)
}
PaddingScheme::PSS { ref salt_len, .. } => {
write!(f, "PaddingScheme::PSS(salt_len: {:?})", salt_len)
}
}
}
}
impl PaddingScheme {
pub fn new_pkcs1v15_encrypt() -> Self {
PaddingScheme::PKCS1v15Encrypt
}
pub fn new_pkcs1v15_sign(hash: Option<Hash>) -> Self {
PaddingScheme::PKCS1v15Sign { hash }
}
pub fn new_oaep<T: 'static + Digest + DynDigest>() -> Self {
PaddingScheme::OAEP {
digest: Box::new(T::new()),
label: None,
}
}
pub fn new_oaep_with_label<T: 'static + Digest + DynDigest, S: AsRef<str>>(label: S) -> Self {
PaddingScheme::OAEP {
digest: Box::new(T::new()),
label: Some(label.as_ref().to_string()),
}
}
pub fn new_pss<T: 'static + Digest + DynDigest, S: 'static + RngCore>(rng: S) -> Self {
PaddingScheme::PSS {
salt_rng: Box::new(rng),
digest: Box::new(T::new()),
salt_len: None,
}
}
pub fn new_pss_with_salt<T: 'static + Digest + DynDigest, S: 'static + RngCore>(
rng: S,
len: usize,
) -> Self {
PaddingScheme::PSS {
salt_rng: Box::new(rng),
digest: Box::new(T::new()),
salt_len: Some(len),
}
}
}