package role import ( "SciencesServer/app/api/admin/controller" menu2 "SciencesServer/app/api/admin/controller/menu" model3 "SciencesServer/app/api/admin/model" model2 "SciencesServer/app/common/model" "SciencesServer/app/service" "SciencesServer/serve/orm" "errors" "gorm.io/gorm" ) type Menu struct{ *controller.Platform } type MenuHandle func(session *service.Session) *Menu // List 菜单列表 func (c *Menu) List(roleID uint64) ([]*menu2.TreeChecked, error) { mSysMenu := model3.NewSysMenu() return menu2.MenuForRole(mSysMenu, c.TenantID, roleID) } // Bind 绑定菜单 func (c *Menu) Bind(roleID uint64, menuIDs []uint64) error { if len(menuIDs) > 0 { var count int64 mSysMenu := model3.NewSysMenu() if err := model2.Count(mSysMenu.SysMenu, &count, model2.NewWhereIn("id", menuIDs), model2.NewWhere("auth", model2.SysMenuAuthForSystem)); err != nil { return err } else if count > 0 { return errors.New("不可设置超管菜单") } } mSysRoleMenu := model3.NewSysRoleMenu() 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 } if len(menuIDs) <= 0 { return nil } menus := make([]*model2.SysRoleMenu, 0) mark := make(map[uint64]uint64, 0) for _, v := range menuIDs { if _, has := mark[v]; has { continue } menus = append(menus, &model2.SysRoleMenu{ ModelTenant: model2.ModelTenant{TenantID: c.TenantID}, RoleID: roleID, MenuID: v, }) mark[v] = v } if err = model2.Creates(mSysRoleMenu.SysRoleMenu, menus, tx); err != nil { return err } return nil }) } func NewMenu() MenuHandle { return func(session *service.Session) *Menu { return &Menu{Platform: &controller.Platform{Session: session}} } }