https://github.com/tiann/hapi
App for Claude Code / Codex / Gemini / OpenCode, vibe coding anytime, anywhere
https://github.com/tiann/hapi
app claude-code codex gemini-cli opencode remote-control
Last synced: 12 days ago
JSON representation
App for Claude Code / Codex / Gemini / OpenCode, vibe coding anytime, anywhere
- Host: GitHub
- URL: https://github.com/tiann/hapi
- Owner: tiann
- License: agpl-3.0
- Created: 2025-12-24T10:44:41.000Z (3 months ago)
- Default Branch: main
- Last Pushed: 2026-02-27T01:01:24.000Z (14 days ago)
- Last Synced: 2026-02-27T08:34:57.381Z (13 days ago)
- Topics: app, claude-code, codex, gemini-cli, opencode, remote-control
- Language: TypeScript
- Homepage: https://hapi.run
- Size: 90.9 MB
- Stars: 1,888
- Watchers: 9
- Forks: 185
- Open Issues: 27
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Agents: AGENTS.md
Awesome Lists containing this project
README
# HAPI
Run official Claude Code / Codex / Gemini / OpenCode sessions locally and control them remotely through a Web / PWA / Telegram Mini App.
> **Why HAPI?** HAPI is a local-first alternative to Happy. See [Why Not Happy?](docs/guide/why-hapi.md) for the key differences.
## Features
- **Seamless Handoff** - Work locally, switch to remote when needed, switch back anytime. No context loss, no session restart.
- **Native First** - HAPI wraps your AI agent instead of replacing it. Same terminal, same experience, same muscle memory.
- **AFK Without Stopping** - Step away from your desk? Approve AI requests from your phone with one tap.
- **Your AI, Your Choice** - Claude Code, Codex, Gemini, OpenCode—different models, one unified workflow.
- **Terminal Anywhere** - Run commands from your phone or browser, directly connected to the working machine.
- **Voice Control** - Talk to your AI agent hands-free using the built-in voice assistant.
## Demo
https://github.com/user-attachments/assets/38230353-94c6-4dbe-9c29-b2a2cc457546
## Getting Started
```bash
npx @twsxtd/hapi hub --relay # start hub with E2E encrypted relay
npx @twsxtd/hapi # run claude code
```
`hapi server` remains supported as an alias.
The terminal will display a URL and QR code. Scan the QR code with your phone or open the URL to access.
> The relay uses WireGuard + TLS for end-to-end encryption. Your data is encrypted from your device to your machine.
For self-hosted options (Cloudflare Tunnel, Tailscale), see [Installation](docs/guide/installation.md)
## Docs
- [App](docs/guide/pwa.md)
- [How it Works](docs/guide/how-it-works.md)
- [Voice Assistant](docs/guide/voice-assistant.md)
- [Why HAPI](docs/guide/why-hapi.md)
- [FAQ](docs/guide/faq.md)
## Build from source
```bash
bun install
bun run build:single-exe
```
## Discussion
- Telegram: [@veryhapi](https://t.me/veryhapi)
## Credits
HAPI means "哈皮" a Chinese transliteration of [Happy](https://github.com/slopus/happy). Great credit to the original project.