Extension for SPADE to integrate Large Language Models in agents
Project description
SPADE-LLM: Large Language Model Integration for Multi-Agent Systems
SPADE-LLM is a Python framework that extends SPADE multi-agent platform with Large Language Model capabilities. Build AI agents powered by OpenAI GPT, Ollama, LM Studio, and other LLM providers for multi-agent systems, with communication via XMPP for distributed AI applications.
Keywords: SPADE, LLM, large language models, multi-agent systems, AI agents, OpenAI, GPT, Ollama, chatbot framework, distributed AI, Python AI, agent communication, XMPP agents, AI collaboration
Table of Contents
- SPADE-LLM: Large Language Model Integration for Multi-Agent Systems
Key Features
- Built-in XMPP Server - No external server setup needed! Start agents with one command
- Multi-LLM Provider Support - Integrate OpenAI models, Ollama local models, LM Studio and more via LiteLLM
- RAG System - Retrieval-Augmented Generation with document loading, text splitting, and vector store retrieval (ChromaDB)
- Structured Outputs - Type-safe LLM responses using Pydantic models; define the schema, get back structured data
- Coordinator Agents - LLM-driven orchestration of SPADE subagents with shared context and automatic routing
- Advanced Tool System - Function calling, async execution, LangChain tool integration, custom tool development
- Smart Context Management - Multi-conversation support, automatic cleanup, sliding window, token-aware context
- Persistent Memory - Agent-based memory, conversation threading, long-term state persistence across sessions
- Intelligent Message Routing - Conditional routing based on LLM responses, dynamic agent selection
- Content Safety Guardrails - Input/output filtering, keyword blocking, content moderation, safety controls
- MCP Integration - Model Context Protocol server support for external tools and services
- Human-in-the-Loop - Web interface for human expert consultation, interactive decision making
Installation instructions
Requirements
- Python 3.11+
- (recommended)
uvinstallation for environment management
Install
# Install with uv (recommended)
uv pip install spade_llm
# Or install with pip
pip install spade_llm
# If working on a project with uv
uv add spade_llm
For optional features:
# RAG support with ChromaDB
pip install spade_llm[chroma] # or: uv add spade_llm --extra chroma
# LangChain tool integration
pip install spade_llm[langchain] # or: uv add spade_llm --extra langchain
Built-in XMPP Server
SPADE 4+ includes a built-in XMPP server, eliminating the need for external server setup. This is a major advantage over other multi-agent frameworks like AutoGen or Swarm that require complex infrastructure configuration.
Start the Server
# Start SPADE's built-in XMPP server
spade run
The server automatically handles:
- Agent registration and authentication
- Message routing between agents
- Connection management
- Domain resolution
Agents automatically connect to the built-in server when using standard SPADE agent configuration.
Quick Start
Get started with SPADE-LLM in just 2 steps:
Step 1: Start the Built-in XMPP Server
# Terminal 1: Start SPADE's built-in server
spade run
Step 2: Create and Run Your LLM Agent
# your_agent.py
import spade
from spade_llm import LLMAgent, LLMProvider
async def main():
provider = LLMProvider(
model="gpt-5-nano",
api_key="your-api-key",
)
agent = LLMAgent(
jid="assistant@localhost", # Connects to built-in server
password="password",
provider=provider,
system_prompt="You are a helpful assistant"
)
await agent.start()
if __name__ == "__main__":
spade.run(main())
# Terminal 2: Run your agent
python your_agent.py
Examples
Multi-Provider Support
# OpenAI
provider = LLMProvider(model="gpt-5-nano", api_key="key")
# Ollama (local)
provider = LLMProvider(model="ollama/llama3.1:8b")
# Any OpenAI-compatible API (LM Studio, vLLM, etc.)
provider = LLMProvider(model="openai/local-model", base_url="http://localhost:1234/v1")
Tools and Function Calling
from spade_llm import LLMTool
async def get_weather(city: str) -> str:
return f"Weather in {city}: 22°C, sunny"
weather_tool = LLMTool(
name="get_weather",
description="Get weather for a city",
parameters={
"type": "object",
"properties": {"city": {"type": "string"}},
"required": ["city"]
},
func=get_weather
)
agent = LLMAgent(
jid="assistant@localhost", # Uses built-in server
password="password",
provider=provider,
tools=[weather_tool]
)
Structured Outputs
from pydantic import BaseModel
from spade_llm import LLMAgent, LLMProvider
class WeatherReport(BaseModel):
city: str
temperature: float
conditions: str
provider = LLMProvider(model="gpt-5-nano", api_key="key")
agent = LLMAgent(
jid="weather@localhost",
password="password",
provider=provider,
system_prompt="Extract weather information",
output_schema=WeatherReport,
)
RAG (Retrieval-Augmented Generation)
from spade_llm import RetrievalAgent, LLMProvider
from spade_llm.rag import DirectoryLoader, RecursiveCharacterTextSplitter, ChromaVectorStore, VectorStoreRetriever
# Load, split, and index documents
loader = DirectoryLoader("./docs")
splitter = RecursiveCharacterTextSplitter(chunk_size=500)
docs = splitter.split_documents(loader.load())
store = ChromaVectorStore(collection_name="my_docs")
await store.add_documents(docs)
retriever = VectorStoreRetriever(vector_store=store)
agent = RetrievalAgent(
jid="rag@localhost",
password="password",
provider=LLMProvider(model="gpt-5-nano", api_key="key"),
retriever=retriever,
)
Documentation
- Installation - Setup and requirements
- Quick Start - Basic usage examples
- Providers - LLM provider configuration
- Tools - Function calling system
- RAG - Retrieval-Augmented Generation
- Structured Outputs - Type-safe LLM responses
- Guardrails - Content filtering and safety
- API Reference - Complete API documentation
Contributing
See Contributing Guide.
License
MIT License
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file spade_llm-0.3.0.tar.gz.
File metadata
- Download URL: spade_llm-0.3.0.tar.gz
- Upload date:
- Size: 82.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e4eea08b183209f22b5225a01cefe299200ca9bb86c9dcaae68ebe51d0cf00bb
|
|
| MD5 |
a93c3baa68a04309ff6a838154d78cbb
|
|
| BLAKE2b-256 |
a402936e2e995e9d4c5a26634994b84a0a1ab96afe9e511b6f3df459320ad99e
|
Provenance
The following attestation bundles were made for spade_llm-0.3.0.tar.gz:
Publisher:
publish.yml on javipalanca/spade_llm
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
spade_llm-0.3.0.tar.gz -
Subject digest:
e4eea08b183209f22b5225a01cefe299200ca9bb86c9dcaae68ebe51d0cf00bb - Sigstore transparency entry: 1205932288
- Sigstore integration time:
-
Permalink:
javipalanca/spade_llm@d891b93207317d6dae5109b79222d2c430a56dba -
Branch / Tag:
refs/tags/v0.3.0 - Owner: https://github.com/javipalanca
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@d891b93207317d6dae5109b79222d2c430a56dba -
Trigger Event:
release
-
Statement type:
File details
Details for the file spade_llm-0.3.0-py3-none-any.whl.
File metadata
- Download URL: spade_llm-0.3.0-py3-none-any.whl
- Upload date:
- Size: 117.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c9376427b435bc195beb738f95d11d99487dc1b1c7c667eab1790da93265d509
|
|
| MD5 |
539fb6cbcc421d9d8fea440f6312cb84
|
|
| BLAKE2b-256 |
762b2d9ce4a87f7b3eb74635a99c5d6213c2cce049227c661435d8f629f86d5f
|
Provenance
The following attestation bundles were made for spade_llm-0.3.0-py3-none-any.whl:
Publisher:
publish.yml on javipalanca/spade_llm
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
spade_llm-0.3.0-py3-none-any.whl -
Subject digest:
c9376427b435bc195beb738f95d11d99487dc1b1c7c667eab1790da93265d509 - Sigstore transparency entry: 1205932294
- Sigstore integration time:
-
Permalink:
javipalanca/spade_llm@d891b93207317d6dae5109b79222d2c430a56dba -
Branch / Tag:
refs/tags/v0.3.0 - Owner: https://github.com/javipalanca
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@d891b93207317d6dae5109b79222d2c430a56dba -
Trigger Event:
release
-
Statement type: