Line data Source code
1 : //! Tools for client/server/stored key management.
2 :
3 : /// Faithfully taken from PostgreSQL.
4 : pub const SCRAM_KEY_LEN: usize = 32;
5 :
6 : /// One of the keys derived from the [password](super::password::SaltedPassword).
7 : /// We use the same structure for all keys, i.e.
8 : /// `ClientKey`, `StoredKey`, and `ServerKey`.
9 218 : #[derive(Clone, Default, PartialEq, Eq, Debug)]
10 : #[repr(transparent)]
11 : pub struct ScramKey {
12 : bytes: [u8; SCRAM_KEY_LEN],
13 : }
14 :
15 : impl ScramKey {
16 126 : pub fn sha256(&self) -> Self {
17 126 : super::sha256([self.as_ref()]).into()
18 126 : }
19 :
20 166 : pub fn as_bytes(&self) -> [u8; SCRAM_KEY_LEN] {
21 166 : self.bytes
22 166 : }
23 : }
24 :
25 : impl From<[u8; SCRAM_KEY_LEN]> for ScramKey {
26 : #[inline(always)]
27 630 : fn from(bytes: [u8; SCRAM_KEY_LEN]) -> Self {
28 630 : Self { bytes }
29 630 : }
30 : }
31 :
32 : impl AsRef<[u8]> for ScramKey {
33 : #[inline(always)]
34 332 : fn as_ref(&self) -> &[u8] {
35 332 : &self.bytes
36 332 : }
37 : }
|