console/modules/security/realm/authc/native/role.go

77 lines
1.6 KiB
Go

/* Copyright © INFINI Ltd. All rights reserved.
* web: https://infinilabs.com
* mail: hello#infini.ltd */
package native
import (
"fmt"
rbac "infini.sh/console/core/security"
"infini.sh/framework/core/orm"
"infini.sh/framework/core/util"
"strings"
)
type Role struct {
}
func (dal *Role) Get(id string) (rbac.Role, error) {
r, ok := rbac.BuiltinRoles[id]
if ok {
return r, nil
}
role := rbac.Role{}
role.ID = id
_, err := orm.Get(&role)
return role, err
}
func (dal *Role) GetBy(field string, value interface{}) (rbac.Role, error) {
role := rbac.Role{}
err, result := orm.GetBy(field, value, &role)
if result.Total > 0 {
if len(result.Result) > 0 {
bytes := util.MustToJSONBytes(result.Result[0])
err := util.FromJSONBytes(bytes, &role)
if err != nil {
panic(err)
}
return role, nil
}
}
return role, err
}
func (dal *Role) Update(role *rbac.Role) error {
return orm.Save(nil, role)
}
func (dal *Role) Create(role *rbac.Role) (string, error) {
role.ID = util.GetUUID()
return role.ID, orm.Save(nil, role)
}
func (dal *Role) Delete(id string) error {
role := rbac.Role{}
role.ID = id
return orm.Delete(nil, role)
}
func (dal *Role) Search(keyword string, from, size int) (orm.Result, error) {
query := orm.Query{}
queryDSL := `{"query":{"bool":{"must":[%s]}}, "from": %d,"size": %d}`
mustBuilder := &strings.Builder{}
if keyword != "" {
mustBuilder.WriteString(fmt.Sprintf(`{"query_string":{"default_field":"*","query": "%s"}}`, keyword))
}
queryDSL = fmt.Sprintf(queryDSL, mustBuilder.String(), from, size)
query.RawQuery = []byte(queryDSL)
err, result := orm.Search(rbac.Role{}, &query)
return result, err
}