surrealdb/key/database/
az.rsuse crate::key::error::KeyCategory;
use crate::key::key_req::KeyRequirements;
use derive::Key;
use serde::{Deserialize, Serialize};
#[derive(Clone, Debug, Eq, PartialEq, PartialOrd, Serialize, Deserialize, Key)]
pub struct Az<'a> {
__: u8,
_a: u8,
pub ns: &'a str,
_b: u8,
pub db: &'a str,
_c: u8,
_d: u8,
_e: u8,
pub az: &'a str,
}
pub fn new<'a>(ns: &'a str, db: &'a str, tb: &'a str) -> Az<'a> {
Az::new(ns, db, tb)
}
pub fn prefix(ns: &str, db: &str) -> Vec<u8> {
let mut k = super::all::new(ns, db).encode().unwrap();
k.extend_from_slice(&[b'!', b'a', b'z', 0x00]);
k
}
pub fn suffix(ns: &str, db: &str) -> Vec<u8> {
let mut k = super::all::new(ns, db).encode().unwrap();
k.extend_from_slice(&[b'!', b'a', b'z', 0xff]);
k
}
impl KeyRequirements for Az<'_> {
fn key_category(&self) -> KeyCategory {
KeyCategory::DatabaseAnalyzer
}
}
impl<'a> Az<'a> {
pub fn new(ns: &'a str, db: &'a str, az: &'a str) -> Self {
Self {
__: b'/', _a: b'*', ns,
_b: b'*', db,
_c: b'!', _d: b'a', _e: b'z', az,
}
}
}
#[cfg(test)]
mod tests {
#[test]
fn key() {
use super::*;
#[rustfmt::skip]
let val = Az::new(
"ns",
"db",
"test",
);
let enc = Az::encode(&val).unwrap();
assert_eq!(enc, b"/*ns\0*db\0!aztest\0");
let dec = Az::decode(&enc).unwrap();
assert_eq!(val, dec);
}
#[test]
fn prefix() {
let val = super::prefix("namespace", "database");
assert_eq!(val, b"/*namespace\0*database\0!az\0");
}
#[test]
fn suffix() {
let val = super::suffix("namespace", "database");
assert_eq!(val, b"/*namespace\0*database\0!az\xff");
}
}