Add error logging, config and documentation
This commit is contained in:
parent
aed126482d
commit
9e3a7978a7
4 changed files with 43 additions and 29 deletions
55
Readme.md
55
Readme.md
|
@ -32,7 +32,9 @@ It perfectly fits if you would like to give some people the possibility to uploa
|
|||
|
||||
## Configuration
|
||||
|
||||
The configuration is done in form of a yaml file. _swd_ will scan the following locations for the presence of a `config.yaml` in the following order:
|
||||
The configuration is done in form of a yaml file. _swd_ will scan the
|
||||
following locations for the presence of a `config.yaml` in the following
|
||||
order:
|
||||
|
||||
- The directory `./config`
|
||||
- The directory `$HOME/.swd`
|
||||
|
@ -45,6 +47,7 @@ Here an example of a very simple but functional configuration:
|
|||
address: "127.0.0.1" # the bind address
|
||||
port: "8000" # the listening port
|
||||
dir: "/home/webdav" # the provided base dir
|
||||
prefix: "/webdav" # the url-prefix of the original url
|
||||
users:
|
||||
user: # with password 'foo' and jailed access to '/home/webdav/user'
|
||||
password: "$2a$10$yITzSSNJZAdDZs8iVBQzkuZCzZ49PyjTiPIrmBUKUpB0pwX7eySvW"
|
||||
|
@ -52,10 +55,13 @@ Here an example of a very simple but functional configuration:
|
|||
admin: # with password 'foo' and access to '/home/webdav'
|
||||
password: "$2a$10$DaWhagZaxWnWAOXY0a55.eaYccgtMOL3lGlqI3spqIBGyM0MD.EN6"
|
||||
|
||||
With this configuration you'll grant access for two users and the webdav
|
||||
server is available under `http://127.0.0.1:8000/webdav`.
|
||||
|
||||
### TLS
|
||||
|
||||
At first, use your favorite toolchain to obtain a SSL certificate and keyfile (if you don't already have some).
|
||||
At first, use your favorite toolchain to obtain a SSL certificate and
|
||||
keyfile (if you don't already have some).
|
||||
|
||||
Here an example with `openssl`:
|
||||
|
||||
|
@ -75,21 +81,21 @@ Now you can reference your keypair in the configuration via:
|
|||
users:
|
||||
...
|
||||
|
||||
The presence of the `tls` section is completely enough to let the server start with a TLS secured https connection.
|
||||
The presence of the `tls` section is completely enough to let the server
|
||||
start with a TLS secured https connection.
|
||||
|
||||
In the current release version you must take care, that the private key doesn't need a passphrase. Otherwise starting the server will fail.
|
||||
In the current release version you must take care, that the private key
|
||||
doesn't need a passphrase. Otherwise starting the server will fail.
|
||||
|
||||
### Behind a proxy
|
||||
|
||||
If you'd like to move your setup behind a proxy / gateway under a specific path, you can set the config variable `prefix` to match the url-prefix of your proxy configuration.
|
||||
_swd_ will also work behind a reverse proxy. Here is an example
|
||||
configuration with `apache2 httpd`'s `mod_proxy`:
|
||||
|
||||
For example: If you have a rule that proxies all requests of `https://domain.com/webdav` to `https://localhost:8000`, you have to set the prefix to `/webdav`.
|
||||
|
||||
address: "127.0.0.1" # the bind address
|
||||
port: "8000" # the listening port
|
||||
prefix: "/webdav" # the url-prefix of the original url
|
||||
dir: "/home/webdav" # the provided base directory
|
||||
...
|
||||
<Location /webdav>
|
||||
ProxyPass https://webdav-host:8000/
|
||||
ProxyPassReverse https://webdav-host:8000/
|
||||
</Location>
|
||||
|
||||
### User management
|
||||
|
||||
|
@ -108,17 +114,22 @@ You can enable / disable logging for the following operations:
|
|||
- **U**pdating of files or directories
|
||||
- **D**eletion of files or directories
|
||||
|
||||
All logs are disabled per default until you will turn it on via the following config entries:
|
||||
You can also enable or disable the error log.
|
||||
|
||||
address: "127.0.0.1" # the bind address
|
||||
port: "8000" # the listening port
|
||||
dir: "/home/webdav" # the provided base directory
|
||||
log:
|
||||
create: true
|
||||
read: true
|
||||
update: true
|
||||
delete: true
|
||||
...
|
||||
All file-operation logs are disabled per default until you will turn it on via the following config entries:
|
||||
|
||||
```yaml
|
||||
address: "127.0.0.1" # the bind address
|
||||
port: "8000" # the listening port
|
||||
dir: "/home/webdav" # the provided base directory
|
||||
log:
|
||||
error: true
|
||||
create: true
|
||||
read: true
|
||||
update: true
|
||||
delete: true
|
||||
...
|
||||
```
|
||||
|
||||
Be aware, that the log pattern of an attached tty differs from the log pattern of a detached tty.
|
||||
|
||||
|
|
|
@ -22,6 +22,7 @@ type Config struct {
|
|||
|
||||
// Logging allows definition for logging each CRUD method.
|
||||
type Logging struct {
|
||||
Error bool
|
||||
Create bool
|
||||
Read bool
|
||||
Update bool
|
||||
|
@ -84,6 +85,7 @@ func setDefaults() {
|
|||
viper.SetDefault("Prefix", "")
|
||||
viper.SetDefault("Dir", "/tmp")
|
||||
viper.SetDefault("TLS", nil)
|
||||
viper.SetDefault("Log.Error", true)
|
||||
viper.SetDefault("Log.Create", false)
|
||||
viper.SetDefault("Log.Read", false)
|
||||
viper.SetDefault("Log.Update", false)
|
||||
|
|
|
@ -20,7 +20,7 @@ func main() {
|
|||
},
|
||||
LockSystem: webdav.NewMemLS(),
|
||||
Logger: func(request *http.Request, err error) {
|
||||
if err != nil {
|
||||
if config.Log.Error && err != nil {
|
||||
log.Error(err)
|
||||
}
|
||||
},
|
||||
|
|
|
@ -48,10 +48,11 @@ users:
|
|||
# ---------------------------------- Logging -----------------------------------
|
||||
#
|
||||
# Seperated loglevels for file / directory operations. All set to false per
|
||||
# default.
|
||||
# default instead of error log. The error log is set to true per default.
|
||||
#
|
||||
#log:
|
||||
# create: true
|
||||
# read: true
|
||||
# update: true
|
||||
# delete: true
|
||||
# error: true
|
||||
# create: false
|
||||
# read: false
|
||||
# update: false
|
||||
# delete: falst
|
||||
|
|
Loading…
Reference in a new issue