sheave_core/messages/create_stream_result.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127
use std::io::Result as IOResult;
use crate::{
ByteBuffer,
Decoder,
Encoder,
messages::{
Channel,
ChunkData,
Command,
amf::v0::{
Number,
Null
},
headers::MessageType
}
};
/// The response message for CreateStream requests.
#[derive(Debug, Clone, Default, PartialEq)]
pub struct CreateStreamResult(Number);
impl CreateStreamResult {
/// Constructs a CreateStreamResult command.
pub fn new(message_id: Number) -> Self {
Self(message_id)
}
/// Gets the message ID which is assigned to this stream.
pub fn get_message_id(&self) -> Number {
self.0
}
}
impl From<CreateStreamResult> for u32 {
fn from(create_stream_result: CreateStreamResult) -> Self {
create_stream_result.0.as_integer() as u32
}
}
impl ChunkData for CreateStreamResult {
const CHANNEL: Channel = Channel::System;
const MESSAGE_TYPE: MessageType = MessageType::Command;
}
impl Command for CreateStreamResult {}
impl Decoder<CreateStreamResult> for ByteBuffer {
/// Decodes bytes into a CreateStreamResult command.
///
/// # Errors
///
/// * [`InsufficientBufferLength`]
///
/// When some field misses.
///
/// * [`InconsistentMarker`]
///
/// When some value is inconsistent with its marker.
///
/// # Examples
///
/// ```rust
/// use sheave_core::{
/// ByteBuffer,
/// Decoder,
/// Encoder,
/// messages::{
/// CreateStreamResult,
/// amf::v0::{
/// Number,
/// Null
/// }
/// }
/// };
///
/// let mut buffer = ByteBuffer::default();
/// buffer.encode(&Null);
/// buffer.encode(&Number::default());
/// assert!(Decoder::<CreateStreamResult>::decode(&mut buffer).is_ok());
///
/// let mut buffer = ByteBuffer::default();
/// assert!(Decoder::<CreateStreamResult>::decode(&mut buffer).is_err())
/// ```
///
/// [`InsufficientBufferLength`]: crate::byte_buffer::InsufficientBufferLength
/// [`InconsistentMarker`]: crate::messages::amf::InconsistentMarker
fn decode(&mut self) -> IOResult<CreateStreamResult> {
Decoder::<Null>::decode(self)?;
let message_id: Number = self.decode()?;
Ok(CreateStreamResult(message_id))
}
}
impl Encoder<CreateStreamResult> for ByteBuffer {
/// Encodes a CreateStreamResult command into bytes.
fn encode(&mut self, create_stream_result: &CreateStreamResult) {
self.encode(&Null);
self.encode(&create_stream_result.get_message_id());
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn decode_create_stream_result() {
let mut buffer = ByteBuffer::default();
buffer.encode(&Null);
buffer.encode(&Number::default());
let result: IOResult<CreateStreamResult> = buffer.decode();
assert!(result.is_ok());
let actual = result.unwrap();
let expected = CreateStreamResult::new(Number::default());
assert_eq!(expected, actual)
}
#[test]
fn encode_create_stream_result() {
let mut buffer = ByteBuffer::default();
let expected_message_id = 0f64;
buffer.encode(&CreateStreamResult::new(Number::new(expected_message_id)));
Decoder::<Null>::decode(&mut buffer).unwrap();
let actual_message_id: Number = buffer.decode().unwrap();
assert_eq!(expected_message_id, actual_message_id)
}
}