2022-01-23 05:02:16 +00:00
|
|
|
package auth
|
|
|
|
|
|
|
|
import "errors"
|
|
|
|
|
2022-01-23 05:54:18 +00:00
|
|
|
// Auther is a generic interface to implement password-based authentication and authorization
|
|
|
|
type Auther interface {
|
2022-01-23 05:02:16 +00:00
|
|
|
Authenticate(user, pass string) (*User, error)
|
|
|
|
Authorize(user *User, topic string, perm Permission) error
|
|
|
|
}
|
|
|
|
|
2022-01-23 05:54:18 +00:00
|
|
|
type Manager interface {
|
|
|
|
AddUser(username, password string, role Role) error
|
|
|
|
RemoveUser(username string) error
|
|
|
|
ChangePassword(username, password string) error
|
2022-01-23 20:30:30 +00:00
|
|
|
ChangeRole(username string, role Role) error
|
|
|
|
AllowAccess(username string, topic string, read bool, write bool) error
|
|
|
|
ResetAccess(username string, topic string) error
|
2022-01-23 05:54:18 +00:00
|
|
|
}
|
|
|
|
|
2022-01-23 05:02:16 +00:00
|
|
|
type User struct {
|
|
|
|
Name string
|
|
|
|
Role Role
|
|
|
|
}
|
|
|
|
|
|
|
|
type Permission int
|
|
|
|
|
|
|
|
const (
|
|
|
|
PermissionRead = Permission(1)
|
|
|
|
PermissionWrite = Permission(2)
|
|
|
|
)
|
|
|
|
|
|
|
|
type Role string
|
|
|
|
|
|
|
|
const (
|
|
|
|
RoleAdmin = Role("admin")
|
|
|
|
RoleUser = Role("user")
|
|
|
|
RoleNone = Role("none")
|
|
|
|
)
|
|
|
|
|
|
|
|
var Everyone = &User{
|
|
|
|
Name: "",
|
|
|
|
Role: RoleNone,
|
|
|
|
}
|
|
|
|
|
2022-01-23 20:30:30 +00:00
|
|
|
var Roles = []Role{
|
|
|
|
RoleAdmin,
|
|
|
|
RoleUser,
|
|
|
|
RoleNone,
|
|
|
|
}
|
|
|
|
|
|
|
|
func AllowedRole(role Role) bool {
|
|
|
|
return role == RoleUser || role == RoleAdmin
|
|
|
|
}
|
|
|
|
|
2022-01-23 05:02:16 +00:00
|
|
|
var ErrUnauthorized = errors.New("unauthorized")
|