Skip to content

An open and fair framework for everyone to build AI agents equipped with powerful skills. Launch your agent, improve the world, your wallet, or both!

License

Notifications You must be signed in to change notification settings

crestalnetwork/intentkit

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

IntentKit

IntentKit is an autonomous agent framework that enables the creation and management of AI agents with various capabilities including blockchain interactions, social media management, and custom skill integration.

Alpha Warning

This project is currently in alpha stage and is not recommended for production use.

Features

  • πŸ€– Multiple Agent Support
  • πŸ”„ Autonomous Agent Management
  • πŸ”— Blockchain Integration (EVM for now, will add more)
  • 🐦 Social Media Integration (Twitter, Telegram for now, will add more)
  • πŸ› οΈ Extensible Skill System
  • πŸ”Œ Extensible Plugin System (WIP)

Architecture

                                                                                                       
                                 Entrypoints                                                           
                       β”‚                             β”‚                                                 
                       β”‚   Twitter/Telegram & more   β”‚                                                 
                       β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                                 
                                      β”‚                                                                
  Storage:  ────┐                     β”‚                      β”Œβ”€β”€β”€β”€ Skills:                             
                β”‚                     β”‚                      β”‚                                         
  Agent Config  β”‚     β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β–Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”     β”‚  Chain Integration (EVM,solana,etc...)  
                β”‚     β”‚                                β”‚     β”‚                                         
  Credentials   β”‚     β”‚                                β”‚     β”‚  Wallet Management                      
                β”‚     β”‚           The  Agent           β”‚     β”‚                                         
  Personality   β”‚     β”‚                                β”‚     β”‚  On-Chain Actions                       
                β”‚     β”‚                                β”‚     β”‚                                         
  Memory        β”‚     β”‚      Powered by LangGraph      β”‚     β”‚  Internet Search                        
                β”‚     β”‚                                β”‚     β”‚                                         
  Skill State   β”‚     β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜     β”‚  Image Processing                       
            β”€β”€β”€β”€β”˜                                            └────                                     
                                                                                                       
                                                                More and More...                       
                         β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                                  
                         β”‚                          β”‚                                                  
                         β”‚  Agent Config & Memory   β”‚                                                  
                         β”‚                          β”‚                                                  
                         β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                                  
                                                                                                       

The architecture is a simplified view, and more details can be found in the Architecture section.

Quick Start

Docker (Recommended)

  1. Create a new directory and navigate into it:
mkdir intentkit && cd intentkit
  1. Download the required files:
# Download docker-compose.yml
curl -O https://raw.githubusercontent.com/crestalnetwork/intentkit/main/docker-compose.yml

# Download example environment file
curl -O https://raw.githubusercontent.com/crestalnetwork/intentkit/main/example.env
  1. Set up environment:
# Rename example.env to .env
mv example.env .env

# Edit .env file and add your configuration
# Make sure to set OPENAI_API_KEY
  1. Start the services:
docker compose up
  1. Create your first Agent:
curl -X POST http://127.0.0.1:8000/agents \
     -H "Content-Type: application/json" \
     -d '{
         "id": "admin",
         "name": "Admin",
         "prompt": "You are an autonomous AI agent. Respond to user queries."
     }'

There are many fields that can control the agent's behavior, we have provided a helper shell for you.

  1. Try it out:
curl "http://127.0.0.1:8000/admin/chat?q=Hello"

In terminal, curl cannot auto escape special characters, so you can use browser to test. Just copy the URL to your browser, replace "Hello" with your words.

Local Development

  1. Clone the repository:
git clone https://github.com/crestalnetwork/intentkit.git
cd intentkit
  1. Set up your environment: Python 3.10-3.12 are supported versions, and it's recommended to use 3.12. If you haven't installed poetry, please install it first. We recommend manually creating a venv; otherwise, the venv created automatically by Poetry may not meet your needs.
python3.12 -m venv .venv
source .venv/bin/activate
poetry install --with dev
  1. Configure your environment:
cp example.env .env
# Edit .env with your configuration
  1. Run the application:
# Run the API server in development mode
uvicorn app.api:app --reload

# Run the autonomous agent scheduler
python -m app.autonomous

"Create Agent" and "Try it out" refer to the Docker section.

Integrations

Twitter

Twitter Integration

Coinbase

Coinbase Integration

Configuration

The application can be configured using environment variables or AWS Secrets Manager. Key configuration options:

  • ENV: Environment (local or others)
  • DB_*: PostgreSQL Database configuration (Required)
  • OPENAI_API_KEY: OpenAI API key for agent interactions (Required)
  • CDP_*: Coinbase Developer Platform configuration (Optional)

See example.env for all available options.

Project Structure

  • abstracts/: Abstract classes and interfaces
  • app/: Core application code
    • core/: Core modules
    • services/: Services
    • entrypoints/: Entrypoints means the way to interact with the agent
    • admin/: Admin logic
    • config/: Configurations
    • api.py: REST API server
    • autonomous.py: Autonomous agent scheduler
    • twitter.py: Twitter listener
    • telegram.py: Telegram listener
  • models/: Database models
  • skills/: Skill implementations
  • skill_sets/: Predefined skill set collections
  • plugins/: Reserved for Plugin implementations
  • utils/: Utility functions

Contributing

Contributions are welcome! Please read our Contributing Guidelines before submitting a pull request.

Contribute Skills

If you want to add a skill collection, follow these steps:

  1. Create a new skill collection in the skills/ directory
  2. Implement the skill interface
  3. Register the skill in skills/YOUR_SKILL_COLLECTION/__init__.py

If you want to add a simple skill, follow these steps:

  1. Create a new skill in the skills/common/ directory
  2. Register the skill in skills/common/__init__.py

See the Skill Development Guide for more information.

License

This project is licensed under the MIT License - see the LICENSE file for details.