Skip to main content

AI Agent Framework for building intelligent agents with multiple LLM providers

Project description

Demiurg

A flexible AI agent framework for building intelligent agents with support for multiple LLM providers.

Features

  • 🚀 Simple, minimal API for quick agent creation
  • 🔌 Support for multiple LLM providers (OpenAI, Anthropic, Google, etc.)
  • 📬 Built-in messaging system with conversation history
  • 📁 File handling capabilities (images, audio, text)
  • 🔧 Extensible tool system with Composio integration
  • 🏗️ Production-ready with built-in queue management
  • 🐳 Designed for both cloud and local container deployment

Installation

pip install demiurg

Quick Start

from demiurg import Agent

# Create an agent with default configuration
agent = Agent()

# Or customize your agent
agent = Agent(
    name="My Custom Agent",
    model="gpt-4",
    temperature=0.7,
    provider="openai"
)

Basic Usage

Sending Messages

from demiurg import send_text, send_file

# Send a text message
await send_text(conversation_id, "Hello from my agent!")

# Send a file
await send_file(conversation_id, "/path/to/file.png", caption="Check this out!")

Getting Conversation History

from demiurg import get_conversation_history

# Get formatted conversation history
messages = await get_conversation_history(
    conversation_id,
    limit=50,
    provider="openai"  # Format for specific LLM provider
)

Custom Agent Implementation

from demiurg import Agent

class MyAgent(Agent):
    def __init__(self):
        super().__init__(
            name="Helpful Assistant",
            model="gpt-4",
            system_prompt="You are a helpful AI assistant."
        )
    
    async def process_message(self, message, provider="openai"):
        # Add custom logic here
        response = await super().process_message(message, provider)
        return response

agent = MyAgent()

Environment Variables

The framework uses environment variables for configuration:

  • DEMIURG_BACKEND_URL: Backend API URL (default: http://backend:3000)
  • DEMIURG_AGENT_TOKEN: Authentication token
  • DEMIURG_AGENT_ID: Unique agent identifier
  • OPENAI_API_KEY: OpenAI API key (for OpenAI provider)
  • COMPOSIO_API_KEY: Composio API key (for tool integration)

Provider Support

Currently supported:

  • ✅ OpenAI (GPT-3.5, GPT-4, etc.)

Coming soon:

  • 🚧 Anthropic (Claude)
  • 🚧 Google (Gemini)
  • 🚧 Cohere
  • 🚧 Local models

Development

For development access and contribution guidelines, please contact support@demiurg.ai.

License

Copyright © 2024 Demiurg AI. All rights reserved.

This is proprietary software. See LICENSE file for details.

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

demiurg-0.1.12.tar.gz (27.2 kB view details)

Uploaded Source

Built Distribution

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

demiurg-0.1.12-py3-none-any.whl (32.8 kB view details)

Uploaded Python 3

File details

Details for the file demiurg-0.1.12.tar.gz.

File metadata

  • Download URL: demiurg-0.1.12.tar.gz
  • Upload date:
  • Size: 27.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.2

File hashes

Hashes for demiurg-0.1.12.tar.gz
Algorithm Hash digest
SHA256 bd78570032aba9c419ca51b42e669707a21150f3a6645b36b67f7c4b6980cb33
MD5 3dc181f2b554440aec25b3a63f34e62e
BLAKE2b-256 c613837a6011973dc6085d088b5689be5486181c75738dafba16cee62f13b8a7

See more details on using hashes here.

File details

Details for the file demiurg-0.1.12-py3-none-any.whl.

File metadata

  • Download URL: demiurg-0.1.12-py3-none-any.whl
  • Upload date:
  • Size: 32.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.2

File hashes

Hashes for demiurg-0.1.12-py3-none-any.whl
Algorithm Hash digest
SHA256 84be90ecdd786efb72d23a5ec68426cdd4528e48e7a7c93b9a2a30841212cd20
MD5 024cf80a6919dee33f800f561cdbc6c4
BLAKE2b-256 d286b1b3e24b11c1097032514f76f91474590c0c2dbaffba0a28a1130eea6a63

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