Skip to main content

Production-ready AI framework for building LLM-powered applications with unified tool calling across multiple providers

Reason this release was yanked:

Security issue

Project description

Orchestral

Orchestral

AI agent framework with unified tool calling across multiple LLM providers


Features

  • Web-based conversation interface with persistence
  • Support for Anthropic (Claude), OpenAI (GPT), and Google (Gemini)
  • Extensible tool system for file operations, code execution, and web search
  • Real-time streaming responses with cost tracking
  • Conversation management (rename, duplicate, delete, undo)

Quick Start

Prerequisites

  • Python 3.12 or higher
  • OpenAI API key (required for core functions)
  • Additional provider keys optional (Anthropic, Google)

Installation

Mac/Linux:

git clone https://github.com/orchestralAI/orchestral-core.git
cd orchestral-core
./setup.sh

Windows:

git clone https://github.com/orchestralAI/orchestral-core.git
cd orchestral-core
setup.bat

The setup script will install dependencies and prompt you to configure API keys interactively.

Running the App

Activate the virtual environment:

source orchestral-env/bin/activate  # Mac/Linux
orchestral-env\Scripts\activate     # Windows

Start the web interface:

python demos/app_demo.py

The app will open at http://127.0.0.1:8000

!! NOTE: By default the agents have the ability to execute code on your computer

API Keys

The setup script will guide you through adding API keys. You can also edit .env manually:

OPENAI_API_KEY=sk-proj-...        # Required
ANTHROPIC_API_KEY=sk-ant-...      # Optional
GOOGLE_API_KEY=AIza...            # Optional

Get your keys:

Using the Interface

  • Send messages - Type and press Enter (Shift+Enter for new line)
  • New conversation - Click "+" in sidebar
  • Manage conversations - Click "⋯" to rename, duplicate, or delete
  • Track costs - Click "Cost" button
  • Undo - Remove last message
  • Interrupt - Press Esc while agent is processing

Available Tools

  • RunCommandTool - Execute shell commands
  • RunPythonTool - Run Python code
  • WriteFileTool - Create and modify files
  • ReadFileTool - Read file contents
  • WebSearchTool - Search the web

File operations are scoped to app/workspace/ for safety.

Project Structure

orchestral_core/
├── orchestral/              # Core framework
│   ├── agent/              # Agent orchestration
│   ├── llm/                # LLM provider clients
│   ├── tools/              # Tool system
│   └── ui/                 # UI components
├── app/                    # Web application
│   ├── server.py           # Web server
│   ├── workspace/          # Agent workspace
│   └── conversations/      # Saved conversations
└── demos/                  # Demo scripts

Documentation

Troubleshooting

Module not found:

cd orchestral_core && pip install -e .

API key errors:

  • Verify .env exists and contains your keys
  • Check for extra spaces or quotes

Port 8000 in use: Edit demos/app_demo.py and change the port number

Windows activation issues:

Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser

License

All code contained in this repository is the property of Orchestral AI. Unauthorized reproduction, use, or distribution of this code, in whole or in part, is strictly prohibited without prior written permission from Alex Roman or an authorized representative of Orchestral AI.

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

orchestral_sdk-0.2.1-py3-none-any.whl (436.6 kB view details)

Uploaded Python 3

File details

Details for the file orchestral_sdk-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: orchestral_sdk-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 436.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.2

File hashes

Hashes for orchestral_sdk-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b2ab11ddd868947e003e536de70e4863f5c0f56270479f2ad90f5185a6814958
MD5 75e898e142e01b1b653c3d6f64bd3f72
BLAKE2b-256 ae3cc44851b23d44279d4f04aa55987d7046fda0d06eadfd492100feb376215a

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