From 465b10a02aef310ad05d1484a860db78f998625d Mon Sep 17 00:00:00 2001 From: Henrique Dias Date: Mon, 10 Jul 2017 15:49:18 +0100 Subject: [PATCH] update readme --- caddy/filemanager/README_NEW.md | 10 +++++----- caddy/filemanager/filemanager.go | 26 ++++++++++++++++++-------- 2 files changed, 23 insertions(+), 13 deletions(-) diff --git a/caddy/filemanager/README_NEW.md b/caddy/filemanager/README_NEW.md index 1e22bd67..49b23667 100644 --- a/caddy/filemanager/README_NEW.md +++ b/caddy/filemanager/README_NEW.md @@ -8,7 +8,7 @@ Note that if you are handling large files you might run into troubles due to the To start using this plugin you just need to go to the [download Caddy page](https://caddyserver.com/download) and choose `filemanager` in the directives section. For further information on how Caddy works refer to [its documentation](https://caddyserver.com/docs). -The default credentials are `admin` for the user and the password. It is highy recommended to change this after logging in for the first time and to use HTTPS. In the web interface, you can create more users and define their own permissions. +The default credentials are `admin` for both the user and the password. It is highy recommended to change them after logging in for the first time and to use HTTPS. You can create more users and define their own permissions using the web interface. ## Syntax @@ -18,11 +18,11 @@ filemanager [baseurl] [scope] { } ``` -All of the options above are optional. +`baseurl` is the URL path where you will access File Manager. Defaults to `/`. -+ **baseurl** is the URL where you will access the File Manager interface. Defaults to `/`. -+ **scope** is the path, relative or absolute, to the directory you want to browse in. Defaults to `./`. -+ **path** is the database path where the settings that aren't included in the Caddyfile will be stored. By default, the database will be stored on `.caddy` folder and its name will be an hashed combination of the host and the `baseurl`. It is **highly** recommended to set this option. Otherwise, whenever you change the host or the `baseurl`, your settings will be lost or you will need to point to the previous database. +`scope` is the path, relative or absolute, to the directory you want to browse in. This value will be used for the creation of the first user. Defaults to `./`. + +`path` is the database path where the settings will be stored. By default, the database will be stored on `.caddy/filemanager` folder and its name will be an hashed combination of the host and the `baseurl`. If you use a relative path it will be relative to `.caddy/filemanager`. Despite being optional, it is **highly** recommended to set this option in order to keep the settings when you change the `baseurl` and/or the hostname. ## Examples diff --git a/caddy/filemanager/filemanager.go b/caddy/filemanager/filemanager.go index e14b179f..c7b686e4 100644 --- a/caddy/filemanager/filemanager.go +++ b/caddy/filemanager/filemanager.go @@ -4,8 +4,9 @@ package filemanager import ( - "crypto/sha256" + "crypto/md5" "encoding/hex" + "fmt" "net/http" "os" "path/filepath" @@ -97,22 +98,31 @@ func parse(c *caddy.Controller) ([]*config, error) { caddyConf := httpserver.GetConfig(c) + path := filepath.Join(caddy.AssetsPath(), "filemanager") + err := os.MkdirAll(path, 0700) + if err != nil { + return nil, err + } + + // if there is a database path and it is not absolute, + // it will be relative to Caddy folder. + if !filepath.IsAbs(database) && database != "" { + database = filepath.Join(path, database) + } + // If there is no database path on the settings, // store one in .caddy/filemanager/name.db. if database == "" { - path := filepath.Join(caddy.AssetsPath(), "filemanager") - err := os.MkdirAll(path, 0700) - if err != nil { - return nil, err - } - // The name of the database is the hashed value of a string composed // by the host, address path and the baseurl of this File Manager // instance. - hasher := sha256.New() + hasher := md5.New() hasher.Write([]byte(caddyConf.Addr.Host + caddyConf.Addr.Path + baseURL)) sha := hex.EncodeToString(hasher.Sum(nil)) database = filepath.Join(path, sha+".db") + + fmt.Println("[WARNING] A database is going to be created for your File Manager instace at " + database + + ". It is highly recommended that you set the 'database' option to '" + sha + ".db'\n") } fm, err := New(database, User{