aboutsummaryrefslogtreecommitdiff
path: root/src/server/cmd
diff options
context:
space:
mode:
authorFuwn <[email protected]>2021-03-24 11:39:16 +0000
committerFuwn <[email protected]>2021-03-24 11:39:16 +0000
commit6b03628352aeda71c794dc19750edf2497a88185 (patch)
tree64f48199f0b6716c52052fb81a9a8973431f2efb /src/server/cmd
parentetc: Remove unused module and implement structures (diff)
downloadwhirl-6b03628352aeda71c794dc19750edf2497a88185.tar.xz
whirl-6b03628352aeda71c794dc19750edf2497a88185.zip
format: Move server type specific functions to correct modules
Diffstat (limited to 'src/server/cmd')
-rw-r--r--src/server/cmd/buddy_list.rs14
-rw-r--r--src/server/cmd/mod.rs3
-rw-r--r--src/server/cmd/text.rs46
3 files changed, 63 insertions, 0 deletions
diff --git a/src/server/cmd/buddy_list.rs b/src/server/cmd/buddy_list.rs
new file mode 100644
index 0000000..1423808
--- /dev/null
+++ b/src/server/cmd/buddy_list.rs
@@ -0,0 +1,14 @@
+/// In the future, this will take a `Vec` of buddies and dynamically
+/// create a response packet based on the amount of buddies given.
+pub fn create_buddy_list_notify_command(buddy: &str) -> Vec<u8> {
+ let mut buddy_list_notify = Vec::with_capacity(5 + buddy.len());
+ buddy_list_notify.push(0x01); // ?
+ buddy_list_notify.push(0x1E); // BUDDYLISTNOTIFY
+ buddy_list_notify.push(buddy.len() as u8); // Buddy name length
+ for i in buddy.bytes() { buddy_list_notify.push(i); } // Buddy name
+ buddy_list_notify.push(0x01); // Is buddy logged on?
+ // Insert data length as first byte.
+ buddy_list_notify.insert(0, buddy_list_notify.len() as u8 + 1); // ^
+
+ buddy_list_notify // Return created array
+}
diff --git a/src/server/cmd/mod.rs b/src/server/cmd/mod.rs
new file mode 100644
index 0000000..c211484
--- /dev/null
+++ b/src/server/cmd/mod.rs
@@ -0,0 +1,3 @@
+pub mod buddy_list;
+// pub mod property;
+pub mod text;
diff --git a/src/server/cmd/text.rs b/src/server/cmd/text.rs
new file mode 100644
index 0000000..a0ada32
--- /dev/null
+++ b/src/server/cmd/text.rs
@@ -0,0 +1,46 @@
+pub fn create_text_command(user: &str, message: &str) -> Vec<u8> {
+ let mut text = Vec::with_capacity(6 + user.len() + message.len());
+ text.push(0x01); // ?
+ text.push(0x0E); // Command type
+ text.push(0x00); // Assumed to be a divider.
+ text.push(user.len() as u8); // 'user' length
+ for i in user.bytes() { text.push(i); } // Pushing 'user'
+ text.push(message.len() as u8); // 'message' length
+ for i in message.bytes() { text.push(i); } // Pushing `message`
+ text.insert(0, text.len() as u8 + 1); // Insert data length as first byte.
+
+ text // Return created array
+}
+
+// TODO: Get this working!
+// pub fn get_message_from_text_command(buffer: &'static [u8; 1024]) -> &'static str {
+// from_utf8(
+// &buffer[6..*&buffer.get(0).unwrap().to_owned() as usize]
+// ).unwrap()
+// }
+
+pub fn create_text_command_with_action(
+ user: &str,
+ message: &str,
+ // action: &str // Not accepting input until I figure out how actions work.
+) -> Vec<u8> {
+ let mut text = Vec::with_capacity(6 + user.len() + message.len());
+ text.push(0x01); // ?
+ text.push(0x0E); // Command type
+ text.push(0x00); // Assumed to be a divider.
+ text.push(user.len() as u8); // 'user' length
+ for i in user.bytes() { text.push(i); } // Pushing 'user'
+ text.push(message.len() as u8); // 'message' length
+ for i in message.bytes() { text.push(i); } // Pushing `message`
+
+ let action: [u8; 18] = [
+ 0x12, 0x01, 0x11, 0x00, 0x05, 0x54, 0x52, 0x41,
+ 0x44, 0x45, 0x07, 0x26, 0x7c, 0x2b, 0x69, 0x6e,
+ 0x76, 0x3e
+ ];
+ for i in action.iter() { text.push(*i); }
+
+ text.insert(0, text.len() as u8 + 1); // Insert data length as first byte.
+
+ text // Return created array
+}