You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
OneAuth/api/role/role.go

125 lines
2.7 KiB
Go

3 years ago
package role
import (
"errors"
"github.com/veypi/OneAuth/cfg"
"github.com/veypi/OneAuth/libs/auth"
"github.com/veypi/OneAuth/libs/base"
"github.com/veypi/OneAuth/libs/oerr"
"github.com/veypi/OneAuth/models"
3 years ago
"github.com/veypi/OneBD"
"github.com/veypi/utils/log"
3 years ago
"gorm.io/gorm"
)
var roleP = OneBD.NewHandlerPool(func() OneBD.Handler {
return &roleHandler{}
})
type roleHandler struct {
base.AppHandler
3 years ago
}
func (h *roleHandler) Get() (interface{}, error) {
id := h.Meta().ParamsInt("id")
if !h.GetAuth(auth.Role, h.UUID).CanRead() {
return nil, oerr.NoAuth
}
3 years ago
if id > 0 {
role := &models.Role{}
role.AppUUID = h.UUID
3 years ago
role.ID = uint(id)
err := cfg.DB().Preload("Auths").Preload("Users").First(role).Error
if err != nil {
return nil, err
}
return role, nil
}
roles := make([]*models.Role, 0, 10)
err := cfg.DB().Where("AppUUID = ?", h.UUID).Find(&roles).Error
3 years ago
return roles, err
}
func (h *roleHandler) Post() (interface{}, error) {
if !h.GetAuth(auth.Role).CanCreate() {
3 years ago
return nil, oerr.NoAuth
}
role := &models.Role{
AppUUID: h.UUID,
}
3 years ago
err := h.Meta().ReadJson(role)
if err != nil {
return nil, err
}
role.ID = 0
if role.Name == "" {
3 years ago
return nil, oerr.ApiArgsMissing
}
return role, cfg.DB().Where(role).FirstOrCreate(role).Error
}
func (h *roleHandler) Patch() (interface{}, error) {
if !h.GetAuth(auth.Role).CanUpdate() {
3 years ago
return nil, oerr.NoAuth
}
query := &struct {
Name *string
3 years ago
// 角色标签
Tag *string `gorm:"default:''"`
3 years ago
}{}
err := h.Meta().ReadJson(query)
if err != nil {
return nil, err
}
rid := h.Meta().ParamsInt("id")
if rid <= 0 {
return nil, oerr.ApiArgsError
}
role := &models.Role{}
role.ID = uint(rid)
err = cfg.DB().Preload("Users").Where(role).First(role).Error
if err != nil {
return nil, err
}
return nil, cfg.DB().Transaction(func(tx *gorm.DB) error {
var err error
if query.Tag != nil && *query.Tag != role.Tag {
err = tx.Model(role).Update("Tag", *query.Tag).Error
3 years ago
if err != nil {
return err
}
}
if query.Name != nil && *query.Name != role.Name {
err = tx.Model(role).Update("Name", *query.Name).Error
3 years ago
if err != nil {
return err
}
}
return err
})
}
func (h *roleHandler) Delete() (interface{}, error) {
log.Warn().Msgf("%s %d", h.UUID, h.GetAuth(auth.Role, h.UUID))
if !h.GetAuth(auth.Role, h.UUID).CanDelete() {
3 years ago
return nil, oerr.NoAuth
}
rid := h.Meta().ParamsInt("id")
if rid <= 0 {
return nil, oerr.ApiArgsError
3 years ago
}
role := &models.Role{}
role.ID = uint(rid)
err := cfg.DB().Preload("Users").Where(role).First(role).Error
3 years ago
if err != nil {
return nil, err
}
if role.AppUUID != h.UUID {
return nil, oerr.NoAuth
}
if len(role.Users) != 0 {
return nil, errors.New("关联用户未删除")
}
3 years ago
return nil, cfg.DB().Delete(role).Error
}