filebrowser/backend/users/rules.go

65 lines
1.2 KiB
Go
Raw Normal View History

2024-11-21 00:15:30 +00:00
package users
import (
2020-11-20 10:51:28 +00:00
"path/filepath"
"regexp"
"strings"
)
// Checker is a Rules checker.
type Checker interface {
Check(path string) bool
}
2024-11-21 00:15:30 +00:00
// Check implements rules.Checker.
func (user *User) Check(path string) bool {
allow := true
for _, rule := range user.Rules {
if rule.Matches(path) {
allow = rule.Allow
}
}
return allow
}
// Rule is a allow/disallow rule.
type Rule struct {
Regex bool `json:"regex"`
Allow bool `json:"allow"`
Path string `json:"path"`
Regexp *Regexp `json:"regexp"`
2024-02-10 00:13:02 +00:00
Id string `json:"id"`
}
2020-11-20 10:51:28 +00:00
// MatchHidden matches paths with a basename
// that begins with a dot.
func MatchHidden(path string) bool {
2021-03-18 18:24:24 +00:00
return path != "" && strings.HasPrefix(filepath.Base(path), ".")
2020-11-20 10:51:28 +00:00
}
// Matches matches a path against a rule.
func (r *Rule) Matches(path string) bool {
if r.Regex {
return r.Regexp.MatchString(path)
}
return strings.HasPrefix(path, r.Path)
}
// Regexp is a wrapper to the native regexp type where we
// save the raw expression.
type Regexp struct {
Raw string `json:"raw"`
regexp *regexp.Regexp
}
// MatchString checks if a string matches the regexp.
func (r *Regexp) MatchString(s string) bool {
if r.regexp == nil {
r.regexp = regexp.MustCompile(r.Raw)
}
return r.regexp.MatchString(s)
}