Fast, typed Python SDK for Codex CLI workflows with TypeScript SDK parity.
Project description
acodex
acodex is a fast, typed Python SDK for Codex CLI workflows (sync/async, streaming, structured output, images, safety controls), and API parity with the TypeScript SDK.
What is acodex?
acodex spawns the codex CLI and exchanges JSONL events over stdin/stdout so you can run agent
threads from Python with a fully typed surface: sync + async clients, streaming events, structured
output, image inputs, resumable threads, and safety controls exposed as explicit options.
Install
Prerequisite: Codex CLI
acodex wraps an external CLI. Install the Codex CLI and ensure codex is on your PATH (or pass
codex_path_override=... to Codex(...) / AsyncCodex(...)).
- Upstream CLI: https://github.com/openai/codex
One installation option:
npm install -g @openai/codex
codex --version
Install acodex (uv-first)
uv add acodex
uv run python your_script.py
pip install acodex also works, but uv is recommended.
Recommended for structured output: structured-output extra (primary pattern via output_type):
uv add "acodex[structured-output]"
# or:
pip install "acodex[structured-output]"
60-second quickstart (sync)
from pydantic import BaseModel
from acodex import Codex
class SummaryPayload(BaseModel):
summary: str
thread = Codex().start_thread(
sandbox_mode="read-only",
approval_policy="on-request",
web_search_mode="disabled",
)
turn = thread.run(
"Summarize this repo.",
output_type=SummaryPayload,
)
print(turn.structured_response.summary)
Call run() repeatedly on the same Thread instance to continue the conversation. To resume later
from disk, use Codex().resume_thread(thread_id).
Async quickstart
import asyncio
from acodex import AsyncCodex
async def main() -> None:
thread = AsyncCodex().start_thread()
turn = await thread.run("Say hello")
print(turn.final_response)
asyncio.run(main())
Advanced: stream parsed events
Use run_streamed() to react to intermediate progress (tool calls, streaming responses, item
updates, and final usage).
from acodex import Codex, ItemCompletedEvent, TurnCompletedEvent, TurnFailedEvent
codex = Codex()
thread = codex.start_thread()
streamed = thread.run_streamed(
"List the top 3 risks for this codebase. Be concise.",
)
for event in streamed.events:
if isinstance(event, ItemCompletedEvent):
print("item", event.item)
elif isinstance(event, TurnCompletedEvent):
print("usage", event.usage)
elif isinstance(event, TurnFailedEvent):
print("error", event.error.message)
turn = streamed.result
print(turn.final_response)
streamed.result is available only after streamed.events is fully consumed.
Why acodex
- Typed surface: strict type hints + mypy strict, no runtime deps by default.
- Sync + async:
Codex/ThreadandAsyncCodex/AsyncThread. - Streaming events:
Thread.run_streamed()yields parsedThreadEventdataclasses. - Structured output: validate into a Pydantic model via
output_type(recommended), or passoutput_schema(JSON Schema) for schema-only parity with the TypeScript SDK. - Images: pass
UserInputLocalImagealongside text in a single turn. - Resume threads:
resume_thread(thread_id)(threads persisted under~/.codex/sessions). - Safety controls: expose Codex CLI controls as
ThreadOptions(sandbox_mode,approval_policy,web_search_mode,working_directory, ...). - TS SDK parity: vendored TypeScript SDK is the source of truth; compatibility tests fail loudly on drift.
- Quality gates: Ruff + mypy strict + 100% coverage.
Compatibility & parity (TypeScript SDK)
The vendored TypeScript SDK under vendor/codex-ts-sdk/src/ is the source of truth. CI runs a
Python-only compatibility suite that parses those TS sources and asserts the Python exports,
options keys, events/items models, and class surface stay compatible.
An hourly workflow checks for new stable Codex releases and opens a PR to bump the vendored SDK:
.github/workflows/codex-ts-sdk-bump.yaml.
- Compatibility policy:
COMPATIBILITY.md - Intentional divergences (documented + tested):
DIFFERENCES.md - Contributing:
CONTRIBUTING.md
Links
- Docs: https://docs.acodex.dev
- GitHub: https://github.com/maksimzayats/acodex
- Issues: https://github.com/maksimzayats/acodex/issues
Disclaimer
It is independently maintained and is not affiliated with, sponsored by, or endorsed by OpenAI.
License
Apache-2.0. See LICENSE.
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 acodex-0.117.0.tar.gz.
File metadata
- Download URL: acodex-0.117.0.tar.gz
- Upload date:
- Size: 191.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.2 {"installer":{"name":"uv","version":"0.11.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
051f6ca7fde05f71e932af44303fa0aedae1cba1fefff66dfea8154d8569b5c8
|
|
| MD5 |
d3fc30e72fc7ef8785a0b8a1ffa49e19
|
|
| BLAKE2b-256 |
e44f647f77c02ccda6abcece85ffeb0c1bccebb904c389cee8c99e0bc1a478f3
|
File details
Details for the file acodex-0.117.0-py3-none-any.whl.
File metadata
- Download URL: acodex-0.117.0-py3-none-any.whl
- Upload date:
- Size: 32.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.2 {"installer":{"name":"uv","version":"0.11.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cf3ed88239406a1fc1b1d4d83772480ca8e080a24b3175f3be7bc41da172d9cf
|
|
| MD5 |
1e1e3567d6c268190049b408b5f9e908
|
|
| BLAKE2b-256 |
c5949736dfa82acfcad0ca3bb8315bbc1d6f79bcdc50999ed4ef4643f16d99e8
|