mirror of
https://gitlab.com/famedly/conduit.git
synced 2025-01-14 21:17:13 +01:00
fix: actually clear memory in the admin commands
This commit is contained in:
parent
c17187777f
commit
edd4a3733f
1 changed files with 18 additions and 9 deletions
|
@ -1,7 +1,8 @@
|
||||||
use std::collections::BTreeMap;
|
use std::collections::{BTreeMap, HashMap};
|
||||||
|
|
||||||
use async_trait::async_trait;
|
use async_trait::async_trait;
|
||||||
use futures_util::{stream::FuturesUnordered, StreamExt};
|
use futures_util::{stream::FuturesUnordered, StreamExt};
|
||||||
|
use lru_cache::LruCache;
|
||||||
use ruma::{
|
use ruma::{
|
||||||
api::federation::discovery::{ServerSigningKeys, VerifyKey},
|
api::federation::discovery::{ServerSigningKeys, VerifyKey},
|
||||||
signatures::Ed25519KeyPair,
|
signatures::Ed25519KeyPair,
|
||||||
|
@ -148,28 +149,36 @@ lasttimelinecount_cache: {lasttimelinecount_cache}\n"
|
||||||
|
|
||||||
fn clear_caches(&self, amount: u32) {
|
fn clear_caches(&self, amount: u32) {
|
||||||
if amount > 0 {
|
if amount > 0 {
|
||||||
self.pdu_cache.lock().unwrap().clear();
|
let c = &mut *self.pdu_cache.lock().unwrap();
|
||||||
|
*c = LruCache::new(c.capacity());
|
||||||
}
|
}
|
||||||
if amount > 1 {
|
if amount > 1 {
|
||||||
self.shorteventid_cache.lock().unwrap().clear();
|
let c = &mut *self.shorteventid_cache.lock().unwrap();
|
||||||
|
*c = LruCache::new(c.capacity());
|
||||||
}
|
}
|
||||||
if amount > 2 {
|
if amount > 2 {
|
||||||
self.auth_chain_cache.lock().unwrap().clear();
|
let c = &mut *self.auth_chain_cache.lock().unwrap();
|
||||||
|
*c = LruCache::new(c.capacity());
|
||||||
}
|
}
|
||||||
if amount > 3 {
|
if amount > 3 {
|
||||||
self.eventidshort_cache.lock().unwrap().clear();
|
let c = &mut *self.eventidshort_cache.lock().unwrap();
|
||||||
|
*c = LruCache::new(c.capacity());
|
||||||
}
|
}
|
||||||
if amount > 4 {
|
if amount > 4 {
|
||||||
self.statekeyshort_cache.lock().unwrap().clear();
|
let c = &mut *self.statekeyshort_cache.lock().unwrap();
|
||||||
|
*c = LruCache::new(c.capacity());
|
||||||
}
|
}
|
||||||
if amount > 5 {
|
if amount > 5 {
|
||||||
self.our_real_users_cache.write().unwrap().clear();
|
let c = &mut *self.our_real_users_cache.write().unwrap();
|
||||||
|
*c = HashMap::new();
|
||||||
}
|
}
|
||||||
if amount > 6 {
|
if amount > 6 {
|
||||||
self.appservice_in_room_cache.write().unwrap().clear();
|
let c = &mut *self.appservice_in_room_cache.write().unwrap();
|
||||||
|
*c = HashMap::new();
|
||||||
}
|
}
|
||||||
if amount > 7 {
|
if amount > 7 {
|
||||||
self.lasttimelinecount_cache.lock().unwrap().clear();
|
let c = &mut *self.lasttimelinecount_cache.lock().unwrap();
|
||||||
|
*c = HashMap::new();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue