@naarang/ccc 2.0.0-beta.7 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +200 -74
- package/dist/index.js +97 -54
- package/dist/scripts/build-binaries.ts +241 -24
- package/dist/scripts/install.ps1 +14 -5
- package/dist/scripts/install.sh +4 -3
- package/package.json +9 -1
- package/scripts/build-binaries.ts +241 -24
- package/scripts/install.ps1 +14 -5
- package/scripts/install.sh +4 -3
package/README.md
CHANGED
|
@@ -1,6 +1,73 @@
|
|
|
1
|
-
# CCC
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
# CCC - UI Interface for Coding Agents like Claude Code
|
|
2
|
+
|
|
3
|
+
**Control Claude Code and other coding agents from your mobile device**
|
|
4
|
+
|
|
5
|
+
CCC is a powerful CLI tool that creates a bridge between [Claude Code](https://claude.com/product/claude-code) and your mobile device, allowing you to chat with Claude and execute code operations remotely through the CCC mobile app.
|
|
6
|
+
|
|
7
|
+
[](https://www.npmjs.com/package/@naarang/ccc)
|
|
8
|
+
|
|
9
|
+

|
|
10
|
+
|
|
11
|
+
<p align="center">
|
|
12
|
+
<img src="https://firebasestorage.googleapis.com/v0/b/cc-chat-ui.firebasestorage.app/o/v2%2Fnpm_readme%2FWhatsApp%20Image%202026-01-16%20at%2010.55.20%20PM%20(2).jpeg?alt=media&token=9f71a100-c9ed-4e4e-ae60-f04b86c2b3e7" width="150" style="margin-right: 8px;" />
|
|
13
|
+
<img src="https://firebasestorage.googleapis.com/v0/b/cc-chat-ui.firebasestorage.app/o/v2%2Fnpm_readme%2FWhatsApp%20Image%202026-01-16%20at%2010.55.20%20PM%20(1).jpeg?alt=media&token=6fbb3693-17e1-439e-92f0-f634f79ad51f" width="150" style="margin-right: 8px;" />
|
|
14
|
+
<img src="https://firebasestorage.googleapis.com/v0/b/cc-chat-ui.firebasestorage.app/o/v2%2Fnpm_readme%2FWhatsApp%20Image%202026-01-16%20at%2010.55.20%20PM.jpeg?alt=media&token=3c74c222-7ea5-4e2c-961a-66bcc476a6d7" width="150" style="margin-right: 8px;" />
|
|
15
|
+
<img src="https://firebasestorage.googleapis.com/v0/b/cc-chat-ui.firebasestorage.app/o/v2%2Fnpm_readme%2FWhatsApp%20Image%202026-01-16%20at%2010.55.19%20PM%20(1).jpeg?alt=media&token=e4faec8b-4ad4-400e-9af8-2d0187157f97" width="150" style="margin-right: 8px;" />
|
|
16
|
+
<img src="https://firebasestorage.googleapis.com/v0/b/cc-chat-ui.firebasestorage.app/o/v2%2Fnpm_readme%2FWhatsApp%20Image%202026-01-16%20at%2010.55.19%20PM.jpeg?alt=media&token=b87ce7ad-dc6e-42d4-a6ac-2d1787f206bd" width="150" style="margin-right: 8px;" />
|
|
17
|
+
</p>
|
|
18
|
+
</p>
|
|
19
|
+
|
|
20
|
+
<p align="center">
|
|
21
|
+
<a href="https://play.google.com/store/apps/details?id=com.naarang.ccc">
|
|
22
|
+
<img src="https://firebasestorage.googleapis.com/v0/b/cc-chat-ui.firebasestorage.app/o/GetItOnGooglePlay_Badge_Web_color_English.png?alt=media&token=d2f34558-ce96-4882-9225-8ded76f759ba" alt="Get it on Google Play" height="80">
|
|
23
|
+
</a>
|
|
24
|
+
<br/>
|
|
25
|
+
<a href="https://play.google.com/apps/testing/com.naarang.ccc">
|
|
26
|
+
<sub>Join Android Beta Testing</sub>
|
|
27
|
+
</a>
|
|
28
|
+
</p>
|
|
29
|
+
|
|
30
|
+
<p align="center">
|
|
31
|
+
<a href="https://apps.apple.com/in/app/ccc-ui-for-coding-agents/id6753870766">
|
|
32
|
+
<img src="https://developer.apple.com/assets/elements/badges/download-on-the-app-store.svg" alt="Download on the App Store" height="80">
|
|
33
|
+
</a>
|
|
34
|
+
<br/>
|
|
35
|
+
<a href="https://testflight.apple.com/join/bEVNMrNH">
|
|
36
|
+
<sub>Join iOS Beta Testing (TestFlight)</sub>
|
|
37
|
+
</a>
|
|
38
|
+
</p>
|
|
39
|
+
|
|
40
|
+
<p align="center">
|
|
41
|
+
<a href="https://discord.gg/9EjE8t4YCF">
|
|
42
|
+
<img src="https://img.shields.io/badge/Discord-Join%20Server-5865F2?style=for-the-badge&logo=discord&logoColor=white" alt="Join our Discord">
|
|
43
|
+
</a>
|
|
44
|
+
</p>
|
|
45
|
+
|
|
46
|
+
<p align="center">
|
|
47
|
+
<a href="https://getc3.app">
|
|
48
|
+
<img src="https://img.shields.io/badge/Website-getc3.app-green?style=for-the-badge" alt="Visit Website">
|
|
49
|
+
</a>
|
|
50
|
+
|
|
51
|
+
<a href="https://getc3.app/docs">
|
|
52
|
+
<img src="https://img.shields.io/badge/Docs-Documentation-blue?style=for-the-badge" alt="Documentation">
|
|
53
|
+
</a>
|
|
54
|
+
</p>
|
|
55
|
+
|
|
56
|
+
## Features
|
|
57
|
+
|
|
58
|
+
- **Mobile Control** - Chat with Claude from your phone or tablet
|
|
59
|
+
- **Real-time Sync** - See Claude's responses instantly on your device
|
|
60
|
+
- **Smart Permission System** - Fine-grained control over code modifications
|
|
61
|
+
- **Web Terminal Access** - Full terminal access with auto-generated secure credentials
|
|
62
|
+
- **Checkpoints & Rewind** - Rewind Claude's changes to any checkpoint
|
|
63
|
+
- **Git Integration** - View diffs, commit, push, and create PRs from mobile
|
|
64
|
+
- **File Explorer & Editor** - Browse and edit project files with syntax highlighting
|
|
65
|
+
- **Session Resume** - Resume sessions and seamlessly switch between devices
|
|
66
|
+
- **Context Window Monitor** - Track token usage and context breakdown
|
|
67
|
+
- **Model Switcher** - Switch between Claude models during conversations
|
|
68
|
+
- **Push Notifications** - Get notified when Claude needs attention
|
|
69
|
+
- **Remote Access** - Optional ngrok integration for access from anywhere
|
|
70
|
+
- **Auto-Update System** - Automatic version checks and updates
|
|
4
71
|
|
|
5
72
|
## Requirements
|
|
6
73
|
|
|
@@ -15,11 +82,11 @@ powershell -c "irm bun.sh/install.ps1|iex"
|
|
|
15
82
|
curl -fsSL https://bun.sh/install | bash
|
|
16
83
|
```
|
|
17
84
|
|
|
18
|
-
Learn more
|
|
85
|
+
Learn more at [bun.sh](https://bun.sh)
|
|
19
86
|
|
|
20
87
|
## Installation
|
|
21
88
|
|
|
22
|
-
###
|
|
89
|
+
### Option 1: npm Install (Recommended)
|
|
23
90
|
|
|
24
91
|
```bash
|
|
25
92
|
npm install -g @naarang/ccc
|
|
@@ -30,107 +97,166 @@ Then run:
|
|
|
30
97
|
ccc
|
|
31
98
|
```
|
|
32
99
|
|
|
33
|
-
###
|
|
100
|
+
### Option 2: Standalone Binary (Beta)
|
|
101
|
+
|
|
102
|
+
For users who prefer not to install npm/Bun, standalone binaries are available:
|
|
34
103
|
|
|
104
|
+
**macOS / Linux:**
|
|
35
105
|
```bash
|
|
36
|
-
|
|
37
|
-
bun src/index.ts
|
|
106
|
+
curl -fsSL https://getc3.app/install.sh | bash
|
|
38
107
|
```
|
|
39
108
|
|
|
40
|
-
|
|
109
|
+
**Windows (PowerShell as Administrator):**
|
|
110
|
+
```powershell
|
|
111
|
+
irm https://getc3.app/install.ps1 | iex
|
|
112
|
+
```
|
|
113
|
+
|
|
114
|
+
The binary will be installed to `~/.ccc/bin` and added to your PATH.
|
|
115
|
+
|
|
116
|
+
## Quick Start
|
|
117
|
+
|
|
118
|
+
### 1. Start the Backend Server
|
|
41
119
|
|
|
42
120
|
```bash
|
|
43
|
-
# Start with default settings
|
|
44
121
|
ccc
|
|
122
|
+
```
|
|
45
123
|
|
|
46
|
-
|
|
47
|
-
ccc --debug
|
|
124
|
+
The server will start and display a QR code for easy mobile setup.
|
|
48
125
|
|
|
49
|
-
|
|
50
|
-
ccc --mqtt-port 8884 --router-port 8883 --terminal-port 3001
|
|
126
|
+
### 2. Configure the Mobile App
|
|
51
127
|
|
|
52
|
-
|
|
53
|
-
|
|
128
|
+
Download the CCC mobile app and scan the QR code, or manually add the server:
|
|
129
|
+
|
|
130
|
+
**For Local Network:**
|
|
131
|
+
```
|
|
132
|
+
Server URL: 192.168.x.xxx:8883
|
|
133
|
+
```
|
|
54
134
|
|
|
55
|
-
|
|
56
|
-
|
|
135
|
+
**For Remote Access:**
|
|
136
|
+
```bash
|
|
137
|
+
ccc --ngrok-token YOUR_TOKEN --username admin --password yourpassword
|
|
57
138
|
```
|
|
58
139
|
|
|
140
|
+
### 3. Start Chatting
|
|
141
|
+
|
|
142
|
+
Open the app, create a project pointing to your local directory, and start chatting with Claude!
|
|
143
|
+
|
|
59
144
|
## CLI Options
|
|
60
145
|
|
|
146
|
+
```bash
|
|
147
|
+
ccc [options]
|
|
148
|
+
|
|
149
|
+
Options:
|
|
150
|
+
-d, --debug Enable debug logging
|
|
151
|
+
--mqtt-port <port> Internal broker port (default: 8884)
|
|
152
|
+
--router-port <port> Main server port - app connects here (default: 8883)
|
|
153
|
+
--terminal-port <port> Terminal server port (default: 3001)
|
|
154
|
+
-u, --username <user> Authentication username (required for ngrok)
|
|
155
|
+
-p, --password <pass> Authentication password (required for ngrok)
|
|
156
|
+
-t, --ngrok-token <token> ngrok auth token for remote access
|
|
157
|
+
--ngrok-domain <domain> ngrok static domain (paid plan)
|
|
158
|
+
--no-auto-update Disable automatic updates
|
|
159
|
+
-v, --version Show version number
|
|
160
|
+
-h, --help Show help message
|
|
61
161
|
```
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
162
|
+
|
|
163
|
+
### Examples
|
|
164
|
+
|
|
165
|
+
```bash
|
|
166
|
+
# Basic usage (local network)
|
|
167
|
+
ccc
|
|
168
|
+
|
|
169
|
+
# With authentication
|
|
170
|
+
ccc -u admin -p secret
|
|
171
|
+
|
|
172
|
+
# With ngrok for remote access
|
|
173
|
+
ccc --ngrok-token YOUR_TOKEN -u admin -p secret
|
|
174
|
+
|
|
175
|
+
# Debug mode with custom ports
|
|
176
|
+
ccc --debug --router-port 9000
|
|
72
177
|
```
|
|
73
178
|
|
|
74
|
-
##
|
|
179
|
+
## Permission Modes
|
|
180
|
+
|
|
181
|
+
CCC offers four permission modes to balance convenience and security:
|
|
182
|
+
|
|
183
|
+
| Mode | Description | Use Case |
|
|
184
|
+
|------|-------------|----------|
|
|
185
|
+
| **Default** | Prompts for approval on first use | Balanced security |
|
|
186
|
+
| **Accept Edits** | Auto-approves file modifications | Active development |
|
|
187
|
+
| **Plan Mode** | Analysis only, no code changes | Code review |
|
|
188
|
+
| **Bypass All** | Skips all prompts (use with caution!) | Controlled environments |
|
|
75
189
|
|
|
76
|
-
|
|
190
|
+
## Terminal Access
|
|
77
191
|
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
192
|
+
CCC includes a built-in terminal accessible from the mobile app:
|
|
193
|
+
|
|
194
|
+
- Full terminal emulation with color support
|
|
195
|
+
- Auto-generated secure credentials
|
|
196
|
+
- Project-aware (opens in your project directory)
|
|
197
|
+
- Multiple concurrent sessions (max 5)
|
|
198
|
+
- Automatic resize on orientation change
|
|
85
199
|
|
|
86
200
|
## Security
|
|
87
201
|
|
|
88
202
|
- Terminal credentials are auto-generated and never logged
|
|
89
|
-
-
|
|
90
|
-
-
|
|
91
|
-
-
|
|
203
|
+
- Authentication required for remote access (ngrok)
|
|
204
|
+
- All internal services bind to localhost only
|
|
205
|
+
- Rate limiting on failed authentication attempts
|
|
92
206
|
|
|
93
|
-
##
|
|
207
|
+
## System Requirements
|
|
94
208
|
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
├── services/ # Service implementations
|
|
100
|
-
│ ├── mqtt-broker/ # MQTT broker
|
|
101
|
-
│ ├── terminal-server/ # Terminal server
|
|
102
|
-
│ ├── router/ # HTTP/WS proxy
|
|
103
|
-
│ ├── claude-agent/ # Claude Code CLI management
|
|
104
|
-
│ ├── file-browser/ # File system access
|
|
105
|
-
│ ├── git-service/ # Git operations
|
|
106
|
-
│ ├── notification/ # Push notifications
|
|
107
|
-
│ └── ... # Other services
|
|
108
|
-
├── core/ # Service orchestration
|
|
109
|
-
└── utils/ # Shared utilities
|
|
110
|
-
```
|
|
209
|
+
- **Bun**: v1.0.0 or higher
|
|
210
|
+
- **Claude Code**: Latest version ([Download](https://claude.com/product/claude-code))
|
|
211
|
+
- **Claude Subscription**: Active Pro / Max account or API KEY
|
|
212
|
+
- **Operating Systems**: Linux, macOS, Windows
|
|
111
213
|
|
|
112
|
-
##
|
|
214
|
+
## Troubleshooting
|
|
113
215
|
|
|
114
|
-
|
|
115
|
-
# Run in development mode
|
|
116
|
-
bun src/index.ts --debug
|
|
216
|
+
### Server Won't Start
|
|
117
217
|
|
|
118
|
-
|
|
119
|
-
|
|
218
|
+
```bash
|
|
219
|
+
# Check if ports are in use
|
|
220
|
+
lsof -i :8883
|
|
221
|
+
lsof -i :8884
|
|
120
222
|
|
|
121
|
-
#
|
|
122
|
-
|
|
223
|
+
# Use different ports
|
|
224
|
+
ccc --router-port 9000 --mqtt-port 9001
|
|
123
225
|
```
|
|
124
226
|
|
|
125
|
-
|
|
227
|
+
### Connection Issues
|
|
228
|
+
|
|
229
|
+
1. Ensure you're on the same WiFi network (for local connections)
|
|
230
|
+
2. Check firewall allows port 8883
|
|
231
|
+
3. Use correct format: `hostname:8883` (no `http://`)
|
|
232
|
+
4. Enable debug mode: `ccc --debug`
|
|
233
|
+
|
|
234
|
+
### Claude Not Responding
|
|
235
|
+
|
|
236
|
+
1. Verify Claude Code is installed: `claude --version`
|
|
237
|
+
2. Check authentication: `claude auth status`
|
|
238
|
+
3. Verify project path exists and is accessible
|
|
239
|
+
|
|
240
|
+
## Support & Community
|
|
241
|
+
|
|
242
|
+
- **Documentation**: [getc3.app/docs](https://getc3.app/docs)
|
|
243
|
+
- **Discord**: [Join our community](https://discord.gg/9EjE8t4YCF)
|
|
244
|
+
- **Email**: cccuiapp@gmail.com
|
|
245
|
+
|
|
246
|
+
## Support the Project
|
|
247
|
+
|
|
248
|
+
If you find CCC useful, consider supporting its development:
|
|
249
|
+
|
|
250
|
+
<p align="center">
|
|
251
|
+
<a href="https://getc3.app/support">
|
|
252
|
+
<img src="https://img.shields.io/badge/Support-CCC-blue?style=for-the-badge" alt="Support CCC">
|
|
253
|
+
</a>
|
|
254
|
+
</p>
|
|
126
255
|
|
|
127
|
-
|
|
128
|
-
- Native TypeScript support without transpilation
|
|
129
|
-
- Faster startup and runtime performance
|
|
130
|
-
- Built-in WebSocket server (`Bun.serve()`)
|
|
131
|
-
- `bun-pty` for reliable PTY handling (node-pty has compatibility issues)
|
|
132
|
-
- Simpler dependency management
|
|
256
|
+
---
|
|
133
257
|
|
|
134
|
-
|
|
258
|
+
**Made with ❤️ by naarang**
|
|
135
259
|
|
|
136
|
-
|
|
260
|
+
> **Note**: This tool requires an active Claude subscription and Claude Code to function properly. This project is not affiliated with, endorsed by, or sponsored in any form by Anthropic, Claude or Claude Code.
|
|
261
|
+
Claude & Claude Code are/may be a trademark and product of Anthropic, PBC.
|
|
262
|
+
This is an independent project built to use Claude Code in a convenient way.
|