#ftp-server #google-cloud #ftp #gc #libunftp #unftp

unftp-sbe-gcs

A storage back-end for libunftp, storing files in Google Cloud Storage (GCS)

10 releases

new 0.2.7 Dec 15, 2024
0.2.6 May 16, 2024
0.2.5 Dec 24, 2023
0.2.4 Sep 16, 2023
0.1.0 Mar 26, 2021

#1488 in Network programming

Download history 13/week @ 2024-08-26 22/week @ 2024-09-02 7/week @ 2024-09-09 17/week @ 2024-09-16 32/week @ 2024-09-23 27/week @ 2024-09-30 8/week @ 2024-10-07 9/week @ 2024-10-21 4/week @ 2024-10-28 5/week @ 2024-11-18 5/week @ 2024-11-25 14/week @ 2024-12-02 339/week @ 2024-12-09

363 downloads per month
Used in unftp

Apache-2.0

430KB
8K SLoC

unftp-sbe-gcs

Crate Version API Docs Crate License Follow on Telegram

An storage back-end for libunftp that let you store files in Google Cloud Storage. Please refer to the documentation and the examples directory for usage instructions.

Usage

Add the needed dependencies to Cargo.toml:

[dependencies]
libunftp = "0.20.2"
unftp-sbe-gcs = "0.2.7"
tokio = { version = "1", features = ["full"] }

And add to src/main.rs:

 use libunftp::Server;
use unftp_sbe_gcs::{ServerExt, options::AuthMethod};
use std::path::PathBuf;

#[tokio::main]
pub async fn main() {
    let server = Server::with_gcs("my-bucket", PathBuf::from("/unftp"), AuthMethod::WorkloadIdentity(None))
        .greeting("Welcome to my FTP server")
        .passive_ports(50000..65535)
        .build()
        .unwrap();

    server.listen("127.0.0.1:2121").await;
}

The above example uses the ServerExt extension trait. You can also call one of the other constructors of Server e.g.

use libunftp::Server;
use unftp_sbe_gcs::{CloudStorage, options::AuthMethod};
use std::path::PathBuf;

#[tokio::main]
pub async fn main() {
   let server = libunftp::Server::new(
       Box::new(move || CloudStorage::with_bucket_root("my-bucket", PathBuf::from("/ftp-root"), AuthMethod::WorkloadIdentity(None)))
   )
       .greeting("Welcome to my FTP server")
       .passive_ports(50000..65535)
       .build()
       .unwrap();

   server.listen("127.0.0.1:2121").await;
}

For more usage information see the examples directory and the libunftp API documentation.

Getting help and staying informed

Support is given on a best effort basis. You are welcome to engage us on Github the discussions page or create a Github issue.

You can also follow news and talk to us on Telegram

License

You're free to use, modify and distribute this software under the terms of the Apache License v2.0.

Dependencies

~26–38MB
~695K SLoC