refactor dyn KvTree out of services
Signed-off-by: Jason Volk <jason@zemos.net>
This commit is contained in:
parent
57acc4f655
commit
cb48e25783
69 changed files with 594 additions and 647 deletions
|
@ -1,26 +1,21 @@
|
|||
use std::sync::Arc;
|
||||
|
||||
use conduit::debug_warn;
|
||||
use database::KvTree;
|
||||
use conduit::{debug_warn, utils, Error, Result};
|
||||
use database::{Database, Map};
|
||||
use ruma::{events::presence::PresenceEvent, presence::PresenceState, OwnedUserId, UInt, UserId};
|
||||
|
||||
use crate::{
|
||||
presence::Presence,
|
||||
services,
|
||||
utils::{self, user_id_from_bytes},
|
||||
Error, KeyValueDatabase, Result,
|
||||
};
|
||||
use crate::{presence::Presence, services};
|
||||
|
||||
pub struct Data {
|
||||
presenceid_presence: Arc<dyn KvTree>,
|
||||
userid_presenceid: Arc<dyn KvTree>,
|
||||
presenceid_presence: Arc<Map>,
|
||||
userid_presenceid: Arc<Map>,
|
||||
}
|
||||
|
||||
impl Data {
|
||||
pub(super) fn new(db: &Arc<KeyValueDatabase>) -> Self {
|
||||
pub(super) fn new(db: &Arc<Database>) -> Self {
|
||||
Self {
|
||||
presenceid_presence: db.presenceid_presence.clone(),
|
||||
userid_presenceid: db.userid_presenceid.clone(),
|
||||
presenceid_presence: db["presenceid_presence"].clone(),
|
||||
userid_presenceid: db["userid_presenceid"].clone(),
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -135,7 +130,7 @@ fn presenceid_key(count: u64, user_id: &UserId) -> Vec<u8> {
|
|||
#[inline]
|
||||
fn presenceid_parse(key: &[u8]) -> Result<(u64, OwnedUserId)> {
|
||||
let (count, user_id) = key.split_at(8);
|
||||
let user_id = user_id_from_bytes(user_id)?;
|
||||
let user_id = utils::user_id_from_bytes(user_id)?;
|
||||
let count = utils::u64_from_bytes(count).unwrap();
|
||||
|
||||
Ok((count, user_id))
|
||||
|
|
|
@ -1,10 +1,10 @@
|
|||
use conduit::Server;
|
||||
|
||||
mod data;
|
||||
|
||||
use std::{sync::Arc, time::Duration};
|
||||
|
||||
use conduit::{debug, error, utils, Error, Result, Server};
|
||||
use data::Data;
|
||||
use database::Database;
|
||||
use futures_util::{stream::FuturesUnordered, StreamExt};
|
||||
use ruma::{
|
||||
events::presence::{PresenceEvent, PresenceEventContent},
|
||||
|
@ -13,14 +13,8 @@ use ruma::{
|
|||
};
|
||||
use serde::{Deserialize, Serialize};
|
||||
use tokio::{sync::Mutex, task::JoinHandle, time::sleep};
|
||||
use tracing::{debug, error};
|
||||
|
||||
use crate::{
|
||||
database::KeyValueDatabase,
|
||||
services, user_is_local,
|
||||
utils::{self},
|
||||
Error, Result,
|
||||
};
|
||||
use crate::{services, user_is_local};
|
||||
|
||||
/// Represents data required to be kept in order to implement the presence
|
||||
/// specification.
|
||||
|
@ -88,7 +82,7 @@ pub struct Service {
|
|||
}
|
||||
|
||||
impl Service {
|
||||
pub fn build(server: &Arc<Server>, db: &Arc<KeyValueDatabase>) -> Result<Arc<Self>> {
|
||||
pub fn build(server: &Arc<Server>, db: &Arc<Database>) -> Result<Arc<Self>> {
|
||||
let config = &server.config;
|
||||
let (timer_sender, timer_receiver) = loole::unbounded();
|
||||
Ok(Arc::new(Self {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue