Skip to main content

A tool for orchestrating Swarm using both CLI and API.

Project description

Open-Swarm Update - 20250328

This project is now repurposed due to OpenAI officially supporting the Swarm framework under the new name "openai-agents(-python)".

Open-swarm now utilizes the openai-agents framework for enhanced capabilities, and the MCP logic has been offloaded to the openai-agents framework.

Key focus areas of this open-swarm framework include:

  • Blueprints: A blueprint can be converted into an OpenAI-compatible REST endpoint (analogous to /v1/chat/completions, but with agents) and/or into CLI utilities on the shell.
  • Config Loader: Blueprints and configuration management form a core aspect of the project.

Installation:

Open-swarm is available via PyPI. To install, run:

pip install open-swarm

Usage:

In development, after cloning the repository (github.com/matthewhand/open-swarm), you can run a blueprint directly with:

uv run blueprints/mcp_demo/blueprint_mcp_demo.py

To run the blueprint with a specific instruction (for example, to list its tools), execute:

uv run blueprints/mcp_demo/blueprint_mcp_demo.py --instruction "list your tools"

Alternatively, you can run the blueprint as an API endpoint using the swarm-api utility:

swarm-api --blueprint mcp_demo

In production, you can use the swarm-cli utility to manage and run blueprints. For example, to add an example blueprint:

swarm-cli add github:matthewhand/open-swarm/blueprints/mcp_demo

This command saves the blueprint to:

~/.swarm/blueprints/mcp_demo/

After adding the blueprint, you can convert it into a standalone CLI utility with:

swarm-cli install mcp_demo

Building a Basic Blueprint & Config File:

You can create your own blueprint to extend open-swarm's capabilities. Here is a walkthrough:

  1. Create a Blueprint File:

    • In the blueprints/ directory, create a new Python file, for example blueprints/my_blueprint.py.
    • Define a new class that inherits from BlueprintBase and implement the required abstract methods, such as metadata and create_agents(). For instance:
      from swarm.extensions.blueprint.blueprint_base import BlueprintBase
      
      class MyBlueprint(BlueprintBase):
          @property
          def metadata(self):
              return {
                  "title": "MyBlueprint",
                  "env_vars": [],
                  "required_mcp_servers": [],
                  "max_context_tokens": 8000,
                  "max_context_messages": 50
              }
      
          def create_agents(self):
              # Create and return agents as a dictionary.
              return {"MyAgent": ...}  # Implement your agent creation logic here.
      
      if __name__ == "__main__":
          MyBlueprint.main()
      
  2. Create a Configuration File:

    • Create a configuration file (e.g., swarm_config.json) at the root of the project. This file can include settings for LLM models and MCP servers. For example:
      {
        "llm": {
          "default": {
            "provider": "openai",
            "model": "gpt-4",
            "api_key": "your-openai-api-key",
            "base_url": null
          }
        },
        "mcpServers": {
          "mcp_llms_txt_server": {
            "command": "echo",
            "args": [],
            "env": {}
          },
          "everything_server": {
            "command": "echo",
            "args": [],
            "env": {}
          }
        }
      }
      
  3. Running Your Blueprint:

    • To run your blueprint in development mode, use:
      uv run blueprints/my_blueprint.py
      
    • Ensure your configuration file is properly loaded by your blueprint (this might require modifications in your blueprint's initialization logic or passing a --config parameter).

Installation & Deployment via swarm-cli:

After creating your blueprint and config file, you can manage it with the swarm-cli utility. For example:

  • Adding your blueprint:
    swarm-cli add github:matthewhand/open-swarm/blueprints/my_blueprint
    
  • Installing as a standalone CLI utility:
    swarm-cli install my_blueprint
    

Examples:

Blueprint "mcp_demo":

The blueprint located in blueprints/mcp_demo demonstrates a key design principle:

  • It creates a primary agent named Sage that leverages the MCP framework to incorporate external capabilities.
  • Sage uses another agent, Explorer, as a tool to extend its functionality.

This hierarchical agent design illustrates how blueprints can compose agents that call on subagents as tools. This model serves as a prototype for creating powerful agent-driven workflows and can be deployed both as a REST endpoint and as a CLI tool.

Production Environment:

After installing the package via pip, you can manage blueprints with swarm-cli and launch them as standalone utilities or REST services.

For help with swarm-cli:

swarm-cli --help

For help with swarm-api:

swarm-api --help

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

open_swarm-0.1.1748636259.tar.gz (117.6 kB view details)

Uploaded Source

Built Distribution

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

open_swarm-0.1.1748636259-py3-none-any.whl (110.9 kB view details)

Uploaded Python 3

File details

Details for the file open_swarm-0.1.1748636259.tar.gz.

File metadata

  • Download URL: open_swarm-0.1.1748636259.tar.gz
  • Upload date:
  • Size: 117.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for open_swarm-0.1.1748636259.tar.gz
Algorithm Hash digest
SHA256 79a727cce3bc8bdbbac49aecd917256172507fdc920db1286440745d410df071
MD5 fa72c93bd30f6d9a2a8a5052d85343b7
BLAKE2b-256 5647f579ab39ebae4d1db6e8244bc6091cccf7114add57c40ed8c4d693c817a1

See more details on using hashes here.

File details

Details for the file open_swarm-0.1.1748636259-py3-none-any.whl.

File metadata

File hashes

Hashes for open_swarm-0.1.1748636259-py3-none-any.whl
Algorithm Hash digest
SHA256 0fda747e9f6686d7dc9ab68d9bcb1a2d1bd05f2dd90e4db97fdeb765f514d031
MD5 f44b2694bdbe8d673d2fc1210a9030cc
BLAKE2b-256 611d8ed0e5350f7657b805c6d18aed0e62603c81f3d986df6962f4e0cdbe7f73

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