Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
@golemio/errors
Advanced tools
Library of Error classes of the Golemio Data Platform System
Minimal package with custom Error class extending the native built-in JavaScript Error
class, providing extra functionality and more capabilities for error handling.
Trying to adhere to Node.js best practices.
Developed by http://operatorict.cz
Install Node
Install all npm modules using command:
npm install
To compile typescript code into js one-time
npm run build
or run this, to watch all changes
npm run build-watch
from the application's root directory.
In your project's package.json
set dependency to Errors
npm install @golemio/errors --save
or
yarn add @golemio/errors --save
Then import module, e.g.
import { GeneralError, FatalError } from "@golemio/errors";
Our AbstractGolemioError has:
Error
Error
There are two main classes: GeneralError
and FatalError
. Both are extending AbstractGolemioError
class. Furthermore, GeneralError
subclasses:
BusinessError
DatasourceError
RecoverableError
TransformationError
ValidationError
You can use instance of AbstractGolemioError class as you would a standard JavaScript Error, you will just get additional info and more capabilities:
const found = await this.model.findOne(id);
if (!found ) {
throw new GeneralError("Id `" + id + "` not found", "MyModelClass", new Error("More info"), 404);
}
you can add the underlying Error to get the whole stack trace:
try {
const q = this.model.find("nonsense");
return await q.exec();
} catch (err) {
throw new GeneralError("Database error", "MyModelClass", err, 500);
}
and the result you will get:
MyModelClass: [500] Database error (ObjectParameterError: Parameter "filter" to find() must be an object, got nonsense)
GeneralError: Database error
at MyModel.<anonymous> ({path}\src\core\models\MyModel.ts:65:19)
at Generator.throw (<anonymous>)
at rejected ({path}\src\core\models\MyModel.ts:5:65)
at process._tickCallback (internal/process/next_tick.js:68:7)
if you call .toString()
on the error object in the error handler (or if you use our ErrorHandler class).
You can import the error handler function:
import { handleError } from "@golemio/errors";
The handle function provides a central point for error handling in your application. It logs the error, kills the application if it's unknown or fatal (programmer) error. Returns "API response ready" object if it's a known expected error with one of the standard HTTP codes.
You can use it:
try {
await functionThatThrowsError(); // Can throw our Error class
await jsBuiltInFunction(); // Can throw a native built-in JavaScript Error
} catch (err) { // Catches everything
handleError(err); // Handles everything
}
or for example in Express error handler route
// Error handler to catch all errors sent by routers (propagated through next(err))
this.express.use((err: any, req: Request, res: Response, next: NextFunction) => {
handleError(err).then((error) => {
if (error) {
log.silly("Error caught by the router error handler.");
res.status(error.status || 500).send(error);
}
});
});
and the result can be i.e.:
{
error_message: "Not Found.",
error_status: 404
}
or in development environment (NODE_ENV set to "development"):
{
"error_message": "Not Found.",
"error_status": 404,
"error_stack": "GeneralError: Id `nonsense` not found\n
at MyModel.<anonymous> ({path}y\\dist\\core\\models\\MyModel.js:116:23)\n
at Generator.next (<anonymous>)\n
at fulfilled ({path}\\dist\\core\\models\\MyModel.js:4:58)\n
at process._tickCallback (internal/process/next_tick.js:68:7)"
}
Logging uses provided logger (as an argument) for standard logging with levels and debug
(https://www.npmjs.com/package/debug) for debugging.
You can set both LOG_LEVEL
and DEBUG
settings in ENV variables.
For generating documentation run npm run generate-docs
. TypeDoc source code documentation is located in docs/typedoc
.
Please read CONTRIBUTING.md
.
Contact benak@operatorict.cz or vycpalek@operatorict.cz
FAQs
Library of Error classes of the Golemio Data Platform System
We found that @golemio/errors demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 5 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.