diff options
| author | Max Audron <audron@cocaine.farm> | 2025-03-01 20:00:36 +0100 |
|---|---|---|
| committer | Max Audron <audron@cocaine.farm> | 2025-03-01 20:02:12 +0100 |
| commit | 09bdd93113e46a5ee909190d23a2638c5f4f010b (patch) | |
| tree | 8bf27da0c09317302e6c3b2d2020ac2b7403b650 /src/message/signalproxy/rpccall/objectrenamed.rs | |
| parent | add UserType implementation for required signalproxy objects (diff) | |
implement rpc calls
Diffstat (limited to '')
| -rw-r--r-- | src/message/signalproxy/rpccall/objectrenamed.rs | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/src/message/signalproxy/rpccall/objectrenamed.rs b/src/message/signalproxy/rpccall/objectrenamed.rs new file mode 100644 index 0000000..d103345 --- /dev/null +++ b/src/message/signalproxy/rpccall/objectrenamed.rs @@ -0,0 +1,43 @@ +use crate::primitive::Variant; + +use super::{Direction, RpcCallType}; + +/// Called whenever an object has been renamed, and the object store should update its name. All future sync calls for this object will use the new name instead. +#[derive(Clone, Debug, PartialEq)] +pub struct ObjectRenamed { + classname: String, + newname: String, + oldname: String, +} + +impl RpcCallType for ObjectRenamed { + const NAME: &str = "__objectRenamed__"; + const DIRECTION: Direction = Direction::ServerToClient; + + fn to_network(&self) -> Result<Vec<crate::primitive::Variant>, crate::ProtocolError> { + Ok(vec![ + Variant::ByteArray(Self::NAME.to_string()), + Variant::ByteArray(self.classname.clone()), + self.newname.clone().into(), + self.oldname.clone().into(), + ]) + } + + fn from_network( + size: usize, + input: &mut crate::primitive::VariantList, + ) -> Result<(usize, super::RpcCall), crate::ProtocolError> + where + Self: Sized, + { + Ok(( + size, + Self { + classname: match_variant!(input.remove(0), Variant::ByteArray), + oldname: match_variant!(input.remove(0), Variant::String), + newname: match_variant!(input.remove(0), Variant::String), + } + .into(), + )) + } +} |
