Skip to main content

A lightweight event-driven Codex agent runtime.

Project description

codex-agent

codex-agent-framework is a local-first Python framework for building and running tool-using AI agents.

Use it as a ready-to-run terminal assistant, or import Agent when you want to build your own agentic workflow in Python.

Early alpha: APIs are still evolving and breaking changes are expected while the architecture settles.

Why codex-agent?

codex-agent is meant to be a transparent, hackable local harness for power users and developers:

  • Local-first runtime: sessions, memory, config, plugins, logs, and work files live under your local runtime directory.
  • Multiple entry points: TUI, headless CLI, Python SDK, and local FastAPI server.
  • Plugin-first design: tools, providers, slash commands, hooks, events, prompt sections, and stream processors are extension points.
  • Observable agent loop: turns return structured results and emit events that UIs and integrations can stream.
  • Built-in practical tools: files, shell, Python, context, memory, planner, scheduler, browser/desktop automation, and subagents.

Quick start

Install the package:

python -m pip install codex-agent-framework

For the recommended local setup, run:

codex-agent bootstrap -- -y

bootstrap installs desktop/browser/tray dependencies, installs the user services, and starts them. It is currently aimed mostly at Debian-like Linux systems. Use an X11 session for the best desktop automation support; Wayland is fine if you do not use the desktop plugin.

Open the assistant:

codex-agent

If a local agent server is already running, the TUI connects to it. Otherwise codex-agent starts a temporary server for that TUI session and shuts it down when the TUI exits. New sessions are anchored to the directory where you launch codex-agent; see CLI and runtime.

Inside the TUI, start with:

/help
/sessions
/new_session
/load_session latest
/compact
/config

Use /compact when a long session needs to reduce its active context. It keeps a backend summary and prunes older raw history from the active session file.

Python in 30 seconds

from codex_agent import Agent

agent = Agent(session="new")
turn = agent("Summarize this repository in three practical bullet points.")

print(turn.result)

Stream live events when building your own UI or integration:

from codex_agent import Agent, ResponseContentDeltaEvent

agent = Agent(session="new")
stream = agent.stream("Explain what this project does.")

for event in stream:
    if isinstance(event, ResponseContentDeltaEvent):
        print(event.delta, end="", flush=True)

turn = stream.turn
print("\ncompleted:", turn.completed)

Add a small tool:

import subprocess
from codex_agent import Agent, tool

@tool
def list_changed_files() -> list[str]:
    """Return modified or untracked files in the current git repository."""
    output = subprocess.check_output(["git", "status", "--short"], text=True)
    return [line[3:] for line in output.splitlines() if line.strip()]

agent = Agent(session="latest")
agent.add_tool(list_changed_files)
agent("What changed locally?")

Main ways to use it

Mode Entry point Best for
Interactive TUI codex-agent Daily local assistant usage.
Python SDK Agent(...) Scripts, notebooks, tests, custom applications.
Headless CLI codex-agent run ... Automation and shell pipelines.
Persistent server codex-agent start server Long-lived local service used by UIs or scripts.
Runtime plugins ~/.codex-agent/plugins/*.py Local customization without forking the project.

Useful CLI commands:

codex-agent status --json
codex-agent tools
codex-agent sessions list
codex-agent config get
codex-agent run "Run a quick repository health check."
git diff -- README.md | codex-agent run --stdin "Review this documentation diff."

Built-in capability map

Area Examples Purpose
Files/content read, view, write, edit Strict text reads, broad extraction, exact-string edits.
Shell/Python bash, python Local command execution and persistent Python work.
Context/status context_status, context_compact Inspect and manage the active context window.
Memory/planner memory_add, planner_create Durable semantic memory and persistent named todos.
Scheduler scheduler_schedule Future turns and post-restart continuation.
Browser/desktop browser and desktop tools Persistent Chromium and Linux desktop automation.
Subagents subagents_run Focused child agents such as the read-only explorer profile.

Select built-ins explicitly when you want a smaller agent:

agent = Agent(
    session="latest",
    builtin_plugins=["files", "content", "bash", "python", "environment", "context"],
)

None loads all built-ins, [] loads none, and an explicit list selects plugin module names.

Documentation

The README is intentionally a façade and quick-start guide. Advanced usage lives in docs/:

  • Python SDK: Agent, turns, streaming, events, config, and interactive sessions.
  • Plugins and extensions: tools, providers, commands, runtime plugins, stateful plugins, hooks, events, and stream processors.
  • CLI and runtime: TUI, server, headless CLI, sessions, config, runtime files, and service setup.
  • Built-in capabilities: bundled plugins and common usage patterns.
  • Safety and trust: local trust model, runtime plugins, server binding, secrets, and risky actions.
  • Development: project layout, tests, build, and release checks.

See CHANGELOG.md for release history.

Safety notes

This project lets an AI assistant act on the local machine. That is useful, but risky.

Recommended practices:

  • Avoid running the agent with elevated privileges.
  • Review tools and runtime plugins before enabling autonomous workflows.
  • Keep secrets out of prompts, logs, committed runtime files, and shared session exports.
  • Treat browser, desktop, shell, file-write, and edit operations as real user actions.
  • Keep important runtime plugins under version control.

License

MIT. See LICENSE.

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

codex_agent_framework-0.1.30.tar.gz (282.4 kB view details)

Uploaded Source

Built Distribution

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

codex_agent_framework-0.1.30-py3-none-any.whl (222.7 kB view details)

Uploaded Python 3

File details

Details for the file codex_agent_framework-0.1.30.tar.gz.

File metadata

  • Download URL: codex_agent_framework-0.1.30.tar.gz
  • Upload date:
  • Size: 282.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for codex_agent_framework-0.1.30.tar.gz
Algorithm Hash digest
SHA256 c5dbc8d1c54ec3a016e835767025fe2a850842d8fadca91f20bf8c70e2f7c862
MD5 70d243c285e31991f3c92c7688562189
BLAKE2b-256 886259356c3d2a1bed504687900587016d4854b4b3521d6adb6d5ae5a6597d74

See more details on using hashes here.

File details

Details for the file codex_agent_framework-0.1.30-py3-none-any.whl.

File metadata

File hashes

Hashes for codex_agent_framework-0.1.30-py3-none-any.whl
Algorithm Hash digest
SHA256 b66ab812f5c1a198ff87f8f6ed80210f626d54349bef6d7a25d6cfa99ec43a9e
MD5 518fa7879ace30883ae7dd3c67a4c491
BLAKE2b-256 e29213f6cedc370d836dab961e335cd7bdc8d9c3d7278f7bbe9f38de052c5a6a

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