代码拉取完成,页面将自动刷新
package datamanagelogic
import (
"context"
"gitee.com/unitedrhino/core/service/syssvr/internal/repo/cache"
"gitee.com/unitedrhino/core/service/syssvr/internal/repo/relationDB"
"gitee.com/unitedrhino/core/service/syssvr/internal/svc"
"gitee.com/unitedrhino/core/service/syssvr/pb/sys"
"gitee.com/unitedrhino/share/ctxs"
"gitee.com/unitedrhino/share/def"
"gitee.com/unitedrhino/share/errors"
"github.com/zeromicro/go-zero/core/logx"
)
type DataAreaMultiDeleteLogic struct {
ctx context.Context
svcCtx *svc.ServiceContext
logx.Logger
}
func NewDataAreaMultiDeleteLogic(ctx context.Context, svcCtx *svc.ServiceContext) *DataAreaMultiDeleteLogic {
return &DataAreaMultiDeleteLogic{
ctx: ctx,
svcCtx: svcCtx,
Logger: logx.WithContext(ctx),
}
}
func (l *DataAreaMultiDeleteLogic) DataAreaMultiDelete(in *sys.DataAreaMultiDeleteReq) (*sys.Empty, error) {
uc := ctxs.GetUserCtx(l.ctx)
if in.ProjectID != 0 {
uc.ProjectID = in.ProjectID
} else {
in.ProjectID = uc.ProjectID
}
if !(uc.IsAdmin) {
pa := uc.ProjectAuth[in.ProjectID]
if pa == nil {
return nil, errors.Permissions.AddMsg("项目无权限")
}
in.TargetID = uc.UserID
if in.TargetType != def.TargetUser {
return nil, errors.Permissions.AddMsg("普通用户只能修改用户类型")
}
for _, v := range in.AreaIDs {
if pa.Area[v] == 0 {
return nil, errors.Permissions.AddMsg("区域无权限")
}
}
//return nil, errors.Permissions.WithMsg("只有管理员才有权限授权")
}
err := relationDB.NewDataAreaRepo(l.ctx).DeleteByFilter(l.ctx, relationDB.DataAreaFilter{Targets: []*relationDB.Target{{Type: in.TargetType, ID: in.TargetID}}, AreaIDs: in.AreaIDs})
if err != nil {
return nil, err
}
if in.TargetType == def.TargetUser {
cache.ClearProjectAuth(in.TargetID)
}
return &sys.Empty{}, err
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。