delete_agent_logic.go 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. package agent
  2. import (
  3. "context"
  4. "errors"
  5. "wechat-api/ent/wx"
  6. "wechat-api/ent/agent"
  7. "wechat-api/internal/svc"
  8. "wechat-api/internal/types"
  9. "wechat-api/internal/utils/dberrorhandler"
  10. "github.com/suyuan32/simple-admin-common/msg/errormsg"
  11. "github.com/zeromicro/go-zero/core/logx"
  12. )
  13. type DeleteAgentLogic struct {
  14. ctx context.Context
  15. svcCtx *svc.ServiceContext
  16. logx.Logger
  17. }
  18. func NewDeleteAgentLogic(ctx context.Context, svcCtx *svc.ServiceContext) *DeleteAgentLogic {
  19. return &DeleteAgentLogic{
  20. ctx: ctx,
  21. svcCtx: svcCtx,
  22. Logger: logx.WithContext(ctx),
  23. }
  24. }
  25. func (l *DeleteAgentLogic) DeleteAgent(req *types.IDsReq) (*types.BaseMsgResp, error) {
  26. organizationId := l.ctx.Value("organizationId").(uint64)
  27. if len(req.Ids) == 0 {
  28. return nil, errors.New("ids参数不能为空")
  29. }
  30. // 删除AI角色之前要检查他是否被某账号所使用
  31. count, _ := l.svcCtx.DB.Wx.Query().Where(wx.AgentIDIn(req.Ids...)).Count(l.ctx)
  32. if count > 0 {
  33. return nil, errors.New("有账号在使用该AI角色,请取消关联后再尝试删除")
  34. }
  35. _, err := l.svcCtx.DB.Agent.Delete().Where(agent.IDIn(req.Ids...), agent.OrganizationID(organizationId)).Exec(l.ctx)
  36. if err != nil {
  37. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  38. }
  39. return &types.BaseMsgResp{Msg: errormsg.DeleteSuccess}, nil
  40. }