I'm working hard to release version 1.0.0 with numerous features like realtime logs streaming, system performance & network monitoring, etc. please let me know if you encounter any issues or glitches in the meantime.
Bug-Hunter is a robust error reporting & cluster monitoring solution tailored for Node.js applications. It seamlessly captures uncaught exceptions, providing in-depth insights through detailed error stacks and contextual code snippets. With configurable reporting options, including email and logging, Bug-Hunter ensures effective monitoring and prompt debugging for enhanced application stability.
- Features
- ToDo
- Comparison with pm2
- Anatomy
- Before You Begin
- Installation
Hunter
Class APIs Reference- Usage And Examples
- About Project Backend
- License
- Code of Conduct
- Contributing
- Author
- Realtime Error Tracking: Uses
process
object to listen for any uncaught or rejected promise exceptions in realtime. - Automatic Bug Reporting: Quickly reports issue to application owner via Email and/or Log.
- Flexible Configuration: Customize the error reporting behavior with configurable
HunterConfig
options. - Detailed Context: Provides detailed stack-trace and code-context to help you quickly understand and debug issues.
- Cluster Tracking: Track logs, Monitor system performance & Analyze your Node.js servers cluster in realtime.
- Very Simple Integration: Just 8 to 12 lines of code and you're ready to shoot all your application bugs.
-
Add HTML/Text type email sending logic with templates. -
Add feature to implement logging functionality. -
Add feature for magic-link email verification. -
Integrate Realtime monitoring dashboard. - Add system helth monitoring feature.
- Implement Custom metrics & actions.
Motivation & Idea of this project was taken from pm2 Plus
Feature | Bug Hunter | pm2 Plus Monitoring Service |
---|---|---|
Error Tracking | ✔️ | ✔️ |
Code Context | ✔️ | ✔️ |
Open Source | ✔️ (Full) | ✔️ (Partial) |
Realtime Monitoring Dashboard | ✔️ | ✔️ |
Reporting Options | Email & Log | Real-time Dashboard |
Flexibility | High | Moderate |
Data Handling | Automatic | Real-time Monitoring |
Cost | Open Source and Free | Paid |
Bug-Hunter application contains two frontend components accessible to user, the Web Component & the Package Component
It's the front face of Bug-Hunter and this is where you create your Controller account, track your servers cluster & monitor or control them remotely as and when you want, all for free!
It's programmed in vanilla TS along with HTML & CSS, Hunter-UI is where it's openly available on GitHub. You can find the production hosted web-app here.
It's the handling component of Bug-Hunter and this is what you use to link your server to your Controller account, allowing you to monitor it remotely from web interface anytime.
It's programmed in vanilla TS, this repository is all about the Package Component of Bug-Hunter itself, binary built package is hosted on npm.
As Bug-Hunter is providing cloud-services you need to have a Controller account & gain access to your API-Key to interact with our services, please follow these steps to get free API access. We are offering password-less authentication.
-
- Register or Login with your email.
-
- Navigate to the Keys section, copy the API key and proceed with next step.
Note: Complete API key is not displayed directly in console for security reasons, always use Copy button to copy it to the clipboard.
Install the package using
NPM:
npm install bug-hunter
Yarn:
yarn add bug-hunter
Hunter
class is the central component of the Bug-Hunter package, designed to capture and report uncaught exceptions, perform logging, and monitor systems in Node.js applications. Below is the API reference for the Hunter
class.
working
(boolean): Indicates whether the Hunter is actively engaged in system monitoring and error reporting.isKeyValid
(boolean): Reflects the validity of the provided API key after validation.
config
(HunterConfig): The configuration object for the Hunter instance.logConfig
(HunterLogConfig): The logging configuration object, if logging is enabled.
constructor(conf: HunterConfig)
: Initializes a new instance of theHunter
class with the provided configuration.
startHunting(): boolean
: Begins the error hunting process by attaching event listeners to the process object. Returnsfalse
if the process is already running.stopHunting()
: Stops the error hunting process by removing event listeners and disposing of resources.setLogging(enable: boolean, lconfig?: HunterLogConfig)
: Enables or disables local logging functionality based on theenable
flag and optionallconfig
logging configuration.
validateAPIKey(): Promise<string>
: Validates the API key and returns a message indicating the result.handleUncaughtException(err: Error)
: Handles uncaught exceptions by reporting them to the server and optionally logging them locally.handleUnhandledRejection(reason: {}, rejPromise: Promise<any>)
: Placeholder for handling unhandled rejections. Logic to be implemented.
on("key-status", (validated: boolean) => void)
: Emits an event indicating the status of the API key validation, ifvalidated
istrue
indicates successful validation & authorization of providedapiKey
.
Begin by importing the Hunter
class from the 'bug-hunter' module. Then proceed with initialization of the Hunter
class, providing an object of type HunterConfig
to the constructor. You can then start Bug-Hunter process as demonstrated in the example below.
Furthermore, if you wish to enable local logging functionality, you have the option of passing an object of type HunterLogConfig
to the setLogging
method of the Hunter
instance object, as illustrated in the following example.
import { Hunter } from 'bug-hunter'; // for ModuleJS configuaration
// Refer below this code snippet for more details on `HunterConfig`
const hunterConfig = {
apiKey: "caUMxA.#######:**********************", // Your API key
email: "user-name@provider.ext", // Email linked with your Controller account
appName: "My Server 1", // Give a descriptive name, purely for your reference
// More optional properties....
};
// Refer to `HunterLogConfig` section for more details
const logConfig = {
logDir: "/path/to/log-folder",
maxFileSizeMB: 5,
logType: "json",
}
const hunter = new Hunter(hunterConfig);
// Starting version 0.7.0 `Hunter` extends `EventEmitter`
hunter.on("key-status", (validated) => {
if (!validated) {
console.log("Key validation failed!");
return;
}
// Until this point in time any error that may originate will not be reported via email as API-Key was not yet authorized
console.log("Key validated!");
// Following code can throw unhandled errors....
let buggyObject = {
name: "John"
};
buggyObject.name(); // <== Oops! error occured (buggyObject.name is not a function)
// But don't worry `Hunter` process will immediately catch & notify you of this error in realtime
console.log("Hello, hi!"); // <= This will not get executed but your program can keep running if `quitOnError` is set to `false`
});
hunter.setLogging(true, logConfig); // By default local logging is disabled you need to enable it explicitly
hunter.startHunting(); // Start shooting bugs....
// Your potential program code goes here....
hunter.setLogging(false); // If you ever need to stop logging locally
hunter.stopHunting(); // To dispose off resources and stop `Hunter` process completely
You can use this module in CommonJS configuarations also like this
const { Hunter } = require("bug-hunter");
const hunter = new Hunter(hunterConfig);
// Rest of code is same as shown in the above example
Property | Type | Required | Default | Description |
---|---|---|---|---|
string | ✔️ | Email linked with your controller account | ||
apiKey | string | ✔️ | Your API key for service authentication | |
appName | string | ✔️ | Name of the application or server | |
enableRemoteMonitoring | boolean | ❌ | true | Enable your server to be monitored from Web UI |
includeCodeContext | boolean | ❌ | true | Include code context in error reports |
enableSourceMap | boolean | ❌ | false | Enable source mapping for code context |
quitOnError | boolean | ❌ | false | Quit application when error occurs |
cwdFilter | boolean | ❌ | false | Filter out stack entries outside CWD |
format | "html" or "text" | ❌ | "html" | Format in which you want to receive emails |
Refer types.ts for
HunterConfig
implementation
Property | Type | Required | Default | Description |
---|---|---|---|---|
logDir | string | ✔️ | Path where logs should be saved | |
maxFileSizeMB | number | ❌ | 10 | Maximum size for a single log file |
logType | "text" or "json" | ❌ | "text" | Format of log 'human-readable' or 'structured' |
Refer types.ts for
HunterLogConfig
implementation
Project's backend is developed in Typescript under NodeJS environment and is hosted on Cloudflare Worker, we utilize MailChannel's API to facilitate the transmission of emails via Cloudflare's IP in accordance with the duo partnership as discussed in this blog.
Currently, the backend remains proprietary; nevertheless I'm considering making it open-sourced in the near future. The HTML and Text templates used by the server to send email notifications are publicly available within this repository. You can locate them in the src/web directory.
This project is licensed under the MIT License. Please refer to the LICENSE file for more details.
We are committed to providing a friendly, safe, and welcoming environment for all, regardless of gender, sexual orientation, disability, ethnicity, or religion. Please review our Code of Conduct to understand the standards of behavior we expect from all participants in this project.
Contributions are welcome! To contribute, please follow these steps:
- Fork the repository.
- Create a new branch.
- Make your changes and commit them.
- Open a pull request with a detailed description of your changes.
Your contributions help improve the project and create a welcoming community for all developers.
If you encounter any issues with the project or have suggestions for improvements, please open an issue. We appreciate your feedback and involvement in enhancing the Bug Hunter experience!
- Rishabh Kumar
- LinkedIn Profile
- Contact via Email