Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/pluveto/flydav

Setup a tiny webdav server in 30 seconds. Multi-user, path prefix etc. 轻量高效的 WebDav 服务器。
https://github.com/pluveto/flydav

filesystem go http webdav

Last synced: 2 days ago
JSON representation

Setup a tiny webdav server in 30 seconds. Multi-user, path prefix etc. 轻量高效的 WebDav 服务器。

Awesome Lists containing this project

README

        

# Flydav

Documents in other languages: [中文文档](docs/README.zh-CN.md)

FlyDav is an lightweight and open source webdav server that offers some core features to meet the needs of both individual users and organizations.

With its tiny file size, FlyDav is the ideal solution for users who require a fast and efficient webdav server. It offers basic authentication, supports multiple users and allows each user to have a different root directory and path prefix which are extremely well isolated. In addition, FlyDav provides logging rotation and password security, making it the perfect choice for users who require a secure and reliable webdav solution.

The goal of FlyDav is to keep things easy and simple, with users able to deploy the service in no time. Therefore any extraneous features are not added, thus avoiding bloat.

## One-Run install

**WARN** Only tested for AMD64 Linux with systemd. Enhancement PR is welcomed.

Run:

```bash
curl -sL "https://raw.githubusercontent.com/pluveto/flydav/main/scripts/installer.sh" -o /tmp/flydav-installer.sh
sudo chmod +x /tmp/flydav-installer.sh
sudo bash /tmp/flydav-installer.sh
```

And interactive to configure the service.

Finally remove tmp file.

```bash
sudo rm -f /tmp/flydav-installer.sh
```

## Get started in 30 seconds

1. Start by downloading FlyDav from their website at [release page](https://github.com/pluveto/flydav/releases).
2. Run `./flydav -H 0.0.0.0` to start the server. Then you'll input the password for the default user `flydav`.
3. Open `http://YOUR_IP:7086/webdav` in your webdav client such as RaiDrive.

## FlyDav UI

We provided a simple web page client, which supports browsing and downloading files.

![image-20230207233418753](https://raw.githubusercontent.com/pluveto/0images/master/2023/02/upgit_20230207_1675784061.png)

## Command line options

```bash
$ flydav -h
--------------------------------------------------------------------------------
Usage: flydav [--host HOST] [--port PORT] [--user USER] [--verbose] [--config CONFIG] [--with-ui] [--help] [--version]

Options:
--host HOST, -H HOST host address
--port PORT, -p PORT port
--user USER, -u USER username
--verbose, -v verbose output
--with-ui enable web ui
--config CONFIG, -c CONFIG
config file
--help, -h display this help and exit
```

If you have a config file, you can ignore the command line options. Run `flydav -c /path/to/config.toml` to start the server.

If you want to quickly start the server with host, port, username and a one-time password, you can run `flydav -H IP -p PORT -u USERNAME` to start the server. Then you'll input the password for the user. And the server will serve at `http://IP:PORT/`.

## Configuring FlyDav

1. Start by downloading FlyDav from their website at [release page](https://github.com/pluveto/flydav/releases).
2. Now that you have the software, you need to create a configuration file for it. Start by creating a new file called `flydav.toml`.
3. Inside the configuration file, you will need to add the following information:
- `[server]`: This section will define the host, port, and path of the webdav server.
- `host`: The IP address of the host. This should be set to “0.0.0.0” if you want to make the server accessible from any IP address.
- `port`: The port number to use for the webdav server.
- `path`: The path of the webdav server.
- `fs_dir`: The directory on the server where the webdav files will be stored.
- `[auth]`: This section will define the authentication settings for the webdav server.
- `[[auth.user]]`: This subsection will define the username and credentials for each user that has access to the webdav server.
- `username`: The username of the user.
- `sub_fs_dir`: The subdirectory of the fs_dir to which the user will have access.
- `sub_path`: The path that the user will access the webdav server from.
- `password_hash`: The hashed password of the user.
- `password_crypt`: The type of hashing algorithm used to hash the password. This should be set to “bcrypt” or “sha256”.
- `[log]`: This section will define the logging settings for the webdav server.
- `level`: The log level of the server. This can be set to “debug”, “info”, “warn”, “error”, or “fatal”.
- `[[log.file]]`: This subsection will define the settings for the log file. Ignore this subsection if you do not want to log to a file.
- `format`: The format of the log file. This can be set to “json” or “text”.
- `path`: The path of the log file.
- `max_size`: The maximum size of the log file in megabytes.
- `max_age`: The maximum age of the log file in days.
- `[[log.stdout]]`: This subsection will define the settings for the log output to the console. Ignore this subsection if you do not want to log to the console.
- `format`: The format of the log output. This can be set to “json” or “text”.
- `output`: The output stream for the log output. This can be set to “stdout” or “stderr”.
4. Save the configuration file and run the FlyDav server. You should now be able to access the webdav server with the configured settings.

To get a example configuration file, go to [conf dir](https://github.com/pluveto/flydav/blob/main/conf).

## Install as a service

### Install as a service on Linux

1. Create a new file called `flydav.service` in `/etc/systemd/system/` and add the following information:

File `/etc/systemd/system/flydav.service`

```ini
[Unit]
Description = Flydav Server
After = network.target syslog.target
Wants = network.target

[Service]
Type = simple
# !!! Change the binary location and config path to your own !!!
ExecStart = /usr/local/bin/flydav -c /etc/flydav/flydav.toml

[Install]
WantedBy = multi-user.target
```

2 Run `systemctl daemon-reload` to reload the systemd daemon.
3 Run `systemctl enable flydav` to enable the service.
4 Run `systemctl start flydav` to start the service.

### Manage the service

- Run `systemctl status flydav` to check the status of the service.
- Run `systemctl stop flydav` to stop the service.

## Features

- [x] Basic authentication
- [x] Multiple users
- [x] Different root directory for each user
- [x] Different path prefix for each user
- [x] Logging
- [ ] SSL
- Work in progress
- You can use a reverse proxy like Nginx to enable SSL.

## Setup on your OS

### Ubuntu

Simply add a new location as follow:

![image](https://github.com/pluveto/flydav/assets/50045289/bcd02371-5baf-45a8-ad84-702bfc29d971)

## License

This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details