RgWebhook
is a Node.js library designed to simplify the creation and management of webhooks using Express. It provides functionalities to create a local server for handling webhooks and exposes them via tunneling services like ngrok
, tunnelmole
or localtunnel
.
Install the rgwebhook
package via npm:
npm install rgwebhook
const { startServer, createWebhook } = require('rgwebhook');
// Start the server using ngrok
startServer({ provider: 'ngrok', port: 3000 })
.then(() => {
console.log('Server started!');
})
.catch((err) => {
console.error('Error starting the server:', err);
});
try {
const { webhookInstance, webhookUrl } = createWebhook('uniqueWebhookID', { additionalData: 'optional' });
console.log('Webhook created with URL:', webhookUrl);
// Use webhookInstance to listen for events
webhookInstance.on('GET', (data) => {
console.log('Received GET request data:', data);
});
} catch (error) {
console.error('Error creating the webhook:', error);
}
Starts the Express server and exposes it using the specified tunneling service.
options
(Object): Configuration options for starting the server.provider
(String): The tunneling service provider (ngrok
ortunnelmole
orlocaltunnel
).port
(Number): The port on which the server will run.launchOptions
(Object, optional): Custom parameters to be passed to the respective provider on start.fastifyOptions
(Object, optional): Custom parameters to be passed to fastify on start.
Returns a Promise that resolves when the server is successfully started.
Creates a new webhook with a unique identifier and associated data.
webhookId
(String): A unique identifier for the webhook.data
(Object, optional): Additional data associated with the webhook.
Returns an object containing the webhook instance (EventEmitter
) and its URL.
- Ensure the server is started before creating webhooks.
- Implement error handling to manage potential exceptions.
- Consider securing your webhooks with authentication mechanisms in production environments.
Current version: 0.3.0