create_credit_balance_logic.go 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. package credit_balance
  2. import (
  3. "context"
  4. "github.com/alibabacloud-go/tea/tea"
  5. "github.com/suyuan32/simple-admin-core/rpc/types/core"
  6. "github.com/zeromicro/go-zero/core/errorx"
  7. "github.com/suyuan32/simple-admin-common/msg/errormsg"
  8. "wechat-api/internal/svc"
  9. "wechat-api/internal/types"
  10. "github.com/zeromicro/go-zero/core/logx"
  11. )
  12. type CreateCreditBalanceLogic struct {
  13. ctx context.Context
  14. svcCtx *svc.ServiceContext
  15. logx.Logger
  16. }
  17. func NewCreateCreditBalanceLogic(ctx context.Context, svcCtx *svc.ServiceContext) *CreateCreditBalanceLogic {
  18. return &CreateCreditBalanceLogic{
  19. ctx: ctx,
  20. svcCtx: svcCtx,
  21. Logger: logx.WithContext(ctx),
  22. }
  23. }
  24. func (l *CreateCreditBalanceLogic) CreateCreditBalance(req *types.CreditBalanceInfo) (*types.BaseMsgResp, error) {
  25. userId := l.ctx.Value("userId").(string)
  26. _, err := l.svcCtx.CoreRpc.GetDepartmentById(l.ctx, &core.IDReq{Id: *req.OrganizationId})
  27. if err != nil {
  28. return nil, errorx.NewAlreadyExistsError("租户不存在")
  29. }
  30. tx, err := l.svcCtx.DB.Tx(context.Background())
  31. if err != nil {
  32. return nil, err
  33. }
  34. _, err = tx.CreditBalance.Create().
  35. SetNotNilUserID(req.UserId).
  36. SetNotNilBalance(req.Balance).
  37. SetNotNilStatus(tea.Int(1)).
  38. SetNotNilOrganizationID(req.OrganizationId).
  39. Save(l.ctx)
  40. if err != nil {
  41. l.Logger.Errorf("create credit_balance failed! err=%v\n", err)
  42. _ = tx.Rollback()
  43. }
  44. _, err = tx.CreditUsage.Create().
  45. SetNotNilUserID(req.UserId).
  46. SetNotNilNumber(req.Balance).
  47. SetNtype(2).
  48. SetTable("").
  49. SetNotNilOrganizationID(req.OrganizationId).
  50. SetNid(0).
  51. SetReason("后台管理员创建").
  52. SetOperator(userId).
  53. Save(l.ctx)
  54. if err != nil {
  55. l.Logger.Errorf("create credit_usage failed! err=%v\n", err)
  56. _ = tx.Rollback()
  57. }
  58. _ = tx.Commit()
  59. return &types.BaseMsgResp{Msg: errormsg.CreateSuccess}, nil
  60. }