FreeSwitch ESL implementation for Rust
use freeswitch_esl::{Esl, EslError};
use tokio::net::TcpStream;
#[tokio::main]
async fn main() -> Result<(), EslError> {
let addr = "localhost:8021"; // Freeswitch host
let stream = TcpStream::connect(addr).await?;
let password = "ClueCon";
let inbound = Esl::inbound(stream, password).await?;
let reloadxml = inbound.api("reloadxml").await?;
println!("reloadxml response : {:?}", reloadxml);
let reloadxml = inbound.bgapi("reloadxml").await?;
println!("reloadxml response : {:?}", reloadxml);
Ok(())
}
To use it in outbound mode, add the following line to your FreeSWITCH dialplan:
<action application="socket" data="127.0.0.1:8085 async full"/>
In the main.rs
use freeswitch_esl::{Esl, EslConnection, EslError};
use tokio::net::TcpListener;
async fn process_call(conn: EslConnection) -> Result<(), EslError> {
conn.answer().await?;
conn.playback("ivr/ivr-welcome.wav").await?;
let digit = conn
.play_and_get_digits(
1,
1,
3,
3000,
"#",
"conference/conf-pin.wav",
"conference/conf-bad-pin.wav",
)
.await?;
println!("got digit {}", digit);
conn.playback("ivr/ivr-you_entered.wav").await?;
conn.playback(&format!("digits/{}.wav", digit)).await?;
conn.hangup("NORMAL_CLEARING").await?;
Ok(())
}
#[tokio::main]
async fn main() -> Result<(), EslError> {
let addr = "0.0.0.0:8085"; // Listening address
let listener = TcpListener::bind(addr).await?;
loop {
let (socket, _) = listener.accept().await?;
tokio::spawn(async move {
let stream = Esl::outbound(socket).await.expect("Unable to create outbound connection");
process_call(stream).await.expect("Unable to process call");
});
}
}
- support for event listener