118 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Go
		
	
	
			
		
		
	
	
			118 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Go
		
	
	
| package users
 | |
| 
 | |
| import (
 | |
| 	"github.com/filebrowser/filebrowser/v2/errors"
 | |
| 	"path/filepath"
 | |
| 	"regexp"
 | |
| 
 | |
| 	"github.com/filebrowser/filebrowser/v2/files"
 | |
| 	"github.com/filebrowser/filebrowser/v2/rules"
 | |
| 	"github.com/spf13/afero"
 | |
| )
 | |
| 
 | |
| // ViewMode describes a view mode.
 | |
| type ViewMode string
 | |
| 
 | |
| const (
 | |
| 	ListViewMode   ViewMode = "list"
 | |
| 	MosaicViewMode ViewMode = "mosaic"
 | |
| )
 | |
| 
 | |
| // User describes a user.
 | |
| type User struct {
 | |
| 	ID           uint          `storm:"id,increment" json:"id"`
 | |
| 	Username     string        `storm:"unique" json:"username"`
 | |
| 	Password     string        `json:"password"`
 | |
| 	Scope        string        `json:"scope"`
 | |
| 	Locale       string        `json:"locale"`
 | |
| 	LockPassword bool          `json:"lockPassword"`
 | |
| 	ViewMode     ViewMode      `json:"viewMode"`
 | |
| 	Perm         Permissions   `json:"perm"`
 | |
| 	Commands     []string      `json:"commands"`
 | |
| 	Sorting      files.Sorting `json:"sorting"`
 | |
| 	Fs           afero.Fs      `json:"-"`
 | |
| 	Rules        []rules.Rule  `json:"rules"`
 | |
| }
 | |
| 
 | |
| // GetRules implements rules.Provider.
 | |
| func (u *User) GetRules() []rules.Rule {
 | |
| 	return u.Rules
 | |
| }
 | |
| 
 | |
| var checkableFields = []string{
 | |
| 	"Username",
 | |
| 	"Password",
 | |
| 	"Scope",
 | |
| 	"ViewMode",
 | |
| 	"Commands",
 | |
| 	"Sorting",
 | |
| 	"Rules",
 | |
| }
 | |
| 
 | |
| // Clean cleans up a user and verifies if all its fields
 | |
| // are alright to be saved.
 | |
| func (u *User) Clean(fields ...string) error {
 | |
| 	if len(fields) == 0 {
 | |
| 		fields = checkableFields
 | |
| 	}
 | |
| 
 | |
| 	for _, field := range fields {
 | |
| 		switch field {
 | |
| 		case "Username":
 | |
| 			if u.Username == "" {
 | |
| 				return errors.ErrEmptyUsername
 | |
| 			}
 | |
| 		case "Password":
 | |
| 			if u.Password == "" {
 | |
| 				return errors.ErrEmptyPassword
 | |
| 			}
 | |
| 		case "Scope":
 | |
| 			if !filepath.IsAbs(u.Scope) {
 | |
| 				return errors.ErrScopeIsRelative
 | |
| 			}
 | |
| 		case "ViewMode":
 | |
| 			if u.ViewMode == "" {
 | |
| 				u.ViewMode = ListViewMode
 | |
| 			}
 | |
| 		case "Commands":
 | |
| 			if u.Commands == nil {
 | |
| 				u.Commands = []string{}
 | |
| 			}
 | |
| 		case "Sorting":
 | |
| 			if u.Sorting.By == "" {
 | |
| 				u.Sorting.By = "name"
 | |
| 			}
 | |
| 		case "Rules":
 | |
| 			if u.Rules == nil {
 | |
| 				u.Rules = []rules.Rule{}
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	if u.Fs == nil {
 | |
| 		u.Fs = afero.NewBasePathFs(afero.NewOsFs(), u.Scope)
 | |
| 	}
 | |
| 
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // FullPath gets the full path for a user's relative path.
 | |
| func (u *User) FullPath(path string) string {
 | |
| 	return afero.FullBaseFsPath(u.Fs.(*afero.BasePathFs), path)
 | |
| }
 | |
| 
 | |
| // CanExecute checks if an user can execute a specific command.
 | |
| func (u *User) CanExecute(command string) bool {
 | |
| 	if !u.Perm.Execute {
 | |
| 		return false
 | |
| 	}
 | |
| 
 | |
| 	for _, cmd := range u.Commands {
 | |
| 		if regexp.MustCompile(cmd).MatchString(command) {
 | |
| 			return true
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	return false
 | |
| }
 |