Multi-channel hosting for Microsoft Agent Framework agents.
Project description
agent-framework-hosting
Multi-channel hosting for Microsoft Agent Framework agents.
agent-framework-hosting lets you serve a single agent or workflow target
through one or more channels. The host owns one Starlette ASGI app,
route/lifecycle composition, and per-isolation_key session resolution.
Each channel owns its protocol parsing and response rendering.
The base package contains only channel-neutral plumbing:
AgentFrameworkHost— the Starlette host.Channel— the channel protocol.ChannelRequest/ChannelSession/ChannelIdentity— the request envelope and optional channel metadata.ChannelContext/ChannelContribution/ChannelCommand— channel-side hooks for invoking the target and contributing routes, commands, and lifecycle callbacks.ChannelRunHook/ChannelResponseHook/ChannelStreamUpdateHook— host-invoked customization seams.
ChannelStreamUpdateHook applies to streamed updates only. It is not a
substitute for final-response redaction.
Concrete channels live in their own packages so you only install what you use:
| Package | Transport |
|---|---|
agent-framework-hosting-responses |
OpenAI Responses API |
Additional channel packages can build on the same host contract without adding their protocol dependencies to the base package.
Install
pip install agent-framework-hosting agent-framework-hosting-responses
# or with Hypercorn pre-installed for the demo `host.serve(...)` helper
pip install "agent-framework-hosting[serve]" agent-framework-hosting-responses
# add the [disk] extra to persist reset-session aliases
pip install "agent-framework-hosting[disk]"
Quickstart
from agent_framework.openai import OpenAIChatClient
from agent_framework_hosting import AgentFrameworkHost, Channel
agent = OpenAIChatClient().as_agent(name="Assistant")
# Add channels from sibling packages, e.g. `agent-framework-hosting-responses`
# exposes a `ResponsesChannel` that serves the OpenAI Responses API.
channels: list[Channel] = []
host = AgentFrameworkHost(target=agent, channels=channels)
host.serve(port=8000)
Session state and workflow checkpoints
By default the host keeps live AgentSession objects and reset-session aliases
in memory. Channels opt into continuity by setting
ChannelRequest.session = ChannelSession(isolation_key=...); requests with the
same isolation key reuse the same host-created session.
The host treats isolation_key as an opaque partition key. Each channel or
hosting environment decides where that key comes from:
- protocol headers supplied by a trusted platform,
- request body fields such as a previous response or conversation ID,
- route/path parameters,
- channel-native metadata such as chat/user IDs, or
- environment-provided context in an ephemeral host.
The host should be able to carry any of those sources as long as the channel or
platform has already authenticated and authorized the caller before passing the
key to ChannelSession.
The built-in request-context helper recognizes the x-agent-user-isolation-key
and x-agent-chat-isolation-key header names because some hosting
environments, including Foundry Hosted Agents, already use them. Reusing those
header names does not mean agent-framework-hosting is the supported way to
run on Foundry Hosted Agents; use agent-framework-foundry-hosting for that
hosting surface.
For long-running deployments that need reset_session(...) aliases to survive
restart, pass state_dir:
host = AgentFrameworkHost(
target=agent,
channels=channels,
state_dir="./.host-state",
)
This creates ./.host-state/sessions/ and stores only lightweight alias
bookkeeping. Live AgentSession objects are still rehydrated lazily by the
configured history provider on the next turn.
For workflow targets, checkpoint_location=... is the clearest way to enable
checkpoint persistence. As a convenience, state_dir="./.host-state" also
derives ./.host-state/checkpoints/ for workflow targets. Use the mapping form
when you want only one component:
from agent_framework_hosting import HostStatePaths
host = AgentFrameworkHost(
target=workflow,
channels=channels,
state_dir=HostStatePaths(
sessions="/var/lib/myapp/sessions",
checkpoints="/var/lib/myapp/checkpoints",
),
)
Cross-channel identity linking, multicast delivery, background runs, continuation tokens, and durable delivery runners are follow-up enhancements, not part of this v1 host contract.
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
File details
Details for the file agent_framework_hosting-1.0.0a260625.tar.gz.
File metadata
- Download URL: agent_framework_hosting-1.0.0a260625.tar.gz
- Upload date:
- Size: 30.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.17 {"installer":{"name":"uv","version":"0.11.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8a7e4c0a7a829655a7348be2d7792064d069e10a758de7298caa3cbbcd114dab
|
|
| MD5 |
aeec855a461fef68a5ff85bc6fd9587c
|
|
| BLAKE2b-256 |
2c1cedc9c0be7c5191f2791a632972f4914e3281e5eae6cc8e2f82c9f8d33992
|