Documentation
¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
var ( // ErrGeneric is used for testing purposes and for errors handled later in the callstack ErrGeneric = errors.New("generic error") // ErrBadRequest (400) is returned for bad request (validation) ErrBadRequest = echo.NewHTTPError(400) ErrUnauthorized = echo.ErrUnauthorized )
Functions ¶
This section is empty.
Types ¶
type AccessRole ¶
type AccessRole int
AccessRole represents access role type
const ( // SuperAdminRole has all permissions SuperAdminRole AccessRole = 100 // AdminRole has admin specific permissions AdminRole AccessRole = 110 // CompanyAdminRole can edit company specific things CompanyAdminRole AccessRole = 120 // LocationAdminRole can edit location specific things LocationAdminRole AccessRole = 130 // UserRole is a standard user UserRole AccessRole = 200 )
type AuthUser ¶
type AuthUser struct {
ID int
CompanyID int
LocationID int
Username string
Email string
Role AccessRole
}
AuthUser represents data stored in JWT token for user
type Base ¶
type Base struct {
ID int `json:"id"`
CreatedAt time.Time `json:"created_at"`
UpdatedAt time.Time `json:"updated_at"`
DeletedAt time.Time `json:"deleted_at,omitempty" pg:",soft_delete"`
}
Base contains common fields for all tables
func (*Base) BeforeInsert ¶
BeforeInsert hooks into insert operations, setting createdAt and updatedAt to current time
type Company ¶
type Company struct {
Base
Name string `json:"name"`
Active bool `json:"active"`
Locations []Location `json:"locations,omitempty"`
Owner User `json:"owner"`
}
Company represents company model
type Location ¶
type Location struct {
Base
Name string `json:"name"`
Active bool `json:"active"`
Address string `json:"address"`
CompanyID int `json:"company_id"`
}
Location represents company location model
type Logger ¶
type Logger interface {
// source, msg, error, params
Log(echo.Context, string, string, error, map[string]interface{})
}
Logger represents logging interface
type Pagination ¶
Pagination data
type PaginationReq ¶
PaginationReq holds pagination http fields and tags
func (PaginationReq) Transform ¶
func (p PaginationReq) Transform() Pagination
Transform checks and converts http pagination into database pagination model
type RBACService ¶
type RBACService interface {
User(echo.Context) AuthUser
EnforceRole(echo.Context, AccessRole) error
EnforceUser(echo.Context, int) error
EnforceCompany(echo.Context, int) error
EnforceLocation(echo.Context, int) error
AccountCreate(echo.Context, AccessRole, int, int) error
IsLowerRole(echo.Context, AccessRole) error
}
RBACService represents role-based access control service interface
type RefreshToken ¶
type RefreshToken struct {
Token string `json:"token"`
}
RefreshToken holds authentication token details
type Role ¶
type Role struct {
ID AccessRole `json:"id"`
AccessLevel AccessRole `json:"access_level"`
Name string `json:"name"`
}
Role model
type User ¶
type User struct {
Base
FirstName string `json:"first_name"`
LastName string `json:"last_name"`
Username string `json:"username"`
Password string `json:"-"`
Email string `json:"email"`
Mobile string `json:"mobile,omitempty"`
Phone string `json:"phone,omitempty"`
Address string `json:"address,omitempty"`
Active bool `json:"active"`
LastLogin time.Time `json:"last_login,omitempty"`
LastPasswordChange time.Time `json:"last_password_change,omitempty"`
Token string `json:"-"`
Role *Role `json:"role,omitempty"`
RoleID AccessRole `json:"-"`
CompanyID int `json:"company_id"`
LocationID int `json:"location_id"`
}
User represents user domain model
func (*User) ChangePassword ¶
ChangePassword updates user's password related fields
func (*User) UpdateLastLogin ¶
UpdateLastLogin updates last login field