You've already forked filebrowser
mirror of
https://github.com/filebrowser/filebrowser.git
synced 2025-11-26 14:25:26 +08:00
- In the root command, all flags are now correctly available as environmental variables, except for `--config` flag. This was already supposed to be the case, but due to bugs in the implementation it didn't work properly. - All configuration options (unless I missed something) that are available as flags should now properly update the configuration when using the `config init` and `config set` commands. - Flag names are now consistently in the lowerCamelCase format. All flags that were in a different format have been updated in a backwards compatible way. For a transitionary period of at least 6 months, both will work: - `--dir-mode` --> `--dirMode` - `--hide-login-button` --> `--hideLoginButton` - `--create-user-dir` --> `--createUserDir` - `--minimum-password-length` --> `--minimumPasswordLength` - `--socket-perm` --> `--socketPerm` - `--disable-thumbnails` --> `--disableThumbnails` - `--disable-preview-resize` --> `--disablePreviewResize` - `--disable-exec` --> `--disableExec` - `--disable-type-detection-by-header` --> `--disableTypeDetectionByHeader` - `--img-processors` --> `--imageProcessors` - `--cache-dir` --> `--cacheDir` - `--token-expiration-time` --> `--tokenExpirationTime` - `--baseurl` --> `--baseURL`
115 lines
2.3 KiB
Go
115 lines
2.3 KiB
Go
package cmd
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/spf13/cobra"
|
|
"github.com/spf13/pflag"
|
|
|
|
"github.com/filebrowser/filebrowser/v2/rules"
|
|
"github.com/filebrowser/filebrowser/v2/settings"
|
|
"github.com/filebrowser/filebrowser/v2/storage"
|
|
"github.com/filebrowser/filebrowser/v2/users"
|
|
)
|
|
|
|
func init() {
|
|
rootCmd.AddCommand(rulesCmd)
|
|
rulesCmd.PersistentFlags().StringP("username", "u", "", "username of user to which the rules apply")
|
|
rulesCmd.PersistentFlags().UintP("id", "i", 0, "id of user to which the rules apply")
|
|
}
|
|
|
|
var rulesCmd = &cobra.Command{
|
|
Use: "rules",
|
|
Short: "Rules management utility",
|
|
Long: `On each subcommand you'll have available at least two flags:
|
|
"username" and "id". You must either set only one of them
|
|
or none. If you set one of them, the command will apply to
|
|
an user, otherwise it will be applied to the global set or
|
|
rules.`,
|
|
Args: cobra.NoArgs,
|
|
}
|
|
|
|
func runRules(st *storage.Storage, cmd *cobra.Command, usersFn func(*users.User) error, globalFn func(*settings.Settings) error) error {
|
|
id, err := getUserIdentifier(cmd.Flags())
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if id != nil {
|
|
var user *users.User
|
|
user, err = st.Users.Get("", id)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if usersFn != nil {
|
|
err = usersFn(user)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
printRules(user.Rules, id)
|
|
return nil
|
|
}
|
|
|
|
s, err := st.Settings.Get()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if globalFn != nil {
|
|
err = globalFn(s)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
printRules(s.Rules, id)
|
|
return nil
|
|
}
|
|
|
|
func getUserIdentifier(flags *pflag.FlagSet) (interface{}, error) {
|
|
id, err := flags.GetUint("id")
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
username, err := flags.GetString("username")
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if id != 0 {
|
|
return id, nil
|
|
} else if username != "" {
|
|
return username, nil
|
|
}
|
|
|
|
return nil, nil
|
|
}
|
|
|
|
func printRules(rulez []rules.Rule, id interface{}) {
|
|
if id == nil {
|
|
fmt.Printf("Global Rules:\n\n")
|
|
} else {
|
|
fmt.Printf("Rules for user %v:\n\n", id)
|
|
}
|
|
|
|
for id, rule := range rulez {
|
|
fmt.Printf("(%d) ", id)
|
|
if rule.Regex {
|
|
if rule.Allow {
|
|
fmt.Printf("Allow Regex: \t%s\n", rule.Regexp.Raw)
|
|
} else {
|
|
fmt.Printf("Disallow Regex: \t%s\n", rule.Regexp.Raw)
|
|
}
|
|
} else {
|
|
if rule.Allow {
|
|
fmt.Printf("Allow Path: \t%s\n", rule.Path)
|
|
} else {
|
|
fmt.Printf("Disallow Path: \t%s\n", rule.Path)
|
|
}
|
|
}
|
|
}
|
|
}
|