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.10.tar.gz (25.0 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.10-py3-none-any.whl (30.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: demiurg-0.1.10.tar.gz
  • Upload date:
  • Size: 25.0 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.10.tar.gz
Algorithm Hash digest
SHA256 a685921dbdcab2e5ef6ac1eedc24e340e78893aa554cf50f29a8caa6ae14f986
MD5 9f715ecaccb38ca9f0bd9044d7f7e9c9
BLAKE2b-256 7806162a6246f94cf0a55a17922ebfe5036bc276ac650abe54fae100c1a4a33f

See more details on using hashes here.

File details

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

File metadata

  • Download URL: demiurg-0.1.10-py3-none-any.whl
  • Upload date:
  • Size: 30.5 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.10-py3-none-any.whl
Algorithm Hash digest
SHA256 5d0fd0290a15f5640bdba8216685d5f4ffb0c2746086501888d3a5e42e8ec664
MD5 6755dcbbf371e753cbaf104b2d1fbbfc
BLAKE2b-256 31913bdcc7dba45d20be24c66ced0765df948998f5ff96ac72141100aeb86517

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