sendable-error v0.7.0
sendable-error ·

Composable errors to simplify creating useful failure responses for APIs
npm i sendable-error
Note: this package is in early development, use with caution
SendableErrors
provide built-in support for:
- An easy to use builder interface to construct errors
- A unified way to send your errors as a JSON response
- Error codes to easily identify error types on the client side
- Public and private messages & details so your APIs don't leak technical information yet retaining verbose logging
- Trace IDs allow you to identify specific errors and allows user's to point you in the right direction when they encounter a bug
- A customizable logger interface
import { SendableError } from "sendable-error";
try {
throw new SendableError({
status: 400,
code: "validation/missing-required",
message: "Missing required field 'id'",
public: true,
details: {
field: "id"
}
})
} catch (error) {
return SendableError.of(error).toResponse();
}
Response with status code `400¦:
{
"code": "validation/missing-required",
"message": "Missing required field 'id'",
"traceId": "8ab9c56a-90d1-5e71-b67a-d6b725837802",
"details": {
"field": "id"
}
}
Getting Started
Throwing Errors
Creating a new error from scratch:
throw new SendableError({
code: CODE_MISSING_REQUIRED,
message: "Missing required field 'id'",
public: true,
details: {
field: "id",
},
});
Or provide a cause for the error:
throw new SendableError({
code: CODE_DATABASE_ERROR,
cause: error,
});
Or even transform an error from elsewhere into a SendableError
:
throw SendableError.of(error, {
code: CODE_DATABASE_ERROR
});
Sending Errors
Express
app.use((error, req, res, next) => {
SendableError.of(error).send(res);
});
WinterTC Compatible
export const handler = async (request: Request) => {
try {
// do something that might throw
} catch (error) {
return SendableError.of(error).toResponse();
}
}
Others
try {
// do something that might throw
} catch (error) {
const responseBody = SendableError.of(error).toResponseBody();
/* send responseBody */
}
4 months ago
4 months ago
9 months ago
11 months ago
11 months ago
11 months ago
11 months ago
11 months ago
11 months ago
11 months ago
12 months ago
12 months ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
4 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago