From 7cfb51a106bcf8754219e48edacad10ca3fd4fa9 Mon Sep 17 00:00:00 2001 From: Ashelyn Rose Date: Mon, 30 Sep 2024 20:20:36 -0600 Subject: Only update status when presence_indicator is set and global latch --- src/system.rs | 30 +++++++++++++++++++----------- 1 file changed, 19 insertions(+), 11 deletions(-) (limited to 'src/system.rs') diff --git a/src/system.rs b/src/system.rs index fa44946..98bd026 100644 --- a/src/system.rs +++ b/src/system.rs @@ -8,7 +8,7 @@ use twilight_model::{channel::{message::MessageType, Message}, gateway::{payload use twilight_model::util::Timestamp; use twilight_model::http::attachment::Attachment; -use crate::{config::{AutoproxyConfig, Member, MemberName}, listener::{Listener, ClientEvent}}; +use crate::{config::{AutoproxyConfig, AutoproxyLatchScope, Member, MemberName}, listener::{Listener, ClientEvent}}; pub struct System { pub name: String, @@ -204,8 +204,8 @@ impl System { fn update_autoproxy_state_after_message(&mut self, member: Member, timestamp: Timestamp) { match &self.config.autoproxy { None => (), - Some(AutoproxyConfig::Member { name }) => (), - Some(AutoproxyConfig::Latch { scope, timeout_seconds, presence_indicator }) => { + Some(AutoproxyConfig::Member { name: _ }) => (), + Some(AutoproxyConfig::Latch { scope, timeout_seconds, presence_indicator: _ }) => { self.latch_state = Some((member.clone(), timestamp)); let tx = self.channel.0.clone(); @@ -230,15 +230,23 @@ impl System { } else { Status::Invisible }), - Some(AutoproxyConfig::Latch { scope, timeout_seconds, presence_indicator }) => - match &self.latch_state { - Some((latch_member, _last_timestamp)) => (member.clone(), if member.name == latch_member.name { - Status::Online - } else { - Status::Invisible - }), - None => (member.clone(), Status::Invisible), + Some(AutoproxyConfig::Latch { scope, timeout_seconds: _, presence_indicator }) => { + if let AutoproxyLatchScope::Server = scope { + (member.clone(), Status::Invisible) } + else if !presence_indicator { + (member.clone(), Status::Invisible) + } else { + match &self.latch_state { + Some((latch_member, _last_timestamp)) => (member.clone(), if member.name == latch_member.name { + Status::Online + } else { + Status::Invisible + }), + None => (member.clone(), Status::Invisible), + } + } + } } }).collect(); -- cgit 1.4.1