aboutsummaryrefslogtreecommitdiff
path: root/src/cmd
diff options
context:
space:
mode:
Diffstat (limited to 'src/cmd')
-rw-r--r--src/cmd/buddy_list.rs15
-rw-r--r--src/cmd/mod.rs3
-rw-r--r--src/cmd/property.rs73
-rw-r--r--src/cmd/text.rs19
4 files changed, 110 insertions, 0 deletions
diff --git a/src/cmd/buddy_list.rs b/src/cmd/buddy_list.rs
new file mode 100644
index 0000000..95b0fdd
--- /dev/null
+++ b/src/cmd/buddy_list.rs
@@ -0,0 +1,15 @@
+/// 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
+ // The number of buddies you are being notified of?
+ buddy_list_notify.push(0x0A); // 01 // ^
+ 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/cmd/mod.rs b/src/cmd/mod.rs
new file mode 100644
index 0000000..05e4344
--- /dev/null
+++ b/src/cmd/mod.rs
@@ -0,0 +1,3 @@
+pub mod buddy_list;
+pub mod property;
+pub mod text;
diff --git a/src/cmd/property.rs b/src/cmd/property.rs
new file mode 100644
index 0000000..9ec89a8
--- /dev/null
+++ b/src/cmd/property.rs
@@ -0,0 +1,73 @@
+// struct NetToProperty {
+// _prop_id: i32,
+// _flags: i32,
+// _access: i32,
+// _string_value: String,
+// _bin_value: Vec<i32>,
+// }
+// impl NetToProperty {
+// fn parse_net_data() -> Self {
+// NetToProperty {
+// _prop_id: 0,
+// _flags: 0,
+// _access: 0,
+// _string_value: "".to_string(),
+// _bin_value: vec![]
+// }
+// }
+// }
+
+// To be honest, don't care enough to make this function.
+// It's not important enough as it stands currently.
+pub fn create_property_update_command() -> [u8; 147] { // Vec<u8>
+ // let mut property = Vec::with_capacity(2);
+ // property.push(0x01); // ?
+ // property.push(0x10); // Command type
+ //
+ // // Meaningful Data
+ // property.push(); // Property ID
+ // property.push(); // Flags
+ // property.push(); // Access
+ //
+ // // Insert data length as first byte.
+ // property.insert(0, property.len() as u8 + 1); // ^
+ //
+ // property // Return created array
+
+ [
+ 0x93, 0xFF, 0x10, 0x1B, 0x80, 0x01, 0x0C, 0x77, 0x6F,
+ 0x72, 0x6C, 0x64, 0x73, 0x33, 0x64, 0x2E, 0x63, 0x6F,
+ 0x6D, 0x1A, 0x80, 0x01, 0x12, 0x6D, 0x61, 0x69, 0x6C,
+ 0x2E, 0x77, 0x6F, 0x72, 0x6C, 0x64, 0x73, 0x2E, 0x6E,
+ 0x65, 0x74, 0x3A, 0x32, 0x35, 0x19, 0x80, 0x01, 0x28,
+ 0x68, 0x74, 0x74, 0x70, 0x3A, 0x2F, 0x2F, 0x77, 0x77,
+ 0x77, 0x2D, 0x64, 0x79, 0x6E, 0x61, 0x6D, 0x69, 0x63,
+ 0x2E, 0x75, 0x73, 0x2E, 0x77, 0x6F, 0x72, 0x6C, 0x64,
+ 0x73, 0x2E, 0x6E, 0x65, 0x74, 0x2F, 0x63, 0x67, 0x69,
+ 0x2D, 0x62, 0x69, 0x6E, 0x18, 0x80, 0x01, 0x1F, 0x68,
+ 0x74, 0x74, 0x70, 0x3A, 0x2F, 0x2F, 0x77, 0x77, 0x77,
+ 0x2D, 0x73, 0x74, 0x61, 0x74, 0x69, 0x63, 0x2E, 0x75,
+ 0x73, 0x2E, 0x77, 0x6F, 0x72, 0x6C, 0x64, 0x73, 0x2E,
+ 0x6E, 0x65, 0x74, 0x0F, 0x80, 0x01, 0x01, 0x31, 0x03,
+ 0x80, 0x01, 0x02, 0x32, 0x34, 0x01, 0x80, 0x01, 0x0C,
+ 0x57, 0x4F, 0x52, 0x4C, 0x44, 0x53, 0x4D, 0x41, 0x53,
+ 0x54, 0x45, 0x52
+ ]: [u8; 147]
+}
+
+// src\cmd\property.rs:20:1
+pub fn create_property_request_command() -> [u8; 61] {
+ [
+ 0x3D, 0x01, 0x06, 0x04, 0x01, 0x30, 0x01, 0x0C,
+ 0x57, 0x4F, 0x52, 0x4C, 0x44, 0x53, 0x4D, 0x41,
+ 0x53, 0x54, 0x45, 0x52, 0x03, 0x02, 0x32, 0x34,
+ 0x0F, 0x01, 0x31, 0x0A, 0x10,
+
+ // VAR_SERIAL
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+
+ 0x16, 0x01, 0x30, 0x05, 0x0B, 0x64, 0x69, 0x6D,
+ 0x65, 0x6E, 0x73, 0x69, 0x6F, 0x6E, 0x2D, 0x31
+ ]: [u8; 61]
+}
diff --git a/src/cmd/text.rs b/src/cmd/text.rs
new file mode 100644
index 0000000..b2cecef
--- /dev/null
+++ b/src/cmd/text.rs
@@ -0,0 +1,19 @@
+pub fn create_text_command(message: &str) -> Vec<u8> {
+ let mut text = Vec::with_capacity(6 + message.len());
+ text.push(0x01); // ?
+ text.push(0x0E); // Command type
+ text.push(0x00); // Assumed to be a divider.
+ text.push(0x00); // ^
+ text.push(message.len() as u8); // `message` length
+ for i in message.bytes() { text.push(i); } // `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()
+// }