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

#595 in HTTP client

49 downloads per month

MIT license

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

~5–17MB
~235K SLoC