https://github.com/envhaven/envhaven
Batteries-included development environment for agentic workflows.
https://github.com/envhaven/envhaven
claude-code cli codex docker gemini opencode
Last synced: 7 days ago
JSON representation
Batteries-included development environment for agentic workflows.
- Host: GitHub
- URL: https://github.com/envhaven/envhaven
- Owner: envhaven
- License: mit
- Created: 2025-12-16T01:10:28.000Z (2 months ago)
- Default Branch: master
- Last Pushed: 2026-01-31T02:10:02.000Z (17 days ago)
- Last Synced: 2026-01-31T14:35:11.935Z (16 days ago)
- Topics: claude-code, cli, codex, docker, gemini, opencode
- Language: TypeScript
- Homepage: https://envhaven.com
- Size: 822 KB
- Stars: 12
- Watchers: 0
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
Awesome Lists containing this project
README
EnvHaven
Batteries-included development environment for agentic workflows.
As tools like Claude Code, OpenCode and Codex gain agency, they need full filesystem access to be effective. Running them locally carries risk (`rm -rf` accidents, credential leaks) and friction (installing complex runtimes).
EnvHaven solves this. It's a remote environment that spins up in seconds, with sane defaults and every major AI coding tool and built-in, fully isolated from your personal machine.
**Workflow Freedom:**
- **Browser-only** β Deploy the image, open VS Code in your browser, run `opencode`. Zero setup.
- **Local editor + remote AI** β Use the Haven CLI to sync your project. Edit in Neovim, Zed, Jetbrains, et al. while agents run in the container. Changes sync in ~200ms.
---
## Why EnvHaven
π‘οΈ **Zero-Risk AI environment**
Give autonomous agents full access in a containerized environment. If they break something, nuke the workspace and start over. Your local machine stays untouched.
π₯οΈ **Pick Up Where You Left Off**
Start Claude Code on your laptop, close the lid, resume from your desktopβsame session, same state. Your AI agents and dev servers keep running while you're away. Come back from any device.
π² **Evergreen AI Tooling**
The landscape moves too fast to manage manually. EnvHaven ships with 12+ AI CLI tools (Claude Code, OpenCode, Aider, Codex, Gemini CLI, Goose, Mistral Vibe, etc.) built-in and ready to run.
π **Instant Public URLs** *(Managed only)*
Every managed workspace gets a wildcard `*.envhaven.app` domain. Deploy a web app, webhook receiver, or Discord botβlive instantly. No ngrok, no tunnels, no DNS.
πΎ **Persistent & Owned**
Unlike ephemeral environments (Codespaces) or walled gardens (Replit), EnvHaven workspaces are persistent Linux environments you own.
β‘ **Open Model**
- **Self-Hosted**: Free forever, open-source Docker image and CLI. Run it on your own server.
- **Managed** ($10/mo): Zero-config hosting with custom domains, always-on workspaces, and no DevOps.
---
## Who It's For
| Persona | Use Case |
|---------|----------|
| **Vibe Coders** | That ship by prompting their way to products. Need a "magic box" where code just runs, already fully setup. |
| **AI-Native Devs** | Power users of agentic coding tools like Claude Code or OpenCode that want a standardized, pre-configured backend for their agents. |
| **Setup Purists** | Developers married to their beautifully tuned and customized editor. Use Haven CLI to keep your workflow while agents run wild in a contained environment. |
| **Bot Builders** | Those who vibe-code 24/7 persistent scripts (Discord, Telegram or even trading bots). |
## Quick Start
### Path A: Browser-Only (Zero Setup)
Deploy the image and code immediately in the browser.
```bash
docker run -d \
--name envhaven \
-p 8443:8443 \
-p 2222:22 \
-e PASSWORD=password \
-e SUDO_PASSWORD=password \
ghcr.io/envhaven/envhaven:latest
```
1. Open `https://localhost:8443` (Password: `password`)
2. Open terminalβyou're dropped into a persistent session
3. Run `opencode`, `claude`, or `aider` and start coding
**Multiple AI tools at once?** Click `+` in the footer or use the sidebar to create new terminals. Each runs in its own persistent sessionβclose your browser and they keep running.
### Path B: Local Editor + Remote AI (Haven CLI)
Use your local editor. Files sync bidirectionally. Agents run in the container.
**1. Install Haven CLI**
```bash
curl -fsSL https://envhaven.com/install.sh | sh
```
**2. Connect to your workspace**
```bash
cd my-project
# Managed workspace (shorthand)
haven connect . myproject-alice
# Self-hosted container
haven connect . abc@your-server.com:2222
```
*Files sync in ~200ms.*
**3. Run remote commands**
```bash
haven opencode # Runs OpenCode in the container
haven make build # Runs make in the container
haven npm install # Runs npm in the container
```
> **Self-hosted?** You'll need to configure SSH keys first. See [SSH Access](#ssh-access).
## What's Included
The image (`ghcr.io/envhaven/envhaven`) comes batteries-included.
### AI Coding Agents
No API keys are pre-set. You can set them directly in the UI via the bundled EnvHaven Extension in code-server.
You can also provide your own keys via env vars (`-e ANTHROPIC_API_KEY=...`) or config files.
| Tool | Command | Description |
|------|---------|-------------|
| **OpenCode** | `opencode` | SST's autonomous coding agent |
| **Claude Code** | `claude` | Anthropic's official CLI |
| **Aider** | `aider` | AI pair programming |
| **Codex** | `codex` | OpenAI's coding agent |
| **Gemini CLI** | `gemini` | Google's AI in terminal |
| **Goose** | `goose` | Block's developer agent |
| **Mistral Vibe** | `vibe` | Powered by Devstral |
| **Qwen Code** | `qwen` | Alibaba's coding assistant |
| **Amp** | `amp` | Sourcegraph's coding agent |
| **Augment** | `auggie` | Context-aware coding agent |
| **Kiro** | `kiro-cli` | AWS-powered AI CLI |
| **Factory Droid** | `droid` | Factory's AI agent |
### Runtimes & SDKs
| Language | Version | Notes |
|----------|---------|-------|
| **Node.js** | 20.x | LTS |
| **Bun** | Latest | Fast JS runtime |
| **Python** | 3.12 | Managed via `uv` |
| **Go** | 1.22 | |
| **Rust** | Stable | Via rustup |
### Dev Tools
- **Core:** `zsh`, `git`, `curl`, `wget`, `zip`, `unzip`
- **Utils:** `ripgrep`, `fd`, `jq`, `sqlite3`, `htop`
- **Media:** `ffmpeg` (video/audio), `playwright` (browser automation)
- **Integrations:** `gh` (GitHub CLI), `docker` (client)
## Haven CLI Architecture
The CLI enables a hybrid workflow: **Local Editor + Remote Compute**.
- **Latency:** ~200ms bidirectional sync.
- **Compatibility:** Works with any editor.
- **Independence:** The sync daemon runs in the background; close the CLI and sync continues.
```
ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
β YOUR MACHINE β
β β
β βββββββββββββββββββ βββββββββββββββββββ βββββββββββββββββββ β
β β Local Editor β β Haven CLI β β Sync Daemon β β
β β β β β β β β
β β nvim/lazyvim β β haven connect β β β β
β β emacs/doom β β haven status β β Continuous β β
β β helix β β haven β β bidirectional β β
β β β β β β ~200ms latency β β
β ββββββββββ¬βββββββββ ββββββββββ¬βββββββββ ββββββββββ¬βββββββββ β
β β β β β
β βΌ βΌ βΌ β
β ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ β
β β ~/projects/myapp/ β β
β ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ β
β β² β
β β β
β βΌ β
β ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ β
β β /config/workspace/myapp/ β β
β ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ β
β β² β² β² β
β β β β β
β ββββββββββ΄βββββββββ ββββββββββ΄βββββββββ ββββββββββ΄βββββββββ β
β β Claude Code β β OpenCode β β aider β β
β β Long-running β β Long-running β β Task-based β β
β β AI sessions β β AI sessions β β AI sessions β β
β βββββββββββββββββββ βββββββββββββββββββ βββββββββββββββββββ β
β β
β ENVHAVEN CONTAINER β
ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
```
**Why this matters:**
- **AI agents need contained compute:** They require massive context windows, long-running processes, specific toolchains, and might do dangerous stuff some time.
- **You need your editor:** You rely on your custom keybindings, themes, and muscle memory.
- **Flexibility:** Both workflows work independently or together.
## Docker Compose
For persistent deployments, use `docker-compose.yml` with `.env`:
```bash
cp .env.example .env # Copy and edit with your passwords/API keys
docker compose up -d
```
Or use inline environment variables for quick testing:
```yaml
services:
envhaven:
image: ghcr.io/envhaven/envhaven:latest
container_name: envhaven
environment:
- PUID=1000
- PGID=1000
- TZ=Etc/UTC
- PASSWORD=password # Web UI password
- SUDO_PASSWORD=password # sudo/SSH password
volumes:
- ./config:/config # Persist home directory
ports:
- 8443:8443 # Web UI
- 2222:22 # SSH Access
restart: unless-stopped
```
See [Configuration Reference](docs/configuration.md) for all options including AI API keys and SSH setup.
## SSH Access
SSH enables the Haven CLI and direct terminal access.
| Setup | SSH Host | Haven CLI |
|-------|----------|-----------|
| **Managed** | `ssh-{subdomain}.envhaven.app` | `haven connect . myproject-alice` |
| **Self-hosted** | `your-server:2222` | `haven connect . abc@your-server:2222` |
**Self-hosted setup:** Import your GitHub keys automatically:
```yaml
environment:
- PUBLIC_KEY_URL=https://github.com/yourusername.keys
ports:
- "2222:22"
```
See [Configuration Reference](docs/configuration.md) for all SSH options.
## Documentation
- **[AI Tools Guide](docs/ai-tools.md)** β Setup guides, API keys, and usage examples for all 12+ AI coding tools
- **[Configuration Reference](docs/configuration.md)** β Complete env vars, SSH setup, Docker mods, and compose examples
- **[Development Guide](docs/development.md)** β Building from source, testing, and contributing
- **[Haven CLI](cli/README.md)** β CLI source and architecture