update_agent_logic.go 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. package agent
  2. import (
  3. "context"
  4. "errors"
  5. "wechat-api/ent"
  6. "wechat-api/ent/agent"
  7. "wechat-api/ent/wx"
  8. "wechat-api/internal/svc"
  9. "wechat-api/internal/types"
  10. "wechat-api/internal/utils/dberrorhandler"
  11. "github.com/suyuan32/simple-admin-common/msg/errormsg"
  12. "github.com/zeromicro/go-zero/core/logx"
  13. )
  14. type UpdateAgentLogic struct {
  15. ctx context.Context
  16. svcCtx *svc.ServiceContext
  17. logx.Logger
  18. }
  19. func NewUpdateAgentLogic(ctx context.Context, svcCtx *svc.ServiceContext) *UpdateAgentLogic {
  20. return &UpdateAgentLogic{
  21. ctx: ctx,
  22. svcCtx: svcCtx,
  23. Logger: logx.WithContext(ctx),
  24. }
  25. }
  26. func (l *UpdateAgentLogic) UpdateAgent(req *types.AgentInfo) (*types.BaseMsgResp, error) {
  27. organizationId := l.ctx.Value("organizationId").(uint64)
  28. if *req.Id <= 0 {
  29. l.Error("记录ID不存在")
  30. return nil, errors.New("记录ID不存在")
  31. }
  32. item, err := l.svcCtx.DB.Agent.Query().Where(agent.ID(*req.Id), agent.OrganizationID(organizationId)).First(l.ctx)
  33. if err != nil && ent.IsNotFound(err) {
  34. return nil, errors.New("记录不存在")
  35. }
  36. // 如果是下架AI角色,则需要判断是否有账号在关联该AI角色,如果有不让修改
  37. if item.Status == 1 && req.Status != nil && *req.Status == 2 {
  38. count, _ := l.svcCtx.DB.Wx.Query().Where(wx.AgentID(*req.Id)).Count(l.ctx)
  39. if count > 0 {
  40. return nil, errors.New("有账号在使用该AI角色,请取消关联后再尝试禁用")
  41. }
  42. }
  43. err = l.svcCtx.DB.Agent.UpdateOneID(*req.Id).
  44. SetNotNilName(req.Name).
  45. SetNotNilRole(req.Role).
  46. SetNotNilStatus(req.Status).
  47. SetNotNilBackground(req.Background).
  48. SetNotNilExamples(req.Examples).
  49. Exec(l.ctx)
  50. if err != nil {
  51. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  52. }
  53. return &types.BaseMsgResp{Msg: errormsg.UpdateSuccess}, nil
  54. }