create_credit_balance_logic.go 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  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. _, err := l.svcCtx.CoreRpc.GetDepartmentById(l.ctx, &core.IDReq{Id: *req.OrganizationId})
  31. if err != nil {
  32. return nil, errorx.NewAlreadyExistsError("租户不存在")
  33. }
  34. tx, err := l.svcCtx.DB.Tx(context.Background())
  35. if err != nil {
  36. return nil, err
  37. }
  38. old, err := tx.CreditBalance.Query().Where(creditbalance.OrganizationID(*req.OrganizationId)).First(l.ctx)
  39. if err != nil && ent.IsNotFound(err) {
  40. _, err = tx.CreditBalance.Create().
  41. SetNotNilUserID(req.UserId).
  42. SetNotNilBalance(req.Balance).
  43. SetNotNilOrganizationID(req.OrganizationId).
  44. Save(l.ctx)
  45. if err != nil {
  46. l.Logger.Errorf("create credit_balance failed! err=%v\n", err)
  47. _ = tx.Rollback()
  48. }
  49. } else {
  50. _, err = tx.CreditBalance.UpdateOneID(old.ID).
  51. SetBalance(*req.Balance + old.Balance).
  52. Save(l.ctx)
  53. if err != nil {
  54. l.Logger.Errorf("update credit_balance failed! err=%v\n", err)
  55. _ = tx.Rollback()
  56. }
  57. }
  58. _, err = tx.CreditUsage.Create().
  59. SetNotNilUserID(req.UserId).
  60. SetNotNilNumber(req.Balance).
  61. SetNtype(2).
  62. SetTable("").
  63. SetNotNilOrganizationID(req.OrganizationId).
  64. SetNid(0).
  65. SetReason("管理员操作").
  66. SetOperator(userId).
  67. Save(l.ctx)
  68. if err != nil {
  69. l.Logger.Errorf("create credit_usage failed! err=%v\n", err)
  70. _ = tx.Rollback()
  71. }
  72. _ = tx.Commit()
  73. return &types.BaseMsgResp{Msg: errormsg.CreateSuccess}, nil
  74. }