Crates.io | remotefs-kube |
lib.rs | remotefs-kube |
version | 0.4.0 |
source | src |
created_at | 2024-07-16 16:31:45.693705 |
updated_at | 2024-09-30 09:45:29.351717 |
description | remotefs implementation for kube |
homepage | |
repository | https://github.com/remotefs-rs/remotefs-rs-kube |
max_upload_size | |
id | 1305248 |
size | 141,491 |
~ Remotefs kube client ~
Developed by @veeso
Current version: 0.4.0 (29/09/2024)
remotefs client implementation for Kube.
First of all you need to add remotefs and the client to your project dependencies:
remotefs = "^0.3"
remotefs-kube = "^0.4"
these features are supported:
find
: enable find()
method for RemoteFs. (enabled by default)no-log
: disable logging. By default, this library will log via the log
crate.The library provides two different clients:
The MultiPod client gives access to all the pods with their own containers in a namespace.
This client creates an abstract file system with the following structure
So paths have the following structure: /pod-name/container-name/path/to/file
.
// import remotefs trait and client
use remotefs::RemoteFs;
use remotefs_kube::KubeMultiPodFs;
use std::path::Path;
let rt = Arc::new(
tokio::runtime::Builder::new_current_thread()
.enable_all()
.build()
.unwrap(),
);
let mut client: KubeMultiPodFs = KubeMultiPodFs::new(&rt);
// connect
assert!(client.connect().is_ok());
// get working directory
println!("Wrkdir: {}", client.pwd().ok().unwrap().display());
// change working directory
assert!(client.change_dir(Path::new("/my-pod/alpine/tmp")).is_ok());
// disconnect
assert!(client.disconnect().is_ok());
Here is a basic usage example, with the KubeContainerFs
client, which is used to connect and interact with a single container on a certain pod. This client gives the entire access to the container file system.
// import remotefs trait and client
use remotefs::RemoteFs;
use remotefs_kube::KubeContainerFs;
use std::path::Path;
let rt = Arc::new(
tokio::runtime::Builder::new_current_thread()
.enable_all()
.build()
.unwrap(),
);
let mut client: KubeContainerFs = KubeContainerFs::new("my-pod", "container-name", &rt);
// connect
assert!(client.connect().is_ok());
// get working directory
println!("Wrkdir: {}", client.pwd().ok().unwrap().display());
// change working directory
assert!(client.change_dir(Path::new("/tmp")).is_ok());
// disconnect
assert!(client.disconnect().is_ok());
The following table states the compatibility for the client client and the remote file system trait method.
Note: connect()
, disconnect()
and is_connected()
MUST always be supported, and are so omitted in the table.
Client/Method | Kube |
---|---|
append_file | No |
append | No |
change_dir | Yes |
copy | Yes |
create_dir | Yes |
create_file | Yes |
create | No |
exec | Yes |
exists | Yes |
list_dir | Yes |
mov | Yes |
open_file | Yes |
open | No |
pwd | Yes |
remove_dir_all | Yes |
remove_dir | Yes |
remove_file | Yes |
setstat | Yes |
stat | Yes |
symlink | Yes |
View remotefs-kube's changelog HERE
remotefs-kube is licensed under the MIT license.
You can read the entire license HERE