Properly update an error's properties
npm install set-error-props






Properly update an error's properties.
- Prevents overriding error core properties (name,
message, etc.)
- Protects against prototype pollution
- Prevents overriding existing properties
- Copies another error's properties
- Can set properties as non-enumerable
- Preserves properties descriptors (enumerable, writable,
configurable, get/set)
- Exception-safe: this only throws syntax errors
- Strict TypeScript typing of the return value
``js
import setErrorProps from 'set-error-props'
const error = new Error('one')
setErrorProps(error, { prop: true, message: 'two' })
console.log(error.prop) // true
console.log(error.message) // 'one': message is readonly
`
`bash`
npm install set-error-props
This package works in both Node.js >=18.18.0 and
browsers.
This is an ES module. It must be loaded using
an import or import() statement,
not require(). If TypeScript is used, it must be configured to
output ES modules,
not CommonJS.
error Error | object\props Error | object\options Options?\Error
_Return value_:
Assigns props to error, then returns error.
#### soft
_Type_: boolean\false
_Default_:
Prevents overriding existing properties.
`js`
const error = new Error('one')
setErrorProps(error, { message: 'two' })
console.log(error.message) // 'one'
`js`
const error = new Error('one')
setErrorProps(error, { toString: () => 'injected' })
console.log(error.toString()) // 'Error: one'
console.log(Error.prototype.toString()) // 'Error'
`js`
const error = new Error('message')
error.one = true
setErrorProps(error, { one: false, two: true }, { soft: true })
console.log(error.one) // true
console.log(error.two) // true
`js`
const error = new Error('one')
const secondError = new Error('two')
secondError.prop = true
setErrorProps(error, secondError)
console.log(error.message) // 'one'
console.log(error.prop) // true
`js
const error = new Error('message')
// Properties that start with _ are not enumerable
setErrorProps(error, { _one: true, two: true })
console.log(error._one) // true
console.log(error.two) // true
console.log(Object.keys(error)) // ['two']
console.log(error) // Prints two but not _one`
`js`
const error = new Error('message')
Object.defineProperty(error, 'prop', {
value: false,
enumerable: false,
writable: true,
configurable: true,
})
setErrorProps(error, { prop: true })
console.log(error.prop) // true
console.log(Object.getOwnPropertyDescriptor(error, 'prop').enumerable) // false
`js`
const error = new Proxy(new Error('message'), {
set: () => {
throw new Error('example')
},
defineProperty: () => {
throw new Error('example')
},
})
setErrorProps(error, { prop: true }) // This does not throw
- modern-errors: Handle errors in
a simple, stable, consistent way
- error-custom-class: Create
one error class
- error-class-utils: Utilities
to properly create error classes
- error-serializer: Convert
errors to/from plain objects
- normalize-exception:
Normalize exceptions/errors
- is-error-instance: Check if
a value is an Error instanceset-error-class
- : Properlyset-error-message
update an error's class
- : Properlywrap-error-message
update an error's message
- :set-error-stack
Properly wrap an error's message
- : Properlymerge-error-cause
update an error's stack
- : Merge ancause
error with its error-cause-polyfill
- :error.cause
Polyfill handle-cli-error
- : 💣 Errorlog-process-errors
handler for CLI applications 💥
- : Showerror-http-response
some ❤ to Node.js process errors
- :winston-error-format
Create HTTP error responses
- : Log
errors with Winston
For any question, _don't hesitate_ to submit an issue on GitHub.
Everyone is welcome regardless of personal background. We enforce a
Code of conduct in order to promote a positive and
inclusive environment.
This project was made with ❤️. The simplest way to give back is by starring and
sharing it online.
If the documentation is unclear or has a typo, please click on the page's Edit`
button (pencil icon) and suggest a correction.
If you would like to help us fix a bug or add a new feature, please check our
guidelines. Pull requests are welcome!