diff options
| author | Max Audron <audron@cocaine.farm> | 2020-09-26 12:01:27 +0200 |
|---|---|---|
| committer | Max Audron <audron@cocaine.farm> | 2020-09-26 12:03:01 +0200 |
| commit | 3bdae21716d10032f70a0a889070766bbbe4d141 (patch) | |
| tree | 78a1ddf98601fbbc03a9375626dfa7923ab85521 /src/message/handshake/clientlogin.rs | |
| parent | add parsing of signalproxy messages (diff) | |
split handshake.rs
Diffstat (limited to 'src/message/handshake/clientlogin.rs')
| -rw-r--r-- | src/message/handshake/clientlogin.rs | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/src/message/handshake/clientlogin.rs b/src/message/handshake/clientlogin.rs new file mode 100644 index 0000000..769245b --- /dev/null +++ b/src/message/handshake/clientlogin.rs @@ -0,0 +1,49 @@ +use crate::error::ProtocolError; +use crate::primitive::{Variant, VariantMap}; +use crate::{HandshakeDeserialize, HandshakeSerialize}; + +use failure::Error; + +/// Login to the core with user data +/// username and password are transmitted in plain text +#[derive(Debug)] +pub struct ClientLogin { + pub user: String, + pub password: String, +} + +impl HandshakeSerialize for ClientLogin { + fn serialize(&self) -> Result<Vec<u8>, Error> { + let mut values: VariantMap = VariantMap::new(); + values.insert( + "MsgType".to_string(), + Variant::String("ClientLogin".to_string()), + ); + values.insert("User".to_string(), Variant::String(self.user.clone())); + values.insert( + "Password".to_string(), + Variant::String(self.password.clone()), + ); + return HandshakeSerialize::serialize(&values); + } +} + +impl HandshakeDeserialize for ClientLogin { + fn parse(b: &[u8]) -> Result<(usize, Self), Error> { + let (len, values): (usize, VariantMap) = HandshakeDeserialize::parse(b)?; + + let msgtype = match_variant!(&values["MsgType"], Variant::StringUTF8); + + if msgtype == "ClientLogin" { + return Ok(( + len, + Self { + user: match_variant!(values["User"], Variant::String), + password: match_variant!(values["Password"], Variant::String), + }, + )); + } else { + bail!(ProtocolError::WrongMsgType); + } + } +} |
