Crates.io | rusmpp |
lib.rs | rusmpp |
version | 0.1.3 |
source | src |
created_at | 2024-03-02 10:45:44.122791 |
updated_at | 2024-04-20 06:34:33.227449 |
description | A Rust SMPP library. |
homepage | |
repository | https://github.com/JadKHaddad/Rusmpp |
max_upload_size | |
id | 1159607 |
size | 512,055 |
Rust implementation of the SMPP v5 protocol.
use futures::{SinkExt, StreamExt};
use rusmpp::{
codec::command_codec::CommandCodec,
commands::{
command::Command,
pdu::Pdu,
types::{command_id::CommandId, command_status::CommandStatus},
},
};
use tokio::net::TcpStream;
use tokio_util::codec::{FramedRead, FramedWrite};
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
let stream = TcpStream::connect("34.242.18.250:2775").await?;
let (reader, writer) = stream.into_split();
let mut framed_read = FramedRead::new(reader, CommandCodec {});
let mut framed_write = FramedWrite::new(writer, CommandCodec {});
let enquire_link_command = Command::new(CommandStatus::EsmeRok, 0, Pdu::EnquireLink);
// Send commands.
framed_write.send(&enquire_link_command).await?;
// Wait for responses.
while let Some(Ok(command)) = framed_read.next().await {
if let CommandId::EnquireLinkResp = command.command_id() {
break;
}
}
Ok(())
}
See the examples directory for more examples.
Licensed under either of
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.