StreamVersionConflictError
API reference for StreamVersionConflictError
Class: StreamVersionConflictError<T>
Section titled “Class: StreamVersionConflictError<T>”Error thrown when expected stream version doesn’t match current version This is a specialized version conflict error for stream-based operations
Extends
Section titled “Extends”Type Parameters
Section titled “Type Parameters”T
= unknown
Constructors
Section titled “Constructors”Constructor
Section titled “Constructor”new StreamVersionConflictError<
T
>(current
,expected
,message?
):StreamVersionConflictError
<T
>
Parameters
Section titled “Parameters”current
Section titled “current”T
expected
Section titled “expected”T
message?
Section titled “message?”string
Returns
Section titled “Returns”StreamVersionConflictError
<T
>
Overrides
Section titled “Overrides”VersionConflictError
.constructor
Properties
Section titled “Properties”
readonly
body:unknown
Original error response body from the API
Inherited from
Section titled “Inherited from”current
Section titled “current”
readonly
current:T
The current version that was found
currentVersion
Section titled “currentVersion”
readonly
currentVersion:number
The current version of the stream
Inherited from
Section titled “Inherited from”VersionConflictError
.currentVersion
details?
Section titled “details?”
readonly
optional
details:Record
<string
,unknown
>
Additional error details
Inherited from
Section titled “Inherited from”errorType
Section titled “errorType”
readonly
errorType:string
Error type identifier
Inherited from
Section titled “Inherited from”VersionConflictError
.errorType
expected
Section titled “expected”
readonly
expected:T
The expected version that was provided
expectedVersion
Section titled “expectedVersion”
readonly
expectedVersion:number
The expected version that was provided
Inherited from
Section titled “Inherited from”VersionConflictError
.expectedVersion
message
Section titled “message”message:
string
Inherited from
Section titled “Inherited from”name:
string
Inherited from
Section titled “Inherited from”stack?
Section titled “stack?”
optional
stack:string
Inherited from
Section titled “Inherited from”status
Section titled “status”
readonly
status:number
HTTP status code associated with this error
Inherited from
Section titled “Inherited from”stackTraceLimit
Section titled “stackTraceLimit”
static
stackTraceLimit:number
The Error.stackTraceLimit
property specifies the number of stack frames
collected by a stack trace (whether generated by new Error().stack
or
Error.captureStackTrace(obj)
).
The default value is 10
but may be set to any valid JavaScript number. Changes
will affect any stack trace captured after the value has been changed.
If set to a non-number value, or set to a negative number, stack traces will not capture any frames.
Inherited from
Section titled “Inherited from”VersionConflictError
.stackTraceLimit
Methods
Section titled “Methods”captureStackTrace()
Section titled “captureStackTrace()”
static
captureStackTrace(targetObject
,constructorOpt?
):void
Creates a .stack
property on targetObject
, which when accessed returns
a string representing the location in the code at which
Error.captureStackTrace()
was called.
const myObject = {};Error.captureStackTrace(myObject);myObject.stack; // Similar to `new Error().stack`
The first line of the trace will be prefixed with
${myObject.name}: ${myObject.message}
.
The optional constructorOpt
argument accepts a function. If given, all frames
above constructorOpt
, including constructorOpt
, will be omitted from the
generated stack trace.
The constructorOpt
argument is useful for hiding implementation
details of error generation from the user. For instance:
function a() { b();}
function b() { c();}
function c() { // Create an error without stack trace to avoid calculating the stack trace twice. const { stackTraceLimit } = Error; Error.stackTraceLimit = 0; const error = new Error(); Error.stackTraceLimit = stackTraceLimit;
// Capture the stack trace above function b Error.captureStackTrace(error, b); // Neither function c, nor b is included in the stack trace throw error;}
a();
Parameters
Section titled “Parameters”targetObject
Section titled “targetObject”object
constructorOpt?
Section titled “constructorOpt?”Function
Returns
Section titled “Returns”void
Inherited from
Section titled “Inherited from”VersionConflictError
.captureStackTrace
prepareStackTrace()
Section titled “prepareStackTrace()”
static
prepareStackTrace(err
,stackTraces
):any
Parameters
Section titled “Parameters”Error
stackTraces
Section titled “stackTraces”CallSite
[]
Returns
Section titled “Returns”any
https://v8.dev/docs/stack-trace-api#customizing-stack-traces