An open API service indexing awesome lists of open source software.

https://github.com/ryaneggz/open-harness

Isolated sandbox images for AI coding agents
https://github.com/ryaneggz/open-harness

agent ai claude-code codex deepagents docker langchain nvidia openclaw openshell sandbox

Last synced: about 2 months ago
JSON representation

Isolated sandbox images for AI coding agents

Awesome Lists containing this project

README

          

# Mifune Open Harness

**Mifune Open Harness** โ€” run Claude, Codex, Gemini, and Pi side-by-side from one `docker compose up`. Each agent gets its own branch, its own SOUL, its own schedule.

- **Worktree-per-agent.** Each agent gets its own branch, its own SOUL, its own schedule.
- **Agents that work while you sleep.** Cron-driven heartbeats wake them to do real work, autonomously.
- **One container, every agent.** Claude Code, Codex, Pi, Gemini CLI โ€” same sandbox, same toolchain.
- **Only host dependency: Docker.** No Node, no Python, no toolchain rot on your laptop.
- **Composable infra.** Cherry-pick Postgres, Cloudflare tunnels, SSH, Slack, Caddy gateway.

---

## ๐Ÿ“ฆ Install

```bash
curl -fsSL https://raw.githubusercontent.com/ryaneggz/open-harness/refs/heads/main/install.sh | bash
```

Only host dependency: [Docker](https://docs.docker.com/get-docker/). Add `-s -- --with-cli` to also install the `oh` CLI on the host (requires Node 20+).

## ๐Ÿš€ Quickstart

The full sandbox lifecycle is three commands:

```bash
oh onboard # one-time: GitHub, LLM, Slack, Claude auth wizard
oh sandbox my-agent # provision and start
oh shell my-agent # connect (interactive shell)
oh clean my-agent # tear down
```

Prefer VS Code or remote SSH? See [Connecting to a sandbox](https://github.com/ryaneggz/open-harness/blob/main/docs/getting-started/quickstart.md).

Inside the shell, start working:

```bash
claude # terminal coding agent
pi # automations โ€” Slack, heartbeats, extensions
```

## โœจ What you get

| | |
|---|---|
| **AI agents** | Claude Code, OpenAI Codex, Pi Agent, Mom (Slack bot) |
| **Runtimes** | Node 22, pnpm, Bun, uv (Python) |
| **DevOps** | Docker CLI + Compose, GitHub CLI, cloudflared, tmux, cron |
| **Browser** | agent-browser + Chromium (headless) |
| **Worktree-per-agent** | One branch per agent, one container, shared toolchain |
| **Heartbeats** | Cron-scheduled autonomous runs (`workspace/heartbeats/*.md`) |

## ๐Ÿ“š Where to go next

- [Quickstart](https://github.com/ryaneggz/open-harness/blob/main/docs/getting-started/quickstart.md) โ€” full step-by-step
- [Onboarding](https://github.com/ryaneggz/open-harness/blob/main/docs/getting-started/onboarding.md) โ€” auth wizard walkthrough
- [Compose overlays](https://github.com/ryaneggz/open-harness/blob/main/docs/guide/overlays.md) โ€” Postgres, Slack, SSH, gateway, Cloudflare
- [Slack bot](https://github.com/ryaneggz/open-harness/blob/main/docs/slack/overview.md) โ€” Mom + Pi via Socket Mode
- [CLI reference](https://github.com/ryaneggz/open-harness/blob/main/docs/cli/commands.md) โ€” every `oh` command
- [Heartbeats](https://github.com/ryaneggz/open-harness/blob/main/docs/guide/heartbeats.md) โ€” cron-scheduled autonomous tasks
- [Architecture](https://github.com/ryaneggz/open-harness/blob/main/docs/architecture/orchestrator-worktrees.md) โ€” one container, N worktrees, one daemon

## ๐Ÿ—‚๏ธ Project layout

```
.devcontainer/ # Sandbox environment (Dockerfile, compose, overlays)
docs/ # Plain-markdown documentation (GitHub-rendered)
install/ # Provisioning scripts
workspace/ # Agent workspace template (bind-mounted)
packages/
sandbox/ # @openharness/sandbox โ€” CLI + container lifecycle
slack/ # Vendored fork of pi-mom โ€” Slack bot
```

## ๐Ÿงน Cleanup

```bash
oh clean my-agent
```

## ๐Ÿค Contributing & community

Issues and PRs welcome at [github.com/ryaneggz/open-harness](https://github.com/ryaneggz/open-harness). If Mifune Open Harness is useful to you, please [give us a star](https://github.com/ryaneggz/open-harness/stargazers).

## ๐Ÿ“„ License

MIT.

---

[Full documentation](https://github.com/ryaneggz/open-harness/tree/main/docs)