mirror of
				https://github.com/grafana/grafana.git
				synced 2025-02-25 18:55:37 -06:00 
			
		
		
		
	This fixes: pkg/cmd/grafana-cli/commands/install_command.go:36:11: should use fmt.Errorf(...) instead of errors.New(fmt.Sprintf(...)) (S1028) pkg/models/org_user.go:53:11: should use fmt.Errorf(...) instead of errors.New(fmt.Sprintf(...)) (S1028) pkg/services/notifications/mailer.go:138:16: should use fmt.Errorf(...) instead of errors.New(fmt.Sprintf(...)) (S1028)
		
			
				
	
	
		
			118 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			118 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package models
 | |
| 
 | |
| import (
 | |
| 	"encoding/json"
 | |
| 	"errors"
 | |
| 	"fmt"
 | |
| 	"time"
 | |
| )
 | |
| 
 | |
| // Typed errors
 | |
| var (
 | |
| 	ErrInvalidRoleType     = errors.New("Invalid role type")
 | |
| 	ErrLastOrgAdmin        = errors.New("Cannot remove last organization admin")
 | |
| 	ErrOrgUserNotFound     = errors.New("Cannot find the organization user")
 | |
| 	ErrOrgUserAlreadyAdded = errors.New("User is already added to organization")
 | |
| )
 | |
| 
 | |
| type RoleType string
 | |
| 
 | |
| const (
 | |
| 	ROLE_VIEWER RoleType = "Viewer"
 | |
| 	ROLE_EDITOR RoleType = "Editor"
 | |
| 	ROLE_ADMIN  RoleType = "Admin"
 | |
| )
 | |
| 
 | |
| func (r RoleType) IsValid() bool {
 | |
| 	return r == ROLE_VIEWER || r == ROLE_ADMIN || r == ROLE_EDITOR
 | |
| }
 | |
| 
 | |
| func (r RoleType) Includes(other RoleType) bool {
 | |
| 	if r == ROLE_ADMIN {
 | |
| 		return true
 | |
| 	}
 | |
| 
 | |
| 	if r == ROLE_EDITOR {
 | |
| 		return other != ROLE_ADMIN
 | |
| 	}
 | |
| 
 | |
| 	return false
 | |
| }
 | |
| 
 | |
| func (r *RoleType) UnmarshalJSON(data []byte) error {
 | |
| 	var str string
 | |
| 	err := json.Unmarshal(data, &str)
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	*r = RoleType(str)
 | |
| 
 | |
| 	if !(*r).IsValid() {
 | |
| 		if (*r) != "" {
 | |
| 			return fmt.Errorf("JSON validation error: invalid role value: %s", *r)
 | |
| 		}
 | |
| 
 | |
| 		*r = ROLE_VIEWER
 | |
| 	}
 | |
| 
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| type OrgUser struct {
 | |
| 	Id      int64
 | |
| 	OrgId   int64
 | |
| 	UserId  int64
 | |
| 	Role    RoleType
 | |
| 	Created time.Time
 | |
| 	Updated time.Time
 | |
| }
 | |
| 
 | |
| // ---------------------
 | |
| // COMMANDS
 | |
| 
 | |
| type RemoveOrgUserCommand struct {
 | |
| 	UserId int64
 | |
| 	OrgId  int64
 | |
| }
 | |
| 
 | |
| type AddOrgUserCommand struct {
 | |
| 	LoginOrEmail string   `json:"loginOrEmail" binding:"Required"`
 | |
| 	Role         RoleType `json:"role" binding:"Required"`
 | |
| 
 | |
| 	OrgId  int64 `json:"-"`
 | |
| 	UserId int64 `json:"-"`
 | |
| }
 | |
| 
 | |
| type UpdateOrgUserCommand struct {
 | |
| 	Role RoleType `json:"role" binding:"Required"`
 | |
| 
 | |
| 	OrgId  int64 `json:"-"`
 | |
| 	UserId int64 `json:"-"`
 | |
| }
 | |
| 
 | |
| // ----------------------
 | |
| // QUERIES
 | |
| 
 | |
| type GetOrgUsersQuery struct {
 | |
| 	OrgId int64
 | |
| 	Query string
 | |
| 	Limit int
 | |
| 
 | |
| 	Result []*OrgUserDTO
 | |
| }
 | |
| 
 | |
| // ----------------------
 | |
| // Projections and DTOs
 | |
| 
 | |
| type OrgUserDTO struct {
 | |
| 	OrgId         int64     `json:"orgId"`
 | |
| 	UserId        int64     `json:"userId"`
 | |
| 	Email         string    `json:"email"`
 | |
| 	AvatarUrl     string    `json:"avatarUrl"`
 | |
| 	Login         string    `json:"login"`
 | |
| 	Role          string    `json:"role"`
 | |
| 	LastSeenAt    time.Time `json:"lastSeenAt"`
 | |
| 	LastSeenAtAge string    `json:"lastSeenAtAge"`
 | |
| }
 |