stop_batch_msg_logic.go 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. package batch_msg
  2. import (
  3. "context"
  4. "github.com/suyuan32/simple-admin-common/msg/errormsg"
  5. "github.com/zeromicro/go-zero/core/errorx"
  6. "wechat-api/ent"
  7. "wechat-api/ent/batchmsg"
  8. "wechat-api/internal/utils/dberrorhandler"
  9. "wechat-api/internal/svc"
  10. "wechat-api/internal/types"
  11. "github.com/zeromicro/go-zero/core/logx"
  12. )
  13. type StopBatchMsgLogic struct {
  14. logx.Logger
  15. ctx context.Context
  16. svcCtx *svc.ServiceContext
  17. }
  18. func NewStopBatchMsgLogic(ctx context.Context, svcCtx *svc.ServiceContext) *StopBatchMsgLogic {
  19. return &StopBatchMsgLogic{
  20. Logger: logx.WithContext(ctx),
  21. ctx: ctx,
  22. svcCtx: svcCtx}
  23. }
  24. func (l *StopBatchMsgLogic) StopBatchMsg(req *types.IDReq) (resp *types.BaseMsgResp, err error) {
  25. organizationId := l.ctx.Value("organizationId").(uint64)
  26. batchMsg, err := l.svcCtx.DB.BatchMsg.Query().Where(batchmsg.ID(req.Id), batchmsg.OrganizationID(organizationId)).First(l.ctx)
  27. if err != nil {
  28. if ent.IsNotFound(err) {
  29. return nil, errorx.NewInvalidArgumentError("群发消息不存在")
  30. }
  31. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  32. }
  33. if batchMsg.Status == 0 {
  34. // 设置状态为3,代表已停止
  35. err = l.svcCtx.DB.BatchMsg.UpdateOneID(batchMsg.ID).SetStatus(3).Exec(l.ctx)
  36. if err != nil {
  37. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  38. }
  39. } else if batchMsg.Status == 3 {
  40. return nil, errorx.NewInvalidArgumentError("群发消息已停止")
  41. } else if batchMsg.Status == 2 {
  42. return nil, errorx.NewInvalidArgumentError("群发消息已发送完毕,无法停止")
  43. } else if batchMsg.Status == 1 {
  44. return nil, errorx.NewInvalidArgumentError("群发消息正在发送中,无法停止")
  45. }
  46. return &types.BaseMsgResp{Msg: errormsg.UpdateSuccess}, nil
  47. }