Skip to content

EmailEngine is a scalable and secure email synchronization tool seamlessly integrating with Outlook, leveraging Elasticsearch for efficient data management, with plans to support Yahoo, Gmail, and company-specific email services in the future.

License

Notifications You must be signed in to change notification settings

biswajitpanday/EmailEngine

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

EmailEngine

EmailEngine is an Email Synchronization Application.

Features

  • OAuth Integration: Seamless connection with Outlook, allowing users to securely link their email accounts.
  • Email Synchronization: Efficiently synchronize emails from Outlook, storing data in Elasticsearch.
  • Real-time Updates: Monitors and reflects changes in email status, including read/unread, status, moved emails, deletions etc.
  • Scalability: Designed to handle a large number of users and email accounts, supporting both horizontal and vertical scaling.
  • Extensibility: Easily extendable to support additional email providers in the future using standard protocols.
  • User-friendly Interface: Simple frontend for account management and real-time display of email synchronization status.
  • Secure Data Handling: Utilizes Elasticsearch for secure and efficient storage of email data, ensuring user information is protected.
  • Email Event Subscription: Subscribes to Outlook events using Microsoft Graph Client.
  • Environment Configuration: Supports both production and development environments using environment variables.
  • Docker Integration: Configured as an integrated system for streamlined operations.
  • Centralized Logger and Error Handler: Efficiently manages application logs and errors for improved debugging and monitoring.

Prerequisites

  • Node.js (v14 or higher)
  • Docker
  • Azure account access
  • Azure Admin privileges to register applications

Installation

  1. Clone the repository:

    git clone https://github.com/biswajitpanday/EmailEngine.git
    cd EmailEngine
  2. Set up environment variables:

    Create a .env file in the root directory and add the following variables:

    NODE_ENV=production [development | Production]   <Select production for Docker & development for debugging in local>
    CORS_ORIGIN=http://localhost:3001
    PORT=3000
    ELASTICSEARCH_HOST=http://host.docker.internal:9200
    ELASTICSEARCH_USERNAME=elastic
    ELASTICSEARCH_PASSWORD=<your_elasticsearch_password>
    OUTLOOK_CLIENT_ID=<outlook_client_id>
    OUTLOOK_CLIENT_SECRET=<outlook_client_secret>
    NGROK_AUTHTOKEN=<ngrok_auth_token>
  3. Build and start the Docker containers:

    npm run docker:up
  4. Stop and remove the Docker containers:

    npm run docker:down
  5. Clean up Docker resources:

    npm run docker:prune
  6. Reset Docker environment:

    Master Command. This will run => (npm run docker:down && npm run docker:prune && npm run docker:up)

    npm run docker:reset

How to Run

  • Hit the following Url on your browser and provide your microsoft credential and allow requested access.

    http://localhost:3001

Steps to Configure Azure

1. Register the Backend Application

  1. Navigate to App Registrations

    • Go to Azure portal.
    • Select "Azure Active Directory" > "App registrations".
    • Click "New registration".
  2. Application Details

    • Name: Choose a descriptive name for your BACKEND app
    • Supported account types: "Accounts in any organizational directory and personal Microsoft accounts".
    • Redirect URI: Leave empty for backend configuration.
    • Click "Register".
  3. Expose an API

    • In "Expose an API", set the Application ID URI to api://xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx.
    • Add a scope with:
      • Scope name: choose a scope name
      • Admin consent display name: "choose an admin consent display name"
      • User consent display name: "choose a user consent display name"
    • Click "Add scope".
  4. API Permissions

    • Under "API permissions", add the following Microsoft Graph permissions:
      • Mail.Read
      • Mail.ReadWrite
      • User.Read
    • Grant admin consent for these permissions.
  5. Generate Client Secret

    • Go to "Certificates & secrets" and create a new client secret.
    • Note down the secret value; it won't be visible again.

2. Register the Frontend Application

  1. Navigate to App Registrations

    • Go to Azure portal.
    • Select "Azure Active Directory" > "App registrations".
    • Click "New registration".
  2. Application Details

    • Name: Choose a descriptive name for your FRONTEND app
    • Supported account types: "Accounts in any organizational directory and personal Microsoft accounts".
    • Redirect URIs: Add http://localhost:3001/add-account for SPA and http://localhost:3000 for web.
    • Click "Register".
  3. Configure Authentication

    • Under "Authentication", enable "ID tokens" for single-page applications.
  4. API Permissions

    • Under "API permissions", add:
      • Microsoft Graph permissions:
        • Mail.Read
        • Mail.ReadWrite
        • User.Read
      • Access to the backend API (api://xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx):
        • Scope: Scope name you provided for the backend application
    • Grant admin consent for these permissions.
  5. Generate Client Secret

    • Go to "Certificates & secrets" and create a new client secret.
    • Note down the secret value; it won't be visible again.

3. Set Up Environment Variables

  • In your backend .env file, set the following variables:
    OUTLOOK_CLIENT_ID=<your_application_client_id>
    OUTLOOK_CLIENT_SECRET=<your_generated_client_secret>

FAQ

  1. How to obtain Ngrok Authtoken?

    To obtain Ngrok Authtoken please Login/Signup on Ngrok official site and find the menu Your Authtoken from the dashboard.

  2. How to browse Elasticsearch Database?

    Here's a Chrome Extension: https://chromewebstore.google.com/detail/elasticvue/hkedbapjpblbodpgbajblpnlpenaebaa?hl=en

Gitflow

For detailed information on managing Gitflow, please refer to the Gitflow documentation.

Acknowledgements