operate_credit_balance_logic.go 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. package credit_balance
  2. import (
  3. "context"
  4. "github.com/suyuan32/simple-admin-common/msg/errormsg"
  5. "github.com/suyuan32/simple-admin-core/rpc/types/core"
  6. "github.com/zeromicro/go-zero/core/errorx"
  7. "wechat-api/ent/creditbalance"
  8. "wechat-api/internal/svc"
  9. "wechat-api/internal/types"
  10. "github.com/zeromicro/go-zero/core/logx"
  11. )
  12. type OperateCreditBalanceLogic struct {
  13. logx.Logger
  14. ctx context.Context
  15. svcCtx *svc.ServiceContext
  16. }
  17. func NewOperateCreditBalanceLogic(ctx context.Context, svcCtx *svc.ServiceContext) *OperateCreditBalanceLogic {
  18. return &OperateCreditBalanceLogic{
  19. Logger: logx.WithContext(ctx),
  20. ctx: ctx,
  21. svcCtx: svcCtx}
  22. }
  23. func (l *OperateCreditBalanceLogic) OperateCreditBalance(req *types.CreditBalanceOperateReq) (*types.BaseMsgResp, error) {
  24. isAdmin := l.ctx.Value("isAdmin").(bool)
  25. if !isAdmin {
  26. return nil, errorx.NewInvalidArgumentError("权限不足")
  27. }
  28. if req.Number == nil || *req.Number == 0 {
  29. return nil, errorx.NewInvalidArgumentError("Number参数非法")
  30. }
  31. _, err := l.svcCtx.CoreRpc.GetDepartmentById(l.ctx, &core.IDReq{Id: *req.OrganizationId})
  32. if err != nil {
  33. return nil, errorx.NewAlreadyExistsError("租户不存在")
  34. }
  35. creditBalance, err := l.svcCtx.DB.CreditBalance.Query().Where(creditbalance.OrganizationID(*req.OrganizationId)).Only(l.ctx)
  36. if err != nil {
  37. l.Logger.Errorf("query credit_balance error:%v\n", err)
  38. return nil, errorx.NewInvalidArgumentError(err.Error())
  39. }
  40. var ntype int
  41. if *req.Number > 0 {
  42. ntype = 2
  43. } else {
  44. ntype = 1
  45. }
  46. userId := l.ctx.Value("userId").(string)
  47. tx, err := l.svcCtx.DB.Tx(context.Background())
  48. var beforeNumber, afterNumber float64
  49. if creditBalance == nil {
  50. beforeNumber = 0
  51. afterNumber = *req.Number
  52. } else {
  53. beforeNumber = creditBalance.Balance
  54. afterNumber = beforeNumber + *req.Number
  55. }
  56. _, err = tx.CreditUsage.Create().
  57. SetNumber(*req.Number).
  58. SetNotNilPayMethod(req.PayMethod). //支付方式
  59. SetNotNilPayNumber(req.PayNumber). //支付金额
  60. SetNtype(ntype).
  61. SetNid(0).
  62. SetTable("").
  63. SetReason(*req.Reason).
  64. SetOrganizationID(*req.OrganizationId).
  65. SetOperator(userId).
  66. SetBeforeNumber(beforeNumber).
  67. SetAfterNumber(afterNumber).
  68. Save(l.ctx)
  69. if err != nil {
  70. l.Logger.Errorf("create credit_usage error:%v\n", err)
  71. _ = tx.Rollback()
  72. return nil, errorx.NewInvalidArgumentError("创建租户积分明细失败,请重试")
  73. }
  74. if *req.Number > 0 {
  75. if creditBalance == nil {
  76. _, err = l.svcCtx.DB.CreditBalance.Create().
  77. SetOrganizationID(*req.OrganizationId).
  78. SetBalance(*req.Number).
  79. Save(l.ctx)
  80. if err != nil {
  81. l.Logger.Errorf("create credit_balance error:%v\n", err)
  82. _ = tx.Rollback()
  83. return nil, errorx.NewInvalidArgumentError("创建租户积分余额失败,请重试")
  84. }
  85. } else {
  86. _, err = l.svcCtx.DB.CreditBalance.Update().Where(creditbalance.OrganizationID(*req.OrganizationId)).SetBalance(creditBalance.Balance + *req.Number).Save(l.ctx)
  87. if err != nil {
  88. l.Logger.Errorf("update credit_balance error:%v\n", err)
  89. _ = tx.Rollback()
  90. return nil, errorx.NewInvalidArgumentError("修改租户积分余额失败,请重试.")
  91. }
  92. }
  93. } else {
  94. _, err := l.svcCtx.DB.CreditBalance.Update().Where(creditbalance.OrganizationID(*req.OrganizationId)).SetBalance(creditBalance.Balance + *req.Number).Save(l.ctx)
  95. if err != nil {
  96. l.Logger.Errorf("update credit_balance error:%v\n", err)
  97. _ = tx.Rollback()
  98. return nil, errorx.NewInvalidArgumentError("修改租户积分余额失败,请重试...")
  99. }
  100. }
  101. _ = tx.Commit()
  102. return &types.BaseMsgResp{
  103. Code: 0,
  104. Msg: errormsg.Success,
  105. }, nil
  106. }