use rusmpp_macros::Rusmpp;
use crate::{
pdus::borrowed::Pdu,
tlvs::borrowed::{Tlv, TlvValue},
types::borrowed::COctetString,
values::*,
};
#[derive(Default, Debug, Clone, PartialEq, Eq, Hash, PartialOrd, Ord, Rusmpp)]
#[rusmpp(decode = borrowed, test = skip)]
#[cfg_attr(feature = "arbitrary", derive(::arbitrary::Arbitrary))]
#[cfg_attr(feature = "serde", derive(::serde::Serialize))]
pub struct QueryBroadcastSm<'a> {
pub message_id: COctetString<'a, 1, 65>,
pub source_addr_ton: Ton,
pub source_addr_npi: Npi,
pub source_addr: COctetString<'a, 1, 21>,
#[rusmpp(length = "checked")]
user_message_reference: Option<Tlv<'a>>,
}
impl<'a> QueryBroadcastSm<'a> {
pub fn new(
message_id: COctetString<'a, 1, 65>,
source_addr_ton: Ton,
source_addr_npi: Npi,
source_addr: COctetString<'a, 1, 21>,
user_message_reference: Option<UserMessageReference>,
) -> Self {
let user_message_reference = user_message_reference
.map(TlvValue::UserMessageReference)
.map(From::from);
Self {
message_id,
source_addr_ton,
source_addr_npi,
source_addr,
user_message_reference,
}
}
pub const fn user_message_reference_tlv(&'_ self) -> Option<&'_ Tlv<'_>> {
self.user_message_reference.as_ref()
}
pub fn user_message_reference(&self) -> Option<UserMessageReference> {
self.user_message_reference_tlv()
.and_then(|tlv| match tlv.value() {
Some(TlvValue::UserMessageReference(value)) => Some(value),
_ => None,
})
.copied()
}
pub fn set_user_message_reference(
&mut self,
user_message_reference: Option<UserMessageReference>,
) {
self.user_message_reference = user_message_reference
.map(TlvValue::UserMessageReference)
.map(From::from);
}
pub fn builder() -> QueryBroadcastSmBuilder<'a> {
QueryBroadcastSmBuilder::new()
}
}
impl<'a, const N: usize> From<QueryBroadcastSm<'a>> for Pdu<'a, N> {
fn from(value: QueryBroadcastSm<'a>) -> Self {
Self::QueryBroadcastSm(value)
}
}
#[derive(Debug, Default)]
pub struct QueryBroadcastSmBuilder<'a> {
inner: QueryBroadcastSm<'a>,
}
impl<'a> QueryBroadcastSmBuilder<'a> {
pub fn new() -> Self {
Self::default()
}
pub fn message_id(mut self, message_id: COctetString<'a, 1, 65>) -> Self {
self.inner.message_id = message_id;
self
}
pub fn source_addr_ton(mut self, source_addr_ton: Ton) -> Self {
self.inner.source_addr_ton = source_addr_ton;
self
}
pub fn source_addr_npi(mut self, source_addr_npi: Npi) -> Self {
self.inner.source_addr_npi = source_addr_npi;
self
}
pub fn source_addr(mut self, source_addr: COctetString<'a, 1, 21>) -> Self {
self.inner.source_addr = source_addr;
self
}
pub fn user_message_reference(
mut self,
user_message_reference: Option<UserMessageReference>,
) -> Self {
self.inner
.set_user_message_reference(user_message_reference);
self
}
pub fn build(self) -> QueryBroadcastSm<'a> {
self.inner
}
}
#[cfg(test)]
mod tests {
use crate::tests::TestInstance;
use super::*;
impl TestInstance for QueryBroadcastSm<'_> {
fn instances() -> alloc::vec::Vec<Self> {
alloc::vec![
Self::default(),
Self::builder()
.message_id(COctetString::new(b"123456789012345678901234567890\0").unwrap())
.source_addr_ton(Ton::International)
.source_addr_npi(Npi::Isdn)
.source_addr(COctetString::new(b"1234567890\0").unwrap())
.build(),
Self::builder()
.message_id(COctetString::new(b"123456789012345678901234567890\0").unwrap())
.source_addr_ton(Ton::International)
.source_addr_npi(Npi::Isdn)
.source_addr(COctetString::new(b"1234567890\0").unwrap())
.user_message_reference(Some(UserMessageReference::new(69)))
.build(),
]
}
}
#[test]
fn encode_decode() {
crate::tests::borrowed::encode_decode_with_length_test_instances::<QueryBroadcastSm>();
}
}