mirror of
				https://github.com/filebrowser/filebrowser.git
				synced 2025-10-25 14:24:32 +00:00 
			
		
		
		
	 870b5b4079
			
		
	
	
		870b5b4079
		
	
	
	
	
		
			
			License: MIT Signed-off-by: Henrique Dias <hacdias@gmail.com> Former-commit-id: bb60ec81f56f5d761ef76b2c1e26bbe83210f434 [formerly b28f83c65e0934e138a1710549f52e0f66a158e0] [formerly 7138a3215ceb144afa0ea45be2315f30b052109f [formerly 72069207c6bb0664c7b270096f6916cce76ebeb1]] Former-commit-id: 0fb7ae6353f786edd93a9166141bfa446dd3dbf9 [formerly 5cb07e8c96a7cfca1aec5843123e1abc4ca8578a] Former-commit-id: 914c0348516f072a9ccce4e105327feaaddb4cc0
		
			
				
	
	
		
			92 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package cmd
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 
 | |
| 	"github.com/filebrowser/filebrowser/v2/rules"
 | |
| 	"github.com/filebrowser/filebrowser/v2/settings"
 | |
| 	"github.com/filebrowser/filebrowser/v2/storage"
 | |
| 	"github.com/filebrowser/filebrowser/v2/users"
 | |
| 	"github.com/spf13/cobra"
 | |
| 	"github.com/spf13/pflag"
 | |
| )
 | |
| 
 | |
| 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, users func(*users.User), global func(*settings.Settings)) {
 | |
| 	id := getUserIdentifier(cmd.Flags())
 | |
| 	if id != nil {
 | |
| 		user, err := st.Users.Get("", id)
 | |
| 		checkErr(err)
 | |
| 
 | |
| 		if users != nil {
 | |
| 			users(user)
 | |
| 		}
 | |
| 
 | |
| 		printRules(user.Rules, id)
 | |
| 		return
 | |
| 	}
 | |
| 
 | |
| 	settings, err := st.Settings.Get()
 | |
| 	checkErr(err)
 | |
| 
 | |
| 	if global != nil {
 | |
| 		global(settings)
 | |
| 	}
 | |
| 
 | |
| 	printRules(settings.Rules, id)
 | |
| }
 | |
| 
 | |
| func getUserIdentifier(flags *pflag.FlagSet) interface{} {
 | |
| 	id := mustGetUint(flags, "id")
 | |
| 	username := mustGetString(flags, "username")
 | |
| 
 | |
| 	if id != 0 {
 | |
| 		return id
 | |
| 	} else if username != "" {
 | |
| 		return username
 | |
| 	}
 | |
| 
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| func printRules(rules []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 rules {
 | |
| 		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)
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| }
 |