-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix: fix compatibilities issues w/ api and docs
* fix: Implement new communication protocol * docs: internal_api & main * fix: Add carriage return on send * chore: renamed crate's models * docs: documented api module * fix: parse json with serialize_optionnal_string & docs * fix: serde mapping & fix reading Signed-off-by: Alexis-Bernard <[email protected]> Signed-off-by: WoodenMaiden <[email protected]>
- Loading branch information
1 parent
eee63df
commit 2de3333
Showing
11 changed files
with
329 additions
and
98 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -20,3 +20,6 @@ thiserror = "1.0.32" | |
[lib] | ||
name = "agent_lib" | ||
path = "lib/src/lib.rs" | ||
|
||
[dev-dependencies] | ||
rand = "0.8.5" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
// This message is sent to the API server to indicate wether | ||
// the agent is ready or not to receive messages. | ||
|
||
pub const MESSAGE_SIZE_NB_BYTES: usize = 8; | ||
|
||
/// Represents a message sent by the agent | ||
pub struct Message { | ||
/// These are characters e.g. 00002048 | ||
pub message_size: [u8; MESSAGE_SIZE_NB_BYTES], | ||
/// stringified json, vec because size is unknown | ||
pub message: Vec<u8> | ||
} | ||
|
||
impl Message { | ||
pub fn new(message_to_send: String) -> Self { | ||
let mut message_size = [0; MESSAGE_SIZE_NB_BYTES]; | ||
let message = message_to_send.as_bytes().to_vec(); | ||
|
||
let string_size = format!("{:0>8}", message.len()); | ||
//We can't call directly as bytes as both &str and String sizes are not known at | ||
//compile time unlike message_size | ||
|
||
for (i, c) in string_size.chars().enumerate() { | ||
message_size[i] = c as u8; | ||
} | ||
|
||
Self { | ||
message_size, | ||
message | ||
} | ||
} | ||
|
||
pub fn to_bytes(&self) -> Vec<u8> { | ||
let mut bytes = Vec::new(); | ||
bytes.extend_from_slice(&self.message_size); | ||
bytes.extend_from_slice(&self.message); | ||
bytes | ||
} | ||
|
||
|
||
} | ||
|
||
#[cfg(test)] | ||
mod tests { | ||
use super::*; | ||
|
||
#[test] | ||
fn new_message_well_encoded() { | ||
let message_data = "Hello world".to_string(); | ||
let message = Message::new(message_data); | ||
assert_eq!(message.message, [72, 101, 108, 108, 111, 32, 119, 111, 114, 108, 100]); | ||
assert_eq!(message.message_size, [48, 48, 48, 48, 48, 48, 49, 49]); | ||
|
||
assert_eq!(message.to_bytes(), [48, 48, 48, 48, 48, 48, 49, 49, 72, 101, 108, 108, 111, 32, 119, 111, 114, 108, 100]); | ||
} | ||
|
||
|
||
#[test] | ||
fn message_size_badly_encoded() { | ||
let message_data = "Hello world".to_string(); | ||
let message = Message::new(message_data); | ||
assert_eq!(message.message, [72, 101, 108, 108, 111, 32, 119, 111, 114, 108, 100]); | ||
assert_ne!(message.message_size, [48, 48, 48, 48, 48, 48, 49, 50]); // should be 11, is 12 | ||
} | ||
|
||
} | ||
|
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.