create_credit_balance_logic.go 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. package credit_balance
  2. import (
  3. "context"
  4. "github.com/suyuan32/simple-admin-core/rpc/types/core"
  5. "github.com/zeromicro/go-zero/core/errorx"
  6. "wechat-api/ent"
  7. "wechat-api/ent/creditbalance"
  8. "github.com/suyuan32/simple-admin-common/msg/errormsg"
  9. "wechat-api/internal/svc"
  10. "wechat-api/internal/types"
  11. "github.com/zeromicro/go-zero/core/logx"
  12. )
  13. type CreateCreditBalanceLogic struct {
  14. ctx context.Context
  15. svcCtx *svc.ServiceContext
  16. logx.Logger
  17. }
  18. func NewCreateCreditBalanceLogic(ctx context.Context, svcCtx *svc.ServiceContext) *CreateCreditBalanceLogic {
  19. return &CreateCreditBalanceLogic{
  20. ctx: ctx,
  21. svcCtx: svcCtx,
  22. Logger: logx.WithContext(ctx),
  23. }
  24. }
  25. func (l *CreateCreditBalanceLogic) CreateCreditBalance(req *types.CreditBalanceInfo) (*types.BaseMsgResp, error) {
  26. userId := l.ctx.Value("userId").(string)
  27. if req.OrganizationId == nil || *req.OrganizationId <= 0 {
  28. return nil, errorx.NewInvalidArgumentError("参数非法")
  29. }
  30. if req.Balance == nil {
  31. return nil, errorx.NewInvalidArgumentError("余额参数非法")
  32. }
  33. _, err := l.svcCtx.CoreRpc.GetDepartmentById(l.ctx, &core.IDReq{Id: *req.OrganizationId})
  34. if err != nil {
  35. return nil, errorx.NewAlreadyExistsError("租户不存在")
  36. }
  37. tx, err := l.svcCtx.DB.Tx(context.Background())
  38. if err != nil {
  39. return nil, err
  40. }
  41. old, err := tx.CreditBalance.Query().Where(creditbalance.OrganizationID(*req.OrganizationId)).First(l.ctx)
  42. if err != nil && ent.IsNotFound(err) {
  43. old, err = tx.CreditBalance.Create().
  44. SetNotNilBalance(req.Balance).
  45. SetNotNilOrganizationID(req.OrganizationId).
  46. Save(l.ctx)
  47. if err != nil {
  48. l.Logger.Errorf("create credit_balance failed! err=%v\n", err)
  49. _ = tx.Rollback()
  50. }
  51. } else {
  52. _, err = tx.CreditBalance.UpdateOneID(old.ID).
  53. SetBalance(*req.Balance + old.Balance).
  54. Save(l.ctx)
  55. if err != nil {
  56. l.Logger.Errorf("update credit_balance failed! err=%v\n", err)
  57. _ = tx.Rollback()
  58. }
  59. }
  60. var beforeNumber, afterNumber float32
  61. beforeNumber = old.Balance
  62. afterNumber = *req.Balance + old.Balance
  63. _, err = tx.CreditUsage.Create().
  64. SetNotNilStatus(req.Status).
  65. SetNotNilNumber(req.Balance).
  66. SetBeforeNumber(beforeNumber).
  67. SetAfterNumber(afterNumber).
  68. SetNtype(2).
  69. SetTable("").
  70. SetNotNilOrganizationID(req.OrganizationId).
  71. SetNid(0).
  72. SetReason("管理员操作").
  73. SetOperator(userId).
  74. Save(l.ctx)
  75. if err != nil {
  76. l.Logger.Errorf("create credit_usage failed! err=%v\n", err)
  77. _ = tx.Rollback()
  78. }
  79. _ = tx.Commit()
  80. return &types.BaseMsgResp{Msg: errormsg.CreateSuccess}, nil
  81. }