Skip to main content

AI-powered email processing and CRM automation

Project description

CRM Automator: Modular Agentic CRM Toolkit

Author: Trung Le
Team: RealTimeX.ai
Repository: https://github.com/therealtimex/crm-automator


Overview

The CRM Automator is a modular, agentic toolkit designed to transform unstructured data (emails, transcripts, documents) into structured CRM records. Unlike monolithic automation scripts, this toolkit is built as a collection of reusable Tools that can be orchestrated by AI agents or run as standalone pipelines.

Current Status: Production-Ready (v2.0)

Key Features

  • 🧩 Modular Architecture: Decoupled Ingestion (EML/Text), Intelligence (LLM Extraction), and Integration (CRM Sync).
  • 🤖 Agent-Ready: Components like IntelligenceLayer and RealTimeXClient are designed to be imported as tools for frameworks like LangChain or Autogen.
  • 🛡️ Idempotent & Safe: Implements "Search-before-Update" patterns and SQLite-based state tracking to prevent duplicate records.
  • 🧹 Smart Cleaning Pipeline: Automatically converts bloaty HTML into clean Markdown, strips noise, and resolves tracking links (e.g., unwraps Proofpoint/Safelinks and resolves HubSpot redirects) to ensure accurate URL extraction.
  • 🧠 OpenAI-Compatible: Works independently with OpenAI, Anthropic, or local LLMs (via LM Studio/Ollama) using instructor.

Installation

  1. Clone the repository:

    git clone https://github.com/therealtimex/crm-automator.git
    cd crm-automator
    
  2. Install dependencies:

    # Option A: Standard pip
    pip install -r requirements.txt
    
    # Option B: Modern uv (Recommended)
    uv sync
    
  3. Configure environment:

    cp .env.example .env
    # Edit .env with your CRM and LLM credentials
    

Usage

1. Process Emails (.eml)

Run the automator on a single EML file or an entire directory recursively.

Using uvx (Fastest, zero-install):

uvx eml/eml_automator.py "path/to/email.eml" --env-file ".env"

Using a directory:

uv run python eml/eml_automator.py "path/to/directory" --env-file ".env"

Options:

  • --force, -f: Force re-processing of an email even if it was already synced.
  • --verbose, -v: Enable debug logs to see HTTP requests and LLM thought process.

2. Generic Agent Demo

See how the toolkit handles raw text (e.g., meeting transcripts):

python3 eml/agent_demo.py --api-key "your_key"

Architecture

graph TD
    Ingest[Ingestion Layer] --> Intelligence[Intelligence Layer]
    Intelligence <--> Search[Web Search Tool]
    Intelligence --> Client[CRM Client]
    Client --> CRM[(RealTimeX CRM)]
  • crm_client.py: The "hands" – handles all API calls with retries and 10s timeouts.
  • intelligence.py: The "brain" – uses Pydantic models to extract structured data from text.
  • persistence.py: The "memory" – prevents processing the same resource twice.

Built with ❤️ by the RealTimeX.ai Team

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

crm_automator-1.9.3.tar.gz (20.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

crm_automator-1.9.3-py3-none-any.whl (22.5 kB view details)

Uploaded Python 3

File details

Details for the file crm_automator-1.9.3.tar.gz.

File metadata

  • Download URL: crm_automator-1.9.3.tar.gz
  • Upload date:
  • Size: 20.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.19

File hashes

Hashes for crm_automator-1.9.3.tar.gz
Algorithm Hash digest
SHA256 294f64173b7754eeee11584723d3a5302e52fe3b4e1e236bc89a48fe7cb8e093
MD5 243a145df659f1d04d69e5ba60f4a5c0
BLAKE2b-256 7bbc4bb66b904710959ea2f678415fc2a87139dd48216ee703ac3cce09166dc0

See more details on using hashes here.

File details

Details for the file crm_automator-1.9.3-py3-none-any.whl.

File metadata

  • Download URL: crm_automator-1.9.3-py3-none-any.whl
  • Upload date:
  • Size: 22.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.19

File hashes

Hashes for crm_automator-1.9.3-py3-none-any.whl
Algorithm Hash digest
SHA256 45a9c7d8ac9b0b5a6728a24815e61d9fc6ab8b2cf981e55ddc2cca56bc888e6b
MD5 1c0420c0bd2a1c3afcb2b0029b0729bf
BLAKE2b-256 1dc4e1aaa1472cb0aec95da638d47b84f0a853109b775ff3f4db7c8e26d7d277

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page