delete_sop_node_logic.go 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. package sop_node
  2. import (
  3. "context"
  4. "wechat-api/ent"
  5. "wechat-api/ent/sopnode"
  6. "wechat-api/internal/svc"
  7. "wechat-api/internal/types"
  8. "wechat-api/internal/utils/dberrorhandler"
  9. "github.com/suyuan32/simple-admin-common/msg/errormsg"
  10. "github.com/zeromicro/go-zero/core/logx"
  11. )
  12. type DeleteSopNodeLogic struct {
  13. ctx context.Context
  14. svcCtx *svc.ServiceContext
  15. logx.Logger
  16. }
  17. func NewDeleteSopNodeLogic(ctx context.Context, svcCtx *svc.ServiceContext) *DeleteSopNodeLogic {
  18. return &DeleteSopNodeLogic{
  19. ctx: ctx,
  20. svcCtx: svcCtx,
  21. Logger: logx.WithContext(ctx),
  22. }
  23. }
  24. func (l *DeleteSopNodeLogic) DeleteSopNode(req *types.IDReq) (*types.BaseMsgResp, error) {
  25. organizationId := l.ctx.Value("organizationId").(uint64)
  26. // 根据 id 关联查询处 task 信息,并判断 status 是否为 1
  27. data, err := l.svcCtx.DB.SopNode.Query().
  28. Where(sopnode.ID(req.Id)).
  29. WithSopStage(func(query *ent.SopStageQuery) {
  30. query.WithSopTask()
  31. }).
  32. Only(l.ctx)
  33. if err != nil {
  34. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  35. }
  36. task := data.Edges.SopStage.Edges.SopTask
  37. if task.Status != 1 || task.OrganizationID != organizationId {
  38. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  39. }
  40. // 开始一个新的事务
  41. tx, err := l.svcCtx.DB.Tx(l.ctx)
  42. if err != nil {
  43. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  44. }
  45. // 确保在函数返回时回滚事务,除非提交事务成功
  46. defer func() {
  47. if err != nil {
  48. if rbErr := tx.Rollback(); rbErr != nil {
  49. l.Logger.Errorf("tx rollback error: %v", rbErr)
  50. }
  51. } else {
  52. if commitErr := tx.Commit(); commitErr != nil {
  53. err = commitErr
  54. }
  55. }
  56. }()
  57. // 首先删除所有子节点
  58. err = l.deleteChildren(tx, req.Id)
  59. if err != nil {
  60. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  61. }
  62. // 删除节点本身
  63. _, err = tx.SopNode.Delete().Where(sopnode.IDIn(req.Id)).Exec(l.ctx)
  64. if err != nil {
  65. _ = tx.Rollback()
  66. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  67. }
  68. return &types.BaseMsgResp{Msg: errormsg.DeleteSuccess}, nil
  69. }
  70. func (l *DeleteSopNodeLogic) deleteChildren(tx *ent.Tx, parentID uint64) error {
  71. // 查找所有子节点
  72. children, err := tx.SopNode.Query().Where(sopnode.ParentID(parentID)).All(l.ctx)
  73. if err != nil {
  74. return err
  75. }
  76. // 对每个子节点递归执行删除操作
  77. for _, child := range children {
  78. err := l.deleteChildren(tx, child.ID)
  79. if err != nil {
  80. return err
  81. }
  82. _, err = tx.SopNode.Delete().Where(sopnode.ID(child.ID)).Exec(l.ctx)
  83. if err != nil {
  84. return err
  85. }
  86. }
  87. return nil
  88. }