SDK, MCP, and schemas for authenticated Managed Research.
Project description
Managed Research
Hosted AI workers for durable repo and research runs.
Documentation: https://docs.usesynth.ai/managed-research/intro
Use Managed Research when you want a repeatable run instead of an untraceable chat transcript: attach repositories and context, launch work from Python or MCP, and read back logs, checkpoints, artifacts, PRs, usage, and final reports.
Engineering style
Contributors should follow Synth Style (engineering rules for contracts,
errors, and structure). The canonical Markdown copy lives in the backend
repository: specifications/tanha/references/synthstyle.md.
Surfaces
This package is for authenticated Managed Research integrations. The Python SDK and MCP server expose the backend catalog for project and run automation, including the runbook presets, work modes, model catalog, and usage state the authenticated org is entitled to use.
Surfaces and tiers
- Open Research web: public lab surface with
liteandopen_ended_discovery. - Authenticated Free:
lite,directed_effort, standard model access, and one-time Managed Research credits. - Authenticated Pro and Team: Free plus the paid GA model bundle and higher Managed Research usage pools.
- Beta Access: an overlay on Free, Pro, or Team that adds
open_ended_discovery,heavy, and all-model access.
Open Research on the public web is a narrower lab surface: it accepts lite
runs with open_ended_discovery only. Treat those limits as web admission
policy, not as SDK or MCP client-side rules. See the customer docs for the
current product split: https://docs.usesynth.ai/managed-research/intro
Installation
uv add managed-research
Set an API key:
export SYNTH_API_KEY="sk_..."
Quickstart
import os
from managed_research import ManagedResearchClient, ProjectSelector
client = ManagedResearchClient(api_key=os.environ["SYNTH_API_KEY"])
run = client.runs.start(
"Review the project context and propose the smallest high-impact improvement.",
host_kind="daytona",
work_mode="directed_effort",
providers=[{"provider": "openrouter"}],
)
print("run:", run.run_id)
result = run.wait(timeout=60 * 60, poll_interval=15)
print("state:", result.state.value)
print("artifacts:", [artifact.title for artifact in run.artifacts()])
Main Ideas
- Use
ManagedResearchClientas the Python entrypoint. - Use
client.runs.start(...)for runs that default to the caller's Miscellaneous project. - Pass
project_id=orproject=ProjectSelector.from_project_id(...)when a run belongs to a specific existing project. - Use
client.projects.create(...)andclient.project(project_id)for durable project-scoped work. - Run preflight before launch when you want structured launch blockers.
- Inspect runs through messages, timelines, event logs, authority readouts, operator evidence, traces, checkpoints, artifacts, usage, questions, approvals, and actor/task counts.
- Use MCP from Codex or Claude Code when you want an agent-native interface.
MCP
Hosted:
codex mcp add managed-research --url https://api.usesynth.ai/mcp
claude mcp add --transport http managed-research https://api.usesynth.ai/mcp
Local stdio:
uv tool install managed-research
managed-research-mcp
Links
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
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 managed_research-1.2026.50502.tar.gz.
File metadata
- Download URL: managed_research-1.2026.50502.tar.gz
- Upload date:
- Size: 317.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.4 {"installer":{"name":"uv","version":"0.11.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":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 |
f0513633ff6c8105d3f80da048e4b219af53f1d4c9f8a7a53e70daeed3853151
|
|
| MD5 |
1bf0e62bba5ebee301ab0c31494b8d47
|
|
| BLAKE2b-256 |
ca5300025851df95c9842d1be07743125430e510eb82092cf434e6408e75d9ce
|
File details
Details for the file managed_research-1.2026.50502-py3-none-any.whl.
File metadata
- Download URL: managed_research-1.2026.50502-py3-none-any.whl
- Upload date:
- Size: 311.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.4 {"installer":{"name":"uv","version":"0.11.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":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 |
e0558f6d544d390beae0f419b884836814016137bdb5bc409c8014e7fc84ca5a
|
|
| MD5 |
a6c4c324e48516c0659957b3f5e63dbe
|
|
| BLAKE2b-256 |
985a0192cd571efa328b2c3d646e33a9bc1e8b4ff0a9dd745f8770633ccf8f28
|