firetrap

Crates.iofiretrap
lib.rsfiretrap
version0.1.0
sourcesrc
created_at2018-12-05 15:14:40.430939
updated_at2018-12-05 15:14:40.430939
descriptionModern, safe and extensible FTP server library for Rust
homepage
repositoryhttps://github.com/koenw/firetrap
max_upload_size
id100263
size106,688
(koenw)

documentation

https://docs.rs/firetrap/

README

firetrap

Firetrap helps you create modern, safe and extensible FTP servers in Rust.

Because of its plugable authentication and storage backends (e.g. local filesystem, Google Buckets) it's more flexible than traditional FTP servers and a perfect match for the cloud.

It is currently under heavy development and not yet recommended for production use. API MAY BREAK

Prerequisites

You'll need Rust to build firetrap. There are no runtime dependencies besides the OS and libc.

Getting started

If you've got Rust and cargo installed, create your project with

cargo new my_project

Then add firetrap to your projects dependencies in Cargo.toml:

[dependencies]
firetrap = "*"

Now you're ready to write your server! Add the following to src/main.rs:

extern crate firetrap;

fn main() {
  let server = firetrap::Server::with_root(std::env::temp_dir());
  server.listen("127.0.0.1:2121");
}

You can now run your server with cargo run and connect to localhost:2121 with your favourite FTP client :)

For more examples checkout out the examples directory.

Contributing

First of all, thank you for you interest in contributing to firetrap! Please feel free to create a github issue if you encounter any problems. a feature request, or just feel like it:)

Run make help in the root of this repository to see the available make commands.

License

You're free to use, modify and distribute this software under the terms of the MIT or Apache-2.0 license, whichever has your preference.

Commit count: 150

cargo fmt