package credit_balance import ( "context" "github.com/alibabacloud-go/tea/tea" "github.com/suyuan32/simple-admin-core/rpc/types/core" "github.com/zeromicro/go-zero/core/errorx" "github.com/suyuan32/simple-admin-common/msg/errormsg" "wechat-api/internal/svc" "wechat-api/internal/types" "github.com/zeromicro/go-zero/core/logx" ) type CreateCreditBalanceLogic struct { ctx context.Context svcCtx *svc.ServiceContext logx.Logger } func NewCreateCreditBalanceLogic(ctx context.Context, svcCtx *svc.ServiceContext) *CreateCreditBalanceLogic { return &CreateCreditBalanceLogic{ ctx: ctx, svcCtx: svcCtx, Logger: logx.WithContext(ctx), } } func (l *CreateCreditBalanceLogic) CreateCreditBalance(req *types.CreditBalanceInfo) (*types.BaseMsgResp, error) { userId := l.ctx.Value("userId").(string) _, err := l.svcCtx.CoreRpc.GetDepartmentById(l.ctx, &core.IDReq{Id: *req.OrganizationId}) if err != nil { return nil, errorx.NewAlreadyExistsError("租户不存在") } tx, err := l.svcCtx.DB.Tx(context.Background()) if err != nil { return nil, err } _, err = tx.CreditBalance.Create(). SetNotNilUserID(req.UserId). SetNotNilBalance(req.Balance). SetNotNilStatus(tea.Int(1)). SetNotNilOrganizationID(req.OrganizationId). Save(l.ctx) if err != nil { l.Logger.Errorf("create credit_balance failed! err=%v\n", err) _ = tx.Rollback() } _, err = tx.CreditUsage.Create(). SetNotNilUserID(req.UserId). SetNotNilNumber(req.Balance). SetNtype(2). SetTable(""). SetNotNilOrganizationID(req.OrganizationId). SetNid(0). SetReason("后台管理员创建"). SetOperator(userId). Save(l.ctx) if err != nil { l.Logger.Errorf("create credit_usage failed! err=%v\n", err) _ = tx.Rollback() } _ = tx.Commit() return &types.BaseMsgResp{Msg: errormsg.CreateSuccess}, nil }