How to create your personal AI powered Email Assistant

From Idea to Implementation: Crafting an AI Powered Email Assistant with Semantic Kernel and Neon Serverless

AI Powered Email Assistant Heading Image

Intro

In the realm of Artificial Intelligence, crafting applications that seamlessly blend advanced capabilities with user-friendly design is no small feat. Today, we take you behind the scenes of building an AI Powered Email Assistant, a project that leverages Semantic Kernel for embedding generation and indexing, Neon PostgreSQL for vector storage, and the Azure OpenAI API for generative AI capabilities. This blog post is a practical guide to implementing a powerful AI-driven solution from scratch.

The Vision

Our AI Powered Email Assistant is designed to:

  • Draft emails automatically using input prompts.
  • Enable easy approval, editing, and sending via Microsoft Graph API.
  • Create and store embeddings of the Draft and Send emails in NEON Serverless PostgreSQL DB.
  • Provide a search feature to retrieve similar emails based on contextual embeddings.

This application combines cutting-edge AI technologies and modern web development practices, offering a seamless user experience for drafting and managing emails.

The Core Technologies of our AI Powered Email Assistant

1. Semantic Kernel

Semantic Kernel simplifies the integration of AI services into applications. It provides robust tools for text generation, embedding creation, and memory management. For our project, Semantic Kernel acts as the foundation for:

  • Generating email drafts via Azure OpenAI.
  • Creating embeddings for storing and retrieving contextual data.

2. Vector Indexing with Neon PostgreSQL

Neon, a serverless PostgreSQL solution, allows seamless storage and retrieval of embeddings using the pgvector extension. Its serverless nature ensures scalability and reliability, making it perfect for real-time AI applications.

3. Azure OpenAI API

With Azure OpenAI, the project harnesses models like gpt-4 and text-embedding-ada-002 for generative text and embedding creation. These APIs offer unparalleled flexibility and power for building AI-driven workflows.

How We Built our AI Powered Email Assistant

Step 1: Frontend – A React-Based Interface

The frontend, built in React, provides users with a sleek interface to:

  1. Input recipient details, subject, and email description.
  2. Generate email drafts with a single click.
  3. Approve, edit, and send emails directly.

We incorporated a loading spinner to enhance user feedback and search functionality for retrieving similar emails.

Key Features:

  • State Management: For handling draft generation and email sending.
  • API Integration: React fetch calls connect seamlessly to backend APIs.
  • Dynamic UI: A real-time experience for generating and reviewing drafts.

Step 2: Backend – Semantic Kernel and Vector Storage

The backend, powered by ASP.NET Core, uses Semantic Kernel for AI services and Neon for vector indexing. Key backend components include:

AI Powered Assistant - Backend Swagger
Swagger UI in /api/docs

Semantic Kernel Services:

  • Text Embedding Generation: Uses Azure OpenAI’s text-embedding-ada-002 to create embeddings for email content.
  • Draft Generation: The AI Powered Email Assistant creates email drafts based on user inputs using Azure OpenAI gpt-4 model (OpenAI Skill).
    public async Task<string> GenerateEmailDraftAsync(string subject, string description)
    {
        try
        {
            var chatCompletionService = _kernel.GetRequiredService<IChatCompletionService>();
            
            var message = new ChatMessageContent(
                AuthorRole.User,
                $"Draft a professional email with the following details:\nSubject: {subject}\nDescription: {description}"
            );

            var result = await chatCompletionService.GetChatMessageContentAsync(message.Content ?? string.Empty);
            return result?.Content ?? string.Empty;
        }
        catch (Exception ex)
        {
            throw new Exception($"Error generating email draft: {ex.Message}", ex);
        }
    }
}

Vector Indexing with Neon:

  • Embedding Storage: Stores embeddings in Neon using the pgvector extension.
  • Contextual Search: Retrieves similar emails by calculating vector similarity.

Email Sending via Microsoft Graph:

  • Enables sending emails directly through an authenticated Microsoft Graph API integration.

Key Backend Features:

  • Middleware for PIN Authentication: Adds a secure layer to ensure only authorized users access the application.
  • CORS Policies: Allow safe fronted-backend communication.
  • Swagger Documentation: The Swagger Docs that simplify API testing during development.

Step 3: Integration with Neon

The pgvector extension in Neon PostgreSQL facilitates efficient vector storage and similarity search. Here’s how we integrated Neon into the project:

  • Table Design: A dedicated table for embeddings with columns for subject, content,type, embedding, and created_at. The type column can hold 2 values draft or sent in case the users want to explore previous unsent drafts.
  • Index Optimization: Optimizing the index can save us a lot of time and effort before facing performance issues with CREATE INDEX ON embeddings USING ivfflat (embedding) WITH (lists = 100);
  • Search Implementation: Using SQL queries with vector operations to find the most relevant embeddings.
  • Enhanced Serverless Out-Of-the-box: Even the free SKU offers Read Replica and Autoscaling making it Enterprise-ready.
AI Powered Email Assistant - NEON Serverless Read replica
NEON Read Replica
AI Powered Email Assistant - NEON Serverless Autoscale
Autoscale

Sample from the EmbeddingService.cs

    public async Task<List<SearchResult>> SearchSimilarEmbeddingsAsync(List<float> queryEmbedding, int limit)
    {
        var results = new List<SearchResult>();

        using var connection = new NpgsqlConnection(_connectionString);
        await connection.OpenAsync();

        var sql = @"
            SELECT 
                input_text,
                1 - (embedding <=> @queryEmbedding::vector) as similarity
            FROM embeddings
            ORDER BY embedding <=> @queryEmbedding::vector
            LIMIT @limit";

Why This Approach Stands Out

  1. Efficiency: By storing embeddings instead of just raw data, the system maintains privacy while enabling rich contextual searches.
  2. Scalability: Leveraging Neon’s serverless capabilities ensures that the application can grow without bottlenecks. Autoscale is enabled
  3. User-Centric Design: The combination of React’s dynamic frontend and Semantic Kernel’s advanced AI delivers a polished user experience.
AI Powered Email Assistant - Architecture
Architecture

Step-by-Step Guide to create your own AI Powered Email Assistant

Prerequisites

  1. Azure Account with OpenAI access
  2. Microsoft 365 Developer Account
  3. NEON PostgreSQL Account
  4. .NET 8 SDK
  5. Node.js and npm
  6. Visual Studio Code or Visual Studio 2022

Step 1: Setting Up Azure Resources

  1. Azure OpenAI Setup:
    • Create an Azure OpenAI resource
    • Deploy two models:
      • GPT-4 for text generation
      • text-embedding-ada-002 for embeddings
    • Note down endpoint and API key
  2. Entra ID App Registration:
    • Create new App Registration
    • Required API Permissions:
      • Microsoft Graph: Mail.Send (Application)
      • Microsoft Graph: Mail.ReadWrite (Application)
    • Generate Client Secret
    • Note down Client ID and Tenant ID

Step 2: Database Setup

  1. NEON PostgreSQL:
    • Create a new project
    • Create database
    • Enable pgvector extension
    • Save connection string

Step 3: Backend Implementation (.NET)

Project Structure:

/Controllers
  - EmailController.cs (handles email operations)
  - HomeController.cs (root routing)
  - VectorSearchController.cs (similarity search)

/Services
  - EmailService.cs (Graph API integration)
  - SemanticKernelService.cs (AI operations)
  - VectorSearchService.cs (embedding operations)
  - OpenAISkill.cs (email generation)

Key Components:

  1. SemanticKernelService:
    • Initializes Semantic Kernel
    • Manages AI model connections
    • Handles prompt engineering
  2. EmailService:
    • Microsoft Graph API integration
    • Email sending functionality
    • Authentication management
  3. VectorSearchService:
    • Generates embeddings
    • Manages vector storage
    • Performs similarity searches

Step 5: Configuration

  • Create new dotnet project with: dotnet new webapi -n SemanticKernelEmailAssistant
  • Configure appsettings.json for your Connections.
  • Install Semantic Kernel ( Look into the SemanticKernelEmailAssistant.csproj for all packages and versions) – Versions are Important !
  • When all of your files are complete, then you can execute: dotnet build & dotnet publish -c Release
  • To test locally simply run dotnet run

Step 5: React Frontend

  • Start a new React App with: npx create-react-app ai-email-assistant
  • Change directory in the newly created
  • Copy all files from Git and run npm install
  • Initialize Tailwind npx tailwindcss init (if you see any related errors)

Step 6: Deploy to Azure

Both our Apps are Containerized with Docker, so pay attention to get the Dockerfile for each App.

Use: [ docker build -t backend . ] and tag and push: [ docker tag backend {acrname}.azurecr.io/backend:v1 ] , [ docker push {acrname}.azurecr.io/backend:v1 ]. The same applies for the Frontend. Make sure to login to Azure Container Registry with: az acr login --name $(az acr list -g myresourcegroup --query "[].{name: name}" -o tsv) We will be able to see our new Repo on Azure Container Registry and deploy our Web Apps :

AI Powered Email Assistant - Web Apps

Tagging allows us to use a variety of deployments and select which version we prefer from the Deployment Center Menu of Azure Web Apps

Tag Selection in Azure Web Apps

Troubleshooting and Maintenance

  1. Backend Issues:
    • Use Swagger (/docs) for API testing and debugging.
    • Check Azure Key Vault for PIN and credential updates.
  2. Embedding Errors:
    • Ensure pgvector is correctly configured in Neon PostgreSQL.
    • Verify the Azure OpenAI API key and endpoint are correct.
  3. Frontend Errors:
    • Use browser dev tools to debug fetch requests.
    • Ensure environment variables are correctly set during build and runtime.

Conclusion

In today’s rapidly evolving tech landscape, building an AI-powered application is no longer a daunting task, primarily thanks to groundbreaking technologies like Semantic Kernel, Neon PostgreSQL, and Azure OpenAI. Most importantly, this project clearly demonstrates how these powerful tools can seamlessly work together to deliver a robust, scalable, and user-friendly solution.

First and foremost, the integration of Semantic Kernel effectively streamlines AI orchestration and prompt management. Additionally, Neon PostgreSQL provides exceptional serverless database capabilities that automatically scale with your application’s needs. Furthermore, Azure OpenAI’s reliable API and advanced language models consistently ensure high-quality AI responses and content generation.

Moreover, whether you’re developing a customer service bot, content creation tool, or data analysis platform, this versatile technology stack offers the essential flexibility and power to bring your innovative ideas to life. Consequently, if you’re ready to create your own AI application, the powerful combination of Semantic Kernel and Neon serves as your ideal starting point. Above all, this robust foundation successfully balances sophisticated functionality with straightforward implementation, while simultaneously ensuring seamless scalability as your project continues to grow and evolve.

References

AI Powered Email Assistant Footer Image
AI Powered Email Assistant

Spread the word. Share this post!

Leave Comment