Python SDK for external integration with the unified-ui platform — tracing, streaming, agents, and more.
Project description
unified-ui SDK
Python SDK for external integration with the unified-ui platform — tracing, streaming, agents, and more!
What is unified-ui?
unified-ui transforms the complexity of managing multiple AI systems into a single, cohesive experience. Organizations deploy agents across diverse platforms — Microsoft Foundry, n8n, LangGraph, Copilot, and custom solutions — resulting in fragmented user experiences, inconsistent monitoring, and operational silos.
unified-ui eliminates these challenges by providing one interface where every agent converges.
What is this SDK?
The unified-ui SDK is a complementary Python package that provides capabilities for external integration with the unified-ui platform:
| Module | Description |
|---|---|
| 🔍 Tracing | Standardized tracing objects; LangChain & LangGraph trace sniffing and forwarding |
| 📡 Streaming | Standardized streaming response protocol for unified-ui |
| 🤖 Agents | ReACT Agent class with an agent engine built on LangChain / LangGraph |
| 🔧 Tools | Reusable tool clients (Microsoft 365 Graph API) for building AI agents |
| 🧱 Core | Shared interfaces, base classes, and utility functions |
How It Fits
┌─────────────┐ ┌──────────────────────────────────────────────┐
│ Frontend │────▶│ Platform Service (FastAPI) │
└─────────────┘ │ • Authentication & RBAC │
│ • Tenants, Applications, Credentials │
│ • Conversations, Autonomous Agents │
└──────────────────┬───────────────────────────┘
│
┌────────────────────────┼────────────────────────┐
▼ ▼ ▼
┌────────────────┐ ┌────────────────┐ ┌────────────────┐
│ Agent Service │ │ Custom Service │ │ External App │
│ (Go/Gin) │ │ │ │ │
└────────────────┘ └────────────────┘ └────────────────┘
│ │ │
│ ┌─────────┴──────────┐ │
│ │ unifiedui-sdk ◀───┼───────────┘
│ │ (this package) │
│ └────────────────────┘
▼
┌────────────────┐
│ AI Backends │
│ N8N, Foundry, │
│ LangGraph, ... │
└────────────────┘
Installation
pip install unifiedui-sdk
Or with uv:
uv add unifiedui-sdk
Quick Start
Tracing — Capture Traces from LangChain / LangGraph
from unifiedui_sdk.tracing import UnifiedUILanggraphTracer
tracer = UnifiedUILanggraphTracer()
# Attach to any LangChain/LangGraph execution
result = graph.invoke(
{"messages": [("human", "Hello")]},
config={"callbacks": [tracer]},
)
# Get the trace as a dict (camelCase JSON for the agent-service API)
trace_dict = tracer.get_trace_dict()
Streaming — Build SSE Responses
from unifiedui_sdk.streaming import StreamWriter, StreamMessageType
writer = StreamWriter()
# Build stream messages for the unified-ui SSE protocol
yield writer.stream_start()
yield writer.text_stream("Hello ")
yield writer.text_stream("world!")
yield writer.tool_call_start("tc_1", "search", {"query": "test"})
yield writer.tool_call_end("tc_1", "search", "success", tool_result="Found 3 results")
yield writer.stream_end()
Agents — Single-Agent with Tools
from langchain_openai import ChatOpenAI
from langchain_core.tools import tool
from unifiedui_sdk.agents import ReActAgentConfig, ReActAgentEngine
from unifiedui_sdk.tracing import ReActAgentTracer
@tool
def calculator(expression: str) -> str:
"""Evaluate a math expression."""
return str(eval(expression))
llm = ChatOpenAI(model="gpt-4o-mini", temperature=0.1)
config = ReActAgentConfig(system_prompt="You are a helpful assistant.")
tracer = ReActAgentTracer()
engine = ReActAgentEngine(
config=config, llm=llm, tools=[calculator], tracer=tracer
)
# Stream agent execution
async for msg in engine.invoke_stream("What is 42 * 17?"):
if msg.type == "TEXT_STREAM":
print(msg.content, end="", flush=True)
elif msg.type == "TOOL_CALL_START":
print(f"\nTool: {msg.config['tool_name']}")
elif msg.type == "TOOL_CALL_END":
print(f"Result: {msg.config['tool_result']}")
Agents — Multi-Agent Orchestration
from unifiedui_sdk.agents import ReActAgentConfig, ReActAgentEngine
from unifiedui_sdk.agents.config import MultiAgentConfig
from unifiedui_sdk.tracing import ReActAgentTracer
config = ReActAgentConfig(
system_prompt="You are a research assistant.",
multi_agent_enabled=True,
multi_agent=MultiAgentConfig(
max_sub_agents=5,
max_parallel_per_step=3,
),
)
tracer = ReActAgentTracer()
engine = ReActAgentEngine(config=config, llm=llm, tools=[...], tracer=tracer)
async for msg in engine.invoke_stream("Compare weather in Berlin, Munich, Hamburg"):
if msg.type == "PLAN_COMPLETE":
print("Plan:", msg.config["plan"]["goal"])
elif msg.type == "SUB_AGENT_STREAM":
print(msg.content, end="")
elif msg.type == "SYNTHESIS_STREAM":
print(msg.content, end="")
# Get the full trace
trace = tracer.get_trace()
Agents — Tool Loading (OpenAPI + MCP)
from unifiedui_sdk.agents.config import ToolConfig, ToolType, MCPTransport
from unifiedui_sdk.agents.tools.loader import load_tools
tool_configs = [
ToolConfig(
name="PetStore",
type=ToolType.OPENAPI_DEFINITION,
config={
"spec_url": "https://petstore3.swagger.io/api/v3/openapi.json",
"base_url": "https://petstore3.swagger.io/api/v3",
},
),
ToolConfig(
name="MCP Weather",
type=ToolType.MCP_SERVER,
config={
"url": "http://localhost:8080/sse",
"transport": MCPTransport.SSE,
},
),
]
tools = await load_tools(tool_configs)
engine = ReActAgentEngine(config=config, llm=llm, tools=tools)
Tools — Microsoft 365 Clients
pip install unifiedui-sdk[m365]
from unifiedui_sdk.tools.m365 import (
OutlookAPIClient,
OutlookAuthProvider,
OutlookCapability,
SendMessage,
)
auth = OutlookAuthProvider(
tenant_id="your-tenant-id",
client_id="your-client-id",
client_secret="your-client-secret",
)
client = OutlookAPIClient(
auth_provider=auth,
capabilities=[OutlookCapability.MAIL_READ, OutlookCapability.MAIL_SEND],
)
# Send email
client.messages.send(
user_id="me",
message=SendMessage(
to=["recipient@example.com"],
subject="Hello",
body="<p>Message from unified-ui agent</p>",
),
)
Detailed module documentation:
tracing/·streaming/·agents/·tools/·core/
Development
Prerequisites
- Python 3.13+
- uv (recommended)
Setup
# Clone the repository
git clone https://github.com/unified-ui/unifiedui-sdk.git
cd unifiedui-sdk
# Install dependencies
uv sync
# Install pre-commit hooks
pre-commit install
pre-commit install --hook-type commit-msg
Common Commands
| Command | Description |
|---|---|
pytest tests/ -n auto |
Run tests in parallel |
pytest tests/ -n auto --cov=unifiedui_sdk --cov-fail-under=80 |
Tests + coverage |
ruff check . |
Lint |
ruff format . |
Format |
mypy src/unifiedui_sdk/ |
Type check |
See TOOLING.md for the full tooling guide, pre-commit hooks, and CI details.
Project Structure
unifiedui-sdk/
├── src/unifiedui_sdk/ # Main package (src layout)
│ ├── core/ # Shared interfaces & utilities
│ │ └── utils.py # generate_id, utc_now, safe_str, str_uuid
│ ├── tracing/ # Tracing objects & LangChain/LangGraph sniffing
│ │ ├── models.py # Trace, TraceNode, NodeData, NodeType, NodeStatus
│ │ ├── base.py # BaseTracer (callback handler)
│ │ ├── langchain.py # UnifiedUILangchainTracer
│ │ ├── langgraph.py # UnifiedUILanggraphTracer
│ │ └── react_agent.py # ReActAgentTracer (multi-agent trace support)
│ ├── streaming/ # Standardized streaming responses
│ │ ├── models.py # StreamMessage, StreamMessageType (22 events)
│ │ └── writer.py # StreamWriter (~25 builder methods)
│ ├── tools/ # Reusable tool clients
│ │ └── m365/ # Microsoft 365 Graph API clients
│ │ ├── core/ # Auth, HTTP, exceptions, pagination
│ │ ├── global_search/ # Cross-tenant search
│ │ ├── outlook/ # Email & calendar
│ │ └── sharepoint/ # Sites, drives, pages, lists, OneNote
│ └── agents/ # ReACT Agent Engine
│ ├── config.py # ReActAgentConfig, MultiAgentConfig, ToolConfig
│ ├── engine.py # ReActAgentEngine (single + multi-agent)
│ ├── single.py # Single-agent ReACT executor
│ ├── prompts.py # System prompt builder
│ ├── tools/ # Tool integrations
│ │ ├── openapi.py # OpenAPI 3.x → LangChain tools
│ │ ├── mcp.py # MCP Server → LangChain tools
│ │ └── loader.py # Parallel tool loader
│ └── multi/ # Multi-agent orchestration
│ ├── planner.py # LLM-based execution plan generator
│ ├── executor.py # Parallel sub-agent executor
│ ├── synthesizer.py # Result synthesizer
│ └── orchestrator.py # Full pipeline coordinator
├── tests/ # Test suite (327 tests)
├── docs/ # Documentation
├── pocs/ # Proof-of-concept scripts
└── .github/ # CI workflows & Copilot instructions
Branching Strategy
This project follows a Simplified Flow branching model with automatic versioning — optimized for SDK releases with semantic versioning.
gitGraph
commit id: "init"
branch develop
checkout develop
commit id: "setup"
branch feat/tracing
checkout feat/tracing
commit id: "add tracing"
commit id: "tracing tests"
checkout develop
merge feat/tracing id: "merge tracing"
branch fix/memory-leak
checkout fix/memory-leak
commit id: "fix leak"
checkout develop
merge fix/memory-leak id: "merge fix"
branch feat/streaming
checkout feat/streaming
commit id: "add streaming"
checkout develop
merge feat/streaming id: "merge streaming"
checkout main
merge develop id: "v0.1.0" tag: "v0.1.0 (auto)"
checkout develop
branch feat/agents
checkout feat/agents
commit id: "add agents"
checkout develop
merge feat/agents id: "merge agents"
branch fix/validation
checkout fix/validation
commit id: "fix validation"
checkout develop
merge fix/validation id: "merge validation"
checkout main
merge develop id: "v0.1.1" tag: "v0.1.1 (auto)"
checkout main
branch hotfix/security
checkout hotfix/security
commit id: "critical fix"
checkout main
merge hotfix/security id: "v0.1.2" tag: "v0.1.2 (auto)"
checkout develop
merge hotfix/security id: "backport hotfix"
checkout develop
commit id: "bump to 0.2.0"
checkout main
merge develop id: "v0.2.0" tag: "v0.2.0 (auto)"
Auto-Versioning
Every merge to main triggers automatic versioning:
┌─────────────────────────────────────────────────────────────────────────┐
│ │
│ pyproject.toml PyPI Current Next Version │
│ (version floor) │
│ ────────────────────────────────────────────────────────────────────── │
│ 0.1.0 (not published) → 0.1.0 │
│ 0.1.0 0.1.0 → 0.1.1 (patch++) │
│ 0.1.0 0.1.5 → 0.1.6 (patch++) │
│ 0.2.0 0.1.6 → 0.2.0 (minor bump!) │
│ 1.0.0 0.9.9 → 1.0.0 (major bump!) │
│ │
└─────────────────────────────────────────────────────────────────────────┘
To release a new minor/major version: Update version in pyproject.toml on develop, then merge to main.
Branch Types
| Branch | Purpose | Branches from | Merges into |
|---|---|---|---|
main |
Production releases — every merge triggers PyPI deployment | — | — |
develop |
Integration branch for features and fixes | main |
main |
feat/<name> |
New features or enhancements | develop |
develop |
fix/<name> |
Bug fixes (non-critical) | develop |
develop |
hotfix/<name> |
Critical production fixes | main |
main + develop |
docs/<name> |
Documentation-only changes | develop |
develop |
refactor/<name> |
Code restructuring without behavior changes | develop |
develop |
Workflow
- Feature/Fix development — Create a
feat/orfix/branch fromdevelop. Open a PR back intodevelop. - Release — When ready, open a PR from
developtomain. On merge, CD automatically:- Calculates next version (floor + PyPI patch increment)
- Creates git tag
- Publishes to PyPI
- Generates changelog and GitHub Release
- Hotfixes — For critical bugs, create a
hotfix/branch frommain, fix, and PR tomain. Then backport todevelop.
Rules
- Never commit directly to
mainordevelop— always use PRs - All PRs require passing CI (tests, lint, type check, coverage ≥ 80%)
- Squash merge feature/fix branches into
developfor a clean history - Tag format:
v<major>.<minor>.<patch>(auto-generated) - Branch naming:
<type>/<short-description>(e.g.feat/langchain-tracing,fix/memory-leak)
Contributing
Contributions are welcome! Please read CONTRIBUTING.md for details on our development workflow, code standards, and how to submit pull requests.
Sponsors
If you find this project useful, consider sponsoring its development.
License
MIT License — see LICENSE 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
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 unifiedui_sdk-0.1.2.tar.gz.
File metadata
- Download URL: unifiedui_sdk-0.1.2.tar.gz
- Upload date:
- Size: 56.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1ab78d4c676b746f00b34e94f2669a4d79aa6023c7d2e8320c534507a54821cd
|
|
| MD5 |
fa3df533905e1e239fdebee21a9f09fe
|
|
| BLAKE2b-256 |
d250f86edf695a679d26c2a99f52466e0bd5a15ff5af6adfdef50dcf7fc9a4a4
|
Provenance
The following attestation bundles were made for unifiedui_sdk-0.1.2.tar.gz:
Publisher:
cd-pypi-release.yml on unified-ui/unifiedui-sdk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
unifiedui_sdk-0.1.2.tar.gz -
Subject digest:
1ab78d4c676b746f00b34e94f2669a4d79aa6023c7d2e8320c534507a54821cd - Sigstore transparency entry: 1059491085
- Sigstore integration time:
-
Permalink:
unified-ui/unifiedui-sdk@35d05b8482235e6ef01632548749c312e0849035 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/unified-ui
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
cd-pypi-release.yml@35d05b8482235e6ef01632548749c312e0849035 -
Trigger Event:
push
-
Statement type:
File details
Details for the file unifiedui_sdk-0.1.2-py3-none-any.whl.
File metadata
- Download URL: unifiedui_sdk-0.1.2-py3-none-any.whl
- Upload date:
- Size: 92.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 |
cd5a576c2067a34a84468a7df6dd569b3df60064144acf8001d5c29f08f6c9a9
|
|
| MD5 |
c3de2988c84941639e1d258b9a8408ff
|
|
| BLAKE2b-256 |
0760ccfd777534a642443c8fd965b0434df876796c27dabe0191f27efa1e3c4f
|
Provenance
The following attestation bundles were made for unifiedui_sdk-0.1.2-py3-none-any.whl:
Publisher:
cd-pypi-release.yml on unified-ui/unifiedui-sdk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
unifiedui_sdk-0.1.2-py3-none-any.whl -
Subject digest:
cd5a576c2067a34a84468a7df6dd569b3df60064144acf8001d5c29f08f6c9a9 - Sigstore transparency entry: 1059491089
- Sigstore integration time:
-
Permalink:
unified-ui/unifiedui-sdk@35d05b8482235e6ef01632548749c312e0849035 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/unified-ui
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
cd-pypi-release.yml@35d05b8482235e6ef01632548749c312e0849035 -
Trigger Event:
push
-
Statement type: