mirror of
https://github.com/neondatabase/neon.git
synced 2026-05-24 00:20:37 +00:00
1) `scram::password` was used in tests only. can be replaced with `postgres_protocol::password`. 2) `postgres_protocol::authentication::sasl` provides a client impl of SASL which improves our ability to test
38 lines
852 B
Rust
38 lines
852 B
Rust
//! Tools for client/server/stored key management.
|
|
|
|
/// Faithfully taken from PostgreSQL.
|
|
pub const SCRAM_KEY_LEN: usize = 32;
|
|
|
|
/// One of the keys derived from the user's password.
|
|
/// We use the same structure for all keys, i.e.
|
|
/// `ClientKey`, `StoredKey`, and `ServerKey`.
|
|
#[derive(Clone, Default, PartialEq, Eq, Debug)]
|
|
#[repr(transparent)]
|
|
pub struct ScramKey {
|
|
bytes: [u8; SCRAM_KEY_LEN],
|
|
}
|
|
|
|
impl ScramKey {
|
|
pub fn sha256(&self) -> Self {
|
|
super::sha256([self.as_ref()]).into()
|
|
}
|
|
|
|
pub fn as_bytes(&self) -> [u8; SCRAM_KEY_LEN] {
|
|
self.bytes
|
|
}
|
|
}
|
|
|
|
impl From<[u8; SCRAM_KEY_LEN]> for ScramKey {
|
|
#[inline(always)]
|
|
fn from(bytes: [u8; SCRAM_KEY_LEN]) -> Self {
|
|
Self { bytes }
|
|
}
|
|
}
|
|
|
|
impl AsRef<[u8]> for ScramKey {
|
|
#[inline(always)]
|
|
fn as_ref(&self) -> &[u8] {
|
|
&self.bytes
|
|
}
|
|
}
|