6 releases
0.1.11 | Apr 20, 2024 |
---|---|
0.1.10 | Mar 5, 2024 |
#244 in HTTP client
49 downloads per month
46KB
732 lines
neocities-client
neocities-deploy • GitHub | Codeberg | Releases | AUR | AUR (git) | AUR (binary)
neocities-client • Codeberg | GitHub | crates.io | docs.rs
This is a Rust library for interacting with the Neocities API. It is part of the neocities-deploy project, a command-line tool for deploying a NeoCities site.
This project is in no way affiliated with Neocities. It is a personal project and is not endorsed by Neocities.
Usage
The Client
struct provides a simple interface for interacting with the
website API. To use it, first create a new instance of the Client
struct
(replace "username:password"
with your actual username and password):
let client = Client::builder()
.auth(Auth::from("username:password"))
.build()?;
Once you have a Client
instance, you can use its methods to interact with the
website API. For example, to create an API key (which can be later used to
authenticate with the API without providing your username and password):
let api_key = client.key()?;
println!("API key: {}", api_key);
Or to get more information about the website:
let info = client.info()?;
println!("{:?}", info);
To list the files on the website:
let files = client.list()?;
for file in files {
println!("{}", file.path);
}
To upload one or more files to the website:
client.upload(&[
("/1st_file.txt", b"Contents of the first file"),
("/2nd_file.txt", b"Contents of the second file"),
])?;
To delete one or more files from the website:
client.delete(&["file1.txt", "file2.txt"])?;
For more information on the available methods, see the documentation for the
Client
struct.
License
This project is licensed under the GNU General Public License v3.0. See the LICENSE file for details.
Dependencies
~6–8.5MB
~162K SLoC