mirror of
https://github.com/filebrowser/filebrowser.git
synced 2025-05-08 11:22:10 +00:00

Former-commit-id: 0d8742754bb756ad3a83599850dae5f477282430 [formerly 5cb7d75b695d8400fc2af87edd551d6450e7365f] [formerly a6a814c40a5ff4f195c4ab470d4fccc92bd8c1c8 [formerly 99c8c92c6c6d1225380dbbfc5b61d4263a129156]] Former-commit-id: 45eba5ff05f8e64fbf33d9d670e19a0cf4880656 [formerly 88dc856045b9d51596f36ce387b1c4f3e85a7d3c] Former-commit-id: 1eadaef460060da8ae71df3c66f242c844992725
74 lines
2.3 KiB
Go
74 lines
2.3 KiB
Go
/*
|
|
Package filemanager provides a web interface to access your files
|
|
wherever you are. To use this package as a middleware for your app,
|
|
you'll need to import both File Manager and File Manager HTTP packages.
|
|
|
|
import (
|
|
fm "github.com/hacdias/filemanager"
|
|
h "github.com/hacdias/filemanager/http"
|
|
)
|
|
|
|
Then, you should create a new FileManager object with your options. In this
|
|
case, I'm using BoltDB (via Storm package) as a Store. So, you'll also need
|
|
to import "github.com/hacdias/filemanager/bolt".
|
|
|
|
db, _ := storm.Open("bolt.db")
|
|
|
|
m := &fm.FileManager{
|
|
NoAuth: false,
|
|
DefaultUser: &fm.User{
|
|
AllowCommands: true,
|
|
AllowEdit: true,
|
|
AllowNew: true,
|
|
AllowPublish: true,
|
|
Commands: []string{"git"},
|
|
Rules: []*fm.Rule{},
|
|
Locale: "en",
|
|
CSS: "",
|
|
Scope: ".",
|
|
FileSystem: fileutils.Dir("."),
|
|
},
|
|
Store: &fm.Store{
|
|
Config: bolt.ConfigStore{DB: db},
|
|
Users: bolt.UsersStore{DB: db},
|
|
Share: bolt.ShareStore{DB: db},
|
|
},
|
|
NewFS: func(scope string) fm.FileSystem {
|
|
return fileutils.Dir(scope)
|
|
},
|
|
}
|
|
|
|
The credentials for the first user are always 'admin' for both the user and
|
|
the password, and they can be changed later through the settings. The first
|
|
user is always an Admin and has all of the permissions set to 'true'.
|
|
|
|
Then, you should set the Prefix URL and the Base URL, using the following
|
|
functions:
|
|
|
|
m.SetBaseURL("/")
|
|
m.SetPrefixURL("/")
|
|
|
|
The Prefix URL is a part of the path that is already stripped from the
|
|
r.URL.Path variable before the request arrives to File Manager's handler.
|
|
This is a function that will rarely be used. You can see one example on Caddy
|
|
filemanager plugin.
|
|
|
|
The Base URL is the URL path where you want File Manager to be available in. If
|
|
you want to be available at the root path, you should call:
|
|
|
|
m.SetBaseURL("/")
|
|
|
|
But if you want to access it at '/admin', you would call:
|
|
|
|
m.SetBaseURL("/admin")
|
|
|
|
Now, that you already have a File Manager instance created, you just need to
|
|
add it to your handlers using m.ServeHTTP which is compatible to http.Handler.
|
|
We also have a m.ServeWithErrorsHTTP that returns the status code and an error.
|
|
|
|
One simple implementation for this, at port 80, in the root of the domain, would be:
|
|
|
|
http.ListenAndServe(":80", h.Handler(m))
|
|
*/
|
|
package filemanager
|