conduit/src/database/globals.rs

74 lines
2.3 KiB
Rust
Raw Normal View History

use std::convert::TryInto;
use crate::{utils, Error, Result};
use ruma::identifiers::ServerName;
pub const COUNTER: &str = "c";
pub struct Globals {
pub(super) globals: sled::Tree,
2020-06-05 17:19:26 +01:00
keypair: ruma::signatures::Ed25519KeyPair,
reqwest_client: reqwest::Client,
server_name: Box<ServerName>,
registration_disabled: bool,
}
impl Globals {
2020-06-09 14:13:17 +01:00
pub fn load(globals: sled::Tree, config: &rocket::Config) -> Result<Self> {
2020-06-05 17:19:26 +01:00
let keypair = ruma::signatures::Ed25519KeyPair::new(
&*globals
2020-06-09 14:13:17 +01:00
.update_and_fetch("keypair", utils::generate_keypair)?
.expect("utils::generate_keypair always returns Some"),
"key1".to_owned(),
)
.map_err(|_| Error::bad_database("Private or public keys are invalid."))?;
2020-06-09 14:13:17 +01:00
Ok(Self {
globals,
keypair,
reqwest_client: reqwest::Client::new(),
server_name: config
.get_str("server_name")
.unwrap_or("localhost")
.to_string()
.try_into()
.map_err(|_| Error::BadConfig("Invalid server name found."))?,
registration_disabled: config.get_bool("registration_disabled").unwrap_or(false),
2020-06-09 14:13:17 +01:00
})
}
/// Returns this server's keypair.
2020-06-05 17:19:26 +01:00
pub fn keypair(&self) -> &ruma::signatures::Ed25519KeyPair {
&self.keypair
}
/// Returns a reqwest client which can be used to send requests.
pub fn reqwest_client(&self) -> &reqwest::Client {
&self.reqwest_client
}
pub fn next_count(&self) -> Result<u64> {
Ok(utils::u64_from_bytes(
&self
.globals
.update_and_fetch(COUNTER, utils::increment)?
.expect("utils::increment will always put in a value"),
2020-06-09 14:13:17 +01:00
)
.map_err(|_| Error::bad_database("Count has invalid bytes."))?)
}
pub fn current_count(&self) -> Result<u64> {
2020-06-09 14:13:17 +01:00
self.globals.get(COUNTER)?.map_or(Ok(0_u64), |bytes| {
Ok(utils::u64_from_bytes(&bytes)
.map_err(|_| Error::bad_database("Count has invalid bytes."))?)
2020-06-09 14:13:17 +01:00
})
}
pub fn server_name(&self) -> &ServerName {
self.server_name.as_ref()
}
pub fn registration_disabled(&self) -> bool {
self.registration_disabled
}
}