Skip to main content

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 lite and open_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 ManagedResearchClient as the Python entrypoint.
  • Use client.runs.start(...) for runs that default to the caller's Miscellaneous project.
  • Pass project_id= or project=ProjectSelector.from_project_id(...) when a run belongs to a specific existing project.
  • Use client.projects.create(...) and client.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


Download files

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

Source Distribution

managed_research-1.2026.50501.tar.gz (317.1 kB view details)

Uploaded Source

Built Distribution

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

managed_research-1.2026.50501-py3-none-any.whl (311.1 kB view details)

Uploaded Python 3

File details

Details for the file managed_research-1.2026.50501.tar.gz.

File metadata

  • Download URL: managed_research-1.2026.50501.tar.gz
  • Upload date:
  • Size: 317.1 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

Hashes for managed_research-1.2026.50501.tar.gz
Algorithm Hash digest
SHA256 2f02e2adb26703351bb7d960be951aaa2b3790f65d3c618add0517e6fa13fe47
MD5 2a1c4a138e61c1dc543904e44b0977df
BLAKE2b-256 7f1668a42eac0639c52784a9a7f475f4c8ac4a74f5b214178f22416f0bd045b1

See more details on using hashes here.

File details

Details for the file managed_research-1.2026.50501-py3-none-any.whl.

File metadata

  • Download URL: managed_research-1.2026.50501-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

Hashes for managed_research-1.2026.50501-py3-none-any.whl
Algorithm Hash digest
SHA256 dcd5d235d3b5f1d8149c6856af3fbe31c9bd5c994181982a6e67c5eeb23d6e41
MD5 485a7a5d5c5b316eccefc1a14c9eb8a7
BLAKE2b-256 cb60f7fbb4b0f52913f8134ae6d2dba9e1365e4c2ab201058aa48709435e96ea

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