1 unstable release
0.1.0 | Sep 22, 2024 |
---|
#6 in #next-cloud
45KB
923 lines
NextCloud Client API - crate
This rust
crate provides a simple interface to interact with the NextCloud linux client.
The client has to be installed and setup on the target system for this crate to work.
Objective
The implementation aims to support most features published here: https://github.com/nextcloud/desktop/blob/master/src/gui/socketapi/socketapi.h
If there are things missing, please open an issue or provide a patch.
Contribution
Feel free to open issues for missing parts of the API. There is currently no roadmap, so integration of these might take time.
In addition patches can be provided or merge requests opened.
lib.rs
:
This crate provides an API to the NextCloud
linux client.
It connects to the socket of the client to interact.
The socket is located in the runtime directory, which is defined by the
$XDG_RUNTIME_DIR
environment variable.
If this variable is not available, the creation will fail.
The API is based on the source code published here: https://github.com/nextcloud/desktop/blob/master/src/gui/socketapi/socketapi.h
Examples
use std::path::Path;
use nextcloud_client_api::Api;
let mut api = Api::new()
.expect("failed to open API");
let version = api.version()
.expect("failed to fetch version");
let file_status = api.retrieve_file_status(
&Path::new("/Nextcloud/Documents/About-Storage-Share.pdf")
).expect("failed to retrieve file status");
Dependencies
~280–780KB
~18K SLoC