Crates.io | twilio-async |
lib.rs | twilio-async |
version | 0.5.0 |
source | src |
created_at | 2018-06-30 20:27:33.766804 |
updated_at | 2021-09-16 14:16:13.959592 |
description | An async and ergonomic wrapper around Twilio API & TwiML |
homepage | |
repository | https://github.com/leshow/twilio |
max_upload_size | |
id | 72359 |
size | 61,251 |
An async and ergonomic wrapper around Twilio API & TwiML.
All types can run run()
or a similar function. They return a value that implements Deserialize
.
The examples/
dir has up to date working example code.
Messages:
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
let twilio = Twilio::new(account_sid, token)?;
// sending a message
twilio.send_msg("from", "to", "Hello World").run().await?;
// sending a body-less message with media
twilio
.send_msg("from", "to", "body")
.media("http://i0.kym-cdn.com/photos/images/newsfeed/000/377/946/0b9.jpg")
.run().await?;
// get details about a message
twilio.msg("messagesid").run().await?;
// redact a message
twilio.msg("messagesid").redact().await?;
// get a msg media url
twilio.msg("messagesid").media().await?;
// delete a msg
twilio.msg("messagesid").delete().await?;
// get all messages
twilio.msgs().run().await?;
// get all messages between some time
twilio.msgs().between("start date", "end date").run().await?;
// get all messages on a specific date
twilio.msgs().on("date").run().await?;
}
Calls:
let twilio = Twilio::new(env::var("TWILIO_SID")?, env::var("TWILIO_TOKEN")?)?;
let (status, resp) = twilio
.call("from", "to", "http://demo.twilio.com/docs/voice.xml")
.run().await?;
Twiml:
use twilio_async::twiml::Response;
let resp = Response::new()
.say("Hello World") // builder pattern also supports say(Say::new("Hello World").lang("de")...)
.play("https://api.twilio.com/Cowbell.mp3")
.build();
let s = "<Response><Say voice=\"man\" language=\"en\" loop=\"1\">Hello World</Say><Play loop=\"1\">https://api.twilio.com/Cowbell.mp3</Play></Response>";
assert_eq!(resp.unwrap(), s.to_string());
There is untested code for conferences/recordings.
The TwiML work is complete and has some test coverage.
PRs and suggestions are welcome.