7 releases (4 breaking)
0.5.0 | May 26, 2024 |
---|---|
0.4.0 | Nov 22, 2022 |
0.3.0 | May 23, 2022 |
0.2.2 | Apr 17, 2022 |
0.1.0 | Jan 9, 2022 |
#786 in Network programming
53KB
1K
SLoC
aria2-ws
An aria2 websocket jsonrpc in Rust.
Built with tokio
.
Features
- Methods and typed responses
- Auto reconnect
- Ensures
on_download_complete
andon_error
callback to be executed even after reconnected. - Notification subscription
Example
use std::sync::Arc;
use aria2_ws::{Client, Callbacks, TaskOptions};
use futures::FutureExt;
use serde_json::json;
use tokio::{spawn, sync::Semaphore};
async fn example() {
let client = Client::connect("ws://127.0.0.1:6800/jsonrpc", None)
.await
.unwrap();
let options = TaskOptions {
split: Some(2),
header: Some(vec!["Referer: https://www.pixiv.net/".to_string()]),
// Add extra options which are not included in TaskOptions.
extra_options: json!({"max-download-limit": "100K"})
.as_object()
.unwrap()
.clone(),
..Default::default()
};
let mut not = client.subscribe_notifications();
spawn(async move {
loop {
match not.recv().await {
Ok(msg) => println!("Received notification {:?}", &msg),
Err(broadcast::error::RecvError::Closed) => {
println!("Notification channel closed");
break;
}
Err(broadcast::error::RecvError::Lagged(_)) => {
println!("Notification channel lagged");
}
}
}
});
// use `tokio::sync::Semaphore` to wait for all tasks to finish.
let semaphore = Arc::new(Semaphore::new(0));
client
.add_uri(
vec![
"https://i.pximg.net/img-original/img/2020/05/15/06/56/03/81572512_p0.png"
.to_string(),
],
Some(options.clone()),
None,
Some(Callbacks {
on_download_complete: Some({
let s = semaphore.clone();
async move {
s.add_permits(1);
println!("Task 1 completed!");
}
.boxed()
}),
on_error: Some({
let s = semaphore.clone();
async move {
s.add_permits(1);
println!("Task 1 error!");
}
.boxed()
}),
}),
)
.await
.unwrap();
// Will 404
client
.add_uri(
vec![
"https://i.pximg.net/img-original/img/2022/01/05/23/32/16/95326322_p0.pngxxxx"
.to_string(),
],
Some(options.clone()),
None,
Some(Callbacks {
on_download_complete: Some({
let s = semaphore.clone();
async move {
s.add_permits(1);
println!("Task 2 completed!");
}
.boxed()
}),
on_error: Some({
let s = semaphore.clone();
async move {
s.add_permits(1);
println!("Task 2 error!");
}
.boxed()
}),
}),
)
.await
.unwrap();
// Wait for 2 tasks to finish.
let _ = semaphore.acquire_many(2).await.unwrap();
// Force shutdown aria2.
// client.force_shutdown().await.unwrap();
}
Dependencies
~6–13MB
~148K SLoC