Files

101 lines
2.5 KiB
Go
Raw Normal View History

2021-09-28 11:47:19 +08:00
package role
import (
2022-01-07 17:24:39 +08:00
"SciencesServer/app/api/admin/controller/menu"
2022-01-06 22:02:09 +08:00
"SciencesServer/app/api/admin/model"
2021-09-28 11:47:19 +08:00
model2 "SciencesServer/app/common/model"
2022-01-07 17:24:39 +08:00
"SciencesServer/app/service"
2022-01-06 22:02:09 +08:00
"SciencesServer/app/session"
2021-09-28 11:47:19 +08:00
"SciencesServer/serve/orm"
2022-01-07 17:24:39 +08:00
"errors"
"fmt"
2021-09-28 11:47:19 +08:00
"gorm.io/gorm"
)
2022-01-06 22:02:09 +08:00
type Menu struct{ *session.Admin }
2021-09-28 11:47:19 +08:00
2022-01-06 22:02:09 +08:00
type MenuHandle func(session *session.Admin) *Menu
2021-09-28 11:47:19 +08:00
2022-01-06 22:02:09 +08:00
// Index 菜单列表
2022-01-07 17:24:39 +08:00
func (c *Menu) Index(roleID uint64) ([]*menu.TreeChecked, error) {
2022-01-06 22:02:09 +08:00
mSysMenu := model.NewSysMenu()
2022-01-07 17:24:39 +08:00
return menu.MenuForRoleChecked(mSysMenu, c.TenantID, roleID)
2021-09-28 11:47:19 +08:00
}
// Bind 绑定菜单
func (c *Menu) Bind(roleID uint64, menuIDs []uint64) error {
2022-01-07 17:24:39 +08:00
if c.TenantID > 0 {
// 查询该租户下绑定的菜单信息
mSysTenantMenu := model.NewSysTenantMenu()
2021-09-28 11:47:19 +08:00
2022-01-07 17:24:39 +08:00
var count int64
if err := model2.Count(mSysTenantMenu.SysTenantMenu, &count, model2.NewWhere("tenant_id", c.TenantID),
model2.NewWhereNotIn("menu_id", menuIDs)); err != nil {
return err
} else if count > 0 {
return errors.New("操作异常,菜单权限异常")
}
2021-09-28 11:47:19 +08:00
}
2022-01-06 22:02:09 +08:00
mSysRoleMenu := model.NewSysRoleMenu()
2021-09-28 11:47:19 +08:00
return orm.GetDB().Transaction(func(tx *gorm.DB) error {
err := model2.DeleteWhere(mSysRoleMenu.SysRoleMenu, []*model2.ModelWhere{model2.NewWhere("role_id", roleID)}, tx)
if err != nil {
return err
}
2022-01-07 17:24:39 +08:00
permission := service.NewPermission(
service.WithAuthTenant(fmt.Sprintf("%d", c.TenantID)),
service.WithAuthRoles([]string{fmt.Sprintf("%d", roleID)}),
)
2021-09-28 11:47:19 +08:00
if len(menuIDs) <= 0 {
2022-01-07 17:24:39 +08:00
_, err = permission.RemoveSingleRolePolicy()
return err
2021-09-28 11:47:19 +08:00
}
2022-01-07 17:24:39 +08:00
// 查询菜单信息
mSysMenu := model.NewSysMenu()
2021-09-28 11:47:19 +08:00
2022-01-07 17:24:39 +08:00
menus := make([]*model2.SysMenu, 0)
2021-09-28 11:47:19 +08:00
2022-01-07 17:24:39 +08:00
if err = model2.ScanFields(mSysMenu.SysMenu, &menus, []string{"id", "kind", "auth"}, &model2.ModelWhereOrder{
Where: model2.NewWhereIn("id", menuIDs),
}); err != nil {
return err
}
data := make([]*model2.SysRoleMenu, 0)
request := make([]*service.AuthRequest, 0)
for _, v := range menus {
data = append(data, &model2.SysRoleMenu{
RoleID: roleID,
MenuID: v.ID,
})
if v.Kind == model2.SysMenuKindForCatalogue || v.Auth == "" {
2021-09-28 11:47:19 +08:00
continue
}
2022-01-07 17:24:39 +08:00
mSysMenu.Auth = v.Auth
request = append(request, &service.AuthRequest{
Url: mSysMenu.FilterAuth(),
Method: "*",
})
2021-09-28 11:47:19 +08:00
}
2022-01-07 17:24:39 +08:00
if err = model2.Creates(mSysRoleMenu.SysRoleMenu, data, tx); err != nil {
2021-09-28 11:47:19 +08:00
return err
}
2022-01-07 17:24:39 +08:00
permission.AddRequest(request)
_, err = permission.AddPolicies()
return err
2021-09-28 11:47:19 +08:00
})
}
func NewMenu() MenuHandle {
2022-01-06 22:02:09 +08:00
return func(session *session.Admin) *Menu {
return &Menu{Admin: session}
2021-09-28 11:47:19 +08:00
}
}