Skip to main content

Multi-user wrapper for managing terminal AI coding agent sessions (claude, codex, cursor)

Project description

uxon

PyPI CI License: MIT Python 3.11+ Platform: Linux

Session manager for development teams using terminal AI coding agents (Claude Code, Codex, Cursor CLI) on one or more Linux servers. Team visibility via OS accounts, cross-host visibility via SSH, supervision via sudoers.

uxon dashboard — a lead sees the whole team's agent sessions across hosts

When to use uxon

Use uxon when terminal AI coding agents are a runtime someone else may need to see, attach to, or stop. Four shapes of deployment, one tool:

  • One developer, one host. Persistent TUI over tmux; agents optionally sandboxed in a low-priv <user>_agent account so a yolo run can't trash your $HOME.
  • One developer, several hosts. Aggregate everything into one TUI with a HOST column; locals first, then peers grouped by host.
  • A team sharing one host. Each developer runs as their paired <user>_agent. The lead's TUI sees everyone via sudo. Cross-user supervision without impersonation — the lead never becomes the developer.
  • A team across several hosts. Same supervision property per host; per-peer authority (each host's sudoers is the authority on that host); cross-host audit correlation via UUID correlation_id joining caller-side and peer-side events.

Aggregation is client-side: the lead's TUI fans out over SSH. No daemon, no database, no central server to deploy. Each host stays independently configured and independently authorised.

Install

Requires Python 3.11+, tmux, and Linux.

# Team / shared host (recommended): one root-owned binary in
# /usr/local/bin/uxon. Operator owns the version and the install
# path; launch users can append audit events but cannot edit
# the binary or the trail.
sudo pipx install --global uxon

# Solo / single-owner: each OS user manages their own copy.
uv tool install uxon              # or:  pipx install uxon

uxon                              # launch the TUI; it self-diagnoses

For the bundled installer, PEP 668 caveat, and unreleased-from- main builds, see docs/start/install.md.

Documentation

The site at docs/ is organised two ways. Pick the entry that matches what you have in mind.

By scenario:

By task (Diátaxis layout):

  • docs/start/ — tutorials (install, bootstrap a host, add a peer).
  • docs/guides/ — how-to recipes (operate, harden, customise, debug).
  • docs/reference/ — every command, every flag, every config key, every audit event.
  • docs/explain/ — the model (isolation, supervision, multi-host, audit channel).

Top-level pointers:

Quick TUI tour

uxon (no args, on a TTY) opens a full-screen picker:

  • New session in current folder — start the default agent in $PWD.
  • Create new project — prompt for a name, create <new_project_root>/<name>, optionally create a GitHub repo, launch the agent.
  • Open existing project — pick a directory under new_project_root and launch.

Below that: a unified session dashboard mounting your own sessions, other-user sessions visible via sudo (when the superuser block is active), and one row per session on each configured [[remote_hosts]] peer. Two view modes — flat (default; single ranked list) and by_host (per-host tabs and a status bar); toggle with v. ←/→ on the dashboard cycles between hosts (host tabs in by_host, (host, own/other) transitions in flat). A search bar filters across all rows — hidden by default, press s (or /) to summon it. Per-row data: agent, working dir, live CPU / RAM, attached glyph (/), creation time, last activity time. Enter attaches; d kills with confirmation.

Every launch asks whether to start in normal mode or with --dangerously-skip-permissions ("yolo") — the TUI does not start yolo without that explicit choice.

Full keybinding list: docs/reference/keybindings.md.

Supported agents

Agent id Binary --auto mode --dsp (yolo) Install
claude claude --permission-mode auto --dangerously-skip-permissions Anthropic docs
codex codex --full-auto --dangerously-bypass-approvals-and-sandbox npm i -g @openai/codex
cursor cursor-agent (not supported) --yolo curl https://cursor.com/install -fsSL | bash

Enable agents in config/config.toml:

[agents]
enabled = ["claude", "codex"]
default = "claude"

-w <branch> (worktree) works with any agent; uxon manages the worktree itself. --auto is unavailable for cursor.

uxon doctor probes each enabled agent and prints its path, version, and status. The TUI auto-detects newly-installed agents and offers a one-keypress enable.

Versioning

uxon follows SemVer. uxon --version prints the version and short git commit (with -dirty when the checkout has uncommitted changes).

In a team·N fleet, all peers must run the same major version — see docs/guides/operate/roll-fleet-upgrade.md.

License

MIT © 2026 Vasily Zakharov.

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

uxon-3.6.0.tar.gz (676.9 kB view details)

Uploaded Source

Built Distribution

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

uxon-3.6.0-py3-none-any.whl (341.7 kB view details)

Uploaded Python 3

File details

Details for the file uxon-3.6.0.tar.gz.

File metadata

  • Download URL: uxon-3.6.0.tar.gz
  • Upload date:
  • Size: 676.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for uxon-3.6.0.tar.gz
Algorithm Hash digest
SHA256 9ecd49d52eba42223d48e76cce8977af914ce75a8ea0ff71e18b55f2899077ac
MD5 dcd4387c43d457e3db7d01f65c2ece9a
BLAKE2b-256 901434fa9bb3dba567d4fd997d09ee0f4e7a9a8c1e74b74476608a7defc2408f

See more details on using hashes here.

Provenance

The following attestation bundles were made for uxon-3.6.0.tar.gz:

Publisher: release.yml on vzd3v/uxon

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file uxon-3.6.0-py3-none-any.whl.

File metadata

  • Download URL: uxon-3.6.0-py3-none-any.whl
  • Upload date:
  • Size: 341.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for uxon-3.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6b62c22ae63710bdf42366349976e2627b67bcf986975898aaa6dcc4e5bfb0ba
MD5 9d204cc7ce549c8bf5f2dae56f127f18
BLAKE2b-256 f05250962ae64cbd8b07cca9a212ffd44fc3fe0dc74b78c290ae9414913dd3ac

See more details on using hashes here.

Provenance

The following attestation bundles were made for uxon-3.6.0-py3-none-any.whl:

Publisher: release.yml on vzd3v/uxon

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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