A scalable notification system built with Node.js and Express, utilizing Kafka for message handling and microservices architecture. The backend API pushes notification data to Kafka, which is then processed by dedicated consumers for email, SMS, and WhatsApp notifications.
Figure 1: Overview of the notification system architecture.
- Microservices Architecture: Ensures modularity and scalability.
- Unified API Endpoint: Send notifications via email, SMS, or WhatsApp using a single API.
- Kafka Integration: Manages and routes notification messages asynchronously.
- Dedicated Consumers: Separate consumers handle email, SMS, and WhatsApp notifications.
- Node.js: JavaScript runtime for server-side applications.
- Express: Web framework for API development.
- Kafka: Distributed streaming platform for managing messages.
- Brevo: Service provider for email notifications.
- Tailliwo: Service provider for SMS and WhatsApp messaging.
- Backend API: Exposes a single endpoint to receive notification requests and pushes notification data to Kafka.
- Kafka: Handles asynchronous message processing and routing.
- Consumers: Dedicated services for processing notifications:
- Email Consumer: Sends notifications via Brevo.
- SMS Consumer: Sends notifications via Tailliwo.
- WhatsApp Consumer: Sends notifications via Tailliwo.
- Node.js (v14.x or higher)
- Kafka (for local development or a Kafka cluster)
- Brevo and Tailliwo accounts
Method 1: Manual Installation
-
Clone the repository:
git clone https://github.com/mrsingh-rishi/notification-system.git cd notification-system
-
Install dependencies:
cd api npm install cd .. cd email-consumer npm install cd .. cd whatsapp-consumer npm install cd .. cd sms-consumer npm install cd ..
-
Configuration:
Rename the
.env.example
file inemail-consumer
,sms-consumer
, andwhatsapp-consumer
to.env
and update the necessary environment variables. -
Start Kafka:
Ensure Kafka is running on your local machine or use a Kafka cluster. For local development, follow the Kafka Quickstart.
-
Run the Prisma Migrate and Generate Commands:
npm run prisma:migrate npm run prisma:generate
-
Run the Backend API:
npm start
-
Seed the DB
npm run seed
-
Run Consumers:
Start each consumer to process notifications from Kafka:
cd email-consumer && npm run start cd sms-consumer && npm run start cd whatsapp-consumer && npm run start
Method 2: Docker Installation
-
Build Docker Images:
docker-compose build
-
Start the Application:
docker-compose up
This will start the backend API, email consumer, SMS consumer, WhatsApp consumer, and Kafka services. Ensure you have Docker installed on your system.
- Endpoint:
/api/notifications
- Method: POST
- Description: Sends a notification via the specified service (email, SMS, or WhatsApp).
- Request Body:
{ "userId": 1, "message": "Your notification message here" }