4 releases
0.1.3 | Apr 2, 2023 |
---|---|
0.1.2 | Mar 31, 2023 |
0.1.1 | Mar 30, 2023 |
0.1.0 | Mar 30, 2023 |
#556 in HTTP client
30KB
727 lines
rusty_weed
A client implementation in rust for SeaweedFS. Written with the help of reqwest as http client and serde for serialization/deserialization.
Examples
Upload bytes
let master = Master {
host: MASTER_HOST.to_string(),
port: Some(MASTER_PORT),
};
let options: AssignKeyOptions = Default::default();
let master_resp = master.assign_key(&Some(options)).await;
let fid: FID;
let volume: Volume;
match master_resp {
Ok(x) => {
println!("Address {}", x.location.url);
volume = Volume::from_str(&x.location.url).unwrap();
fid = x.fid;
}
_ => panic!("failed to assign key"),
}
let data = Bytes::from("Hello World!");
let resp = volume.upload_file_bytes(&fid, &data, &None).await;
Upload file with multipart/form-data
let master = Master {
host: MASTER_HOST.to_string(),
port: Some(MASTER_PORT),
};
let options: AssignKeyOptions = Default::default();
let master_resp = master.assign_key(&Some(options)).await;
let fid: FID;
let volume: Volume;
match master_resp {
Ok(x) => {
println!("Address {}", x.location.url);
volume = Volume::from_str(&x.location.url).unwrap();
fid = x.fid;
}
_ => panic!("failed to assign key"),
}
let form = Form::new().part("file", Part::text("Hello World!").file_name("hello.txt").mime_str("text/plain").unwrap());
let file_resp = volume.upload_file_form(&fid, form, &None).await;
TODO
Master endpoints
- /vol/vacuum
- /vol/grow
- /col/delete
- /cluster/status
- /cluster/healthz
- /dir/status
- /vol/status
Volume endpoints
- /status
Filer endpoints
- all
Dependencies
~4–17MB
~229K SLoC