2019-01-05 22:44:33 +00:00
|
|
|
package auth
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
"os"
|
|
|
|
|
2024-12-17 00:01:55 +00:00
|
|
|
"github.com/gtsteffaniak/filebrowser/backend/errors"
|
2025-01-05 19:05:33 +00:00
|
|
|
"github.com/gtsteffaniak/filebrowser/backend/files"
|
2024-12-17 00:01:55 +00:00
|
|
|
"github.com/gtsteffaniak/filebrowser/backend/users"
|
2019-01-05 22:44:33 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// MethodProxyAuth is used to identify no auth.
|
2023-08-05 12:32:43 +00:00
|
|
|
const MethodProxyAuth = "proxy"
|
2019-01-05 22:44:33 +00:00
|
|
|
|
|
|
|
// ProxyAuth is a proxy implementation of an auther.
|
|
|
|
type ProxyAuth struct {
|
2019-01-08 08:57:24 +00:00
|
|
|
Header string `json:"header"`
|
2019-01-05 22:44:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Auth authenticates the user via an HTTP header.
|
2024-11-21 00:15:30 +00:00
|
|
|
func (a ProxyAuth) Auth(r *http.Request, usr *users.Storage) (*users.User, error) {
|
2019-01-05 22:44:33 +00:00
|
|
|
username := r.Header.Get(a.Header)
|
2025-01-05 19:05:33 +00:00
|
|
|
user, err := usr.Get(files.RootPaths["default"], username)
|
2019-01-05 22:44:33 +00:00
|
|
|
if err == errors.ErrNotExist {
|
|
|
|
return nil, os.ErrPermission
|
|
|
|
}
|
|
|
|
|
|
|
|
return user, err
|
|
|
|
}
|
2019-02-15 12:58:45 +00:00
|
|
|
|
|
|
|
// LoginPage tells that proxy auth doesn't require a login page.
|
|
|
|
func (a ProxyAuth) LoginPage() bool {
|
|
|
|
return false
|
|
|
|
}
|