From 31072bbcde7eb70e84d4f2f3532928dc78f4ced8 Mon Sep 17 00:00:00 2001 From: Max Audron Date: Tue, 28 Sep 2021 18:12:51 +0200 Subject: add handle_syncmessage to aliasmanager --- src/message/signalproxy/objects/aliasmanager.rs | 27 +++++++++++++++++++++---- 1 file changed, 23 insertions(+), 4 deletions(-) (limited to 'src/message/signalproxy') diff --git a/src/message/signalproxy/objects/aliasmanager.rs b/src/message/signalproxy/objects/aliasmanager.rs index 2a29865..61da289 100644 --- a/src/message/signalproxy/objects/aliasmanager.rs +++ b/src/message/signalproxy/objects/aliasmanager.rs @@ -1,8 +1,10 @@ +use std::convert::TryInto; + use libquassel_derive::{Network, NetworkList, NetworkMap}; use crate::message::{StatefulSyncable, SyncProxy, Syncable}; -use crate::message::signalproxy::translation::Network; +use crate::message::signalproxy::translation::{Network, NetworkMap}; use crate::primitive::{VariantList, VariantMap}; /// AliasManager @@ -22,6 +24,23 @@ impl AliasManager { self.aliases.push(alias) } } + + pub fn handle_syncmessage( + &mut self, + session: impl SyncProxy, + msg: crate::message::SyncMessage, + ) { + match msg.slot_name.as_str() { + "requestUpdate" => { + self.request_update(session, msg.params.get(0).unwrap().try_into().unwrap()) + } + "update" => { + *self = + AliasManager::from_network_map(&mut msg.params[0].clone().try_into().unwrap()) + } + _ => (), + } + } } impl StatefulSyncable for AliasManager {} @@ -37,15 +56,15 @@ impl Syncable for AliasManager { #[network(repr = "maplist")] pub struct Alias { #[network(rename = "names", variant = "StringList")] - name: String, + pub name: String, #[network(rename = "expansions", variant = "StringList")] - expansion: String, + pub expansion: String, } #[cfg(test)] mod tests { use super::*; - use crate::message::signalproxy::translation::Network; + use crate::message::signalproxy::translation::NetworkList; use crate::primitive::{Variant, VariantList}; -- cgit v1.2.3