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/passwordchange.rs | |
| parent | add UserType implementation for required signalproxy objects (diff) | |
implement rpc calls
Diffstat (limited to '')
| -rw-r--r-- | src/message/signalproxy/rpccall/passwordchange.rs | 88 |
1 files changed, 88 insertions, 0 deletions
diff --git a/src/message/signalproxy/rpccall/passwordchange.rs b/src/message/signalproxy/rpccall/passwordchange.rs new file mode 100644 index 0000000..38bfc97 --- /dev/null +++ b/src/message/signalproxy/rpccall/passwordchange.rs @@ -0,0 +1,88 @@ +use crate::primitive::{PeerPtr, Variant}; + +use super::{Direction, RpcCallType}; + +#[derive(Clone, Debug, PartialEq)] +pub struct ChangePassword { + /// Always zero, only has a value within of the core itself. + peer: PeerPtr, + /// Username + user: String, + /// Old Password + before: String, + // New Password + after: String, +} + +impl RpcCallType for ChangePassword { + const NAME: &str = "2changePassword(PeerPtr,QString,QString,QString)"; + const DIRECTION: Direction = Direction::ClientToServer; + + fn to_network(&self) -> Result<Vec<crate::primitive::Variant>, crate::ProtocolError> { + Ok(vec![ + Variant::ByteArray(Self::NAME.to_string()), + self.peer.clone().into(), + self.user.clone().into(), + self.before.clone().into(), + self.after.clone().into(), + ]) + } + + fn from_network( + size: usize, + input: &mut crate::primitive::VariantList, + ) -> Result<(usize, super::RpcCall), crate::ProtocolError> + where + Self: Sized, + { + Ok(( + size, + Self { + peer: match_variant!(input.remove(0), Variant::PeerPtr), + user: match_variant!(input.remove(0), Variant::String), + before: match_variant!(input.remove(0), Variant::String), + after: match_variant!(input.remove(0), Variant::String), + } + .into(), + )) + } +} + +/// Returns if the recent password change attempt has been a success. +/// This is one of the few responses which only gets sent to the client which sent the original request. +#[derive(Clone, Debug, PartialEq)] +pub struct PasswordChanged { + /// Always zero, only has a value within of the core itself. + peer: PeerPtr, + success: bool, +} + +impl RpcCallType for PasswordChanged { + const NAME: &str = "2passwordChanged(PeerPtr,bool)"; + const DIRECTION: Direction = Direction::ServerToClient; + + fn to_network(&self) -> Result<Vec<crate::primitive::Variant>, crate::ProtocolError> { + Ok(vec![ + Variant::ByteArray(Self::NAME.to_string()), + self.peer.clone().into(), + self.success.clone().into(), + ]) + } + + fn from_network( + size: usize, + input: &mut crate::primitive::VariantList, + ) -> Result<(usize, super::RpcCall), crate::ProtocolError> + where + Self: Sized, + { + Ok(( + size, + Self { + peer: match_variant!(input.remove(0), Variant::PeerPtr), + success: match_variant!(input.remove(0), Variant::bool), + } + .into(), + )) + } +} |
