@pixelbyte-software/pixcode 1.51.1 → 1.51.3
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/CODE_OF_CONDUCT.md +41 -41
- package/CONTRIBUTING.md +155 -155
- package/LICENSE +718 -718
- package/README.de.md +169 -169
- package/README.ja.md +167 -167
- package/README.ko.md +167 -167
- package/README.md +419 -419
- package/README.ru.md +169 -169
- package/README.tr.md +298 -298
- package/README.zh-CN.md +167 -167
- package/SECURITY.md +46 -46
- package/dist/api-automation.html +110 -110
- package/dist/api-docs.html +548 -548
- package/dist/assets/{index-DARIZgoD.js → index-17CwxHSZ.js} +185 -185
- package/dist/assets/index-B9N-gfOQ.css +32 -0
- package/dist/clear-cache.html +85 -85
- package/dist/convert-icons.md +52 -52
- package/dist/docs.html +308 -308
- package/dist/favicon.svg +8 -8
- package/dist/features.html +133 -133
- package/dist/generate-icons.js +48 -48
- package/dist/humans.txt +15 -15
- package/dist/icons/codex-white.svg +3 -3
- package/dist/icons/codex.svg +3 -3
- package/dist/icons/cursor-white.svg +11 -11
- package/dist/icons/icon-128x128.svg +9 -9
- package/dist/icons/icon-144x144.svg +9 -9
- package/dist/icons/icon-152x152.svg +9 -9
- package/dist/icons/icon-192x192.svg +9 -9
- package/dist/icons/icon-384x384.svg +9 -9
- package/dist/icons/icon-512x512.svg +9 -9
- package/dist/icons/icon-72x72.svg +9 -9
- package/dist/icons/icon-96x96.svg +9 -9
- package/dist/icons/icon-template.svg +9 -9
- package/dist/icons/qwen-logo.svg +14 -14
- package/dist/index.html +59 -59
- package/dist/landing.html +268 -268
- package/dist/llms-full.txt +119 -119
- package/dist/llms.txt +53 -53
- package/dist/logo.svg +12 -12
- package/dist/manifest.json +60 -60
- package/dist/openapi.yaml +1696 -1696
- package/dist/orchestration.html +125 -125
- package/dist/robots.txt +4 -4
- package/dist/site.css +692 -692
- package/dist/sitemap.xml +51 -51
- package/dist/sw.js +132 -132
- package/dist-server/server/cli.js +96 -96
- package/dist-server/server/daemon/manager.js +33 -33
- package/dist-server/server/daemon-manager.js +64 -64
- package/dist-server/server/index.js +125 -4
- package/dist-server/server/index.js.map +1 -1
- package/dist-server/server/modules/orchestration/a2a/adapters/json-event.adapter.js +84 -0
- package/dist-server/server/modules/orchestration/a2a/adapters/json-event.adapter.js.map +1 -0
- package/dist-server/server/modules/orchestration/a2a/adapters/json-event.adapter.test.js +43 -0
- package/dist-server/server/modules/orchestration/a2a/adapters/json-event.adapter.test.js.map +1 -0
- package/dist-server/server/modules/orchestration/hermes/hermes.routes.js +55 -1
- package/dist-server/server/modules/orchestration/hermes/hermes.routes.js.map +1 -1
- package/dist-server/server/modules/orchestration/index.js +1 -0
- package/dist-server/server/modules/orchestration/index.js.map +1 -1
- package/dist-server/server/routes/commands.js +25 -25
- package/dist-server/server/routes/git.js +17 -17
- package/dist-server/server/routes/live-view.js +46 -46
- package/dist-server/server/services/hermes-gateway.js +310 -0
- package/dist-server/server/services/hermes-gateway.js.map +1 -1
- package/dist-server/server/services/public-api-manifest.js +59 -51
- package/dist-server/server/services/public-api-manifest.js.map +1 -1
- package/package.json +222 -222
- package/scripts/fix-node-pty.js +67 -67
- package/scripts/github/create-v1.38-issues.mjs +351 -351
- package/scripts/github/create-vscode-workbench-issues.mjs +121 -121
- package/scripts/hermes/configure-pixcode-mcp.mjs +165 -163
- package/scripts/hermes/pixcode-mcp-server.mjs +1009 -958
- package/scripts/smoke/changes-panel-layout.mjs +48 -48
- package/scripts/smoke/chat-composer-fixed-layout.mjs +55 -55
- package/scripts/smoke/chat-message-timeline-order.mjs +41 -41
- package/scripts/smoke/chat-realtime-hydration.mjs +44 -44
- package/scripts/smoke/chat-session-provider-pools.mjs +35 -35
- package/scripts/smoke/chat-session-state.mjs +19 -19
- package/scripts/smoke/code-editor-theme.mjs +55 -55
- package/scripts/smoke/code-editor-vscode-engine.mjs +91 -91
- package/scripts/smoke/command-center-agent-writes.mjs +79 -79
- package/scripts/smoke/command-center-non-git.mjs +46 -46
- package/scripts/smoke/context-packet.mjs +43 -43
- package/scripts/smoke/control-room-ux-redesign.mjs +91 -91
- package/scripts/smoke/daemon-entrypoint.mjs +20 -20
- package/scripts/smoke/default-landing-routing.mjs +33 -33
- package/scripts/smoke/desktop-native-notifications.mjs +30 -30
- package/scripts/smoke/desktop-tray-icon.mjs +33 -33
- package/scripts/smoke/discord-release-workflow.mjs +24 -24
- package/scripts/smoke/git-install-update.mjs +255 -255
- package/scripts/smoke/handoff-artifact-protocol.mjs +50 -50
- package/scripts/smoke/hermes-api-install.mjs +56 -56
- package/scripts/smoke/hermes-gateway-persistence.mjs +104 -104
- package/scripts/smoke/hermes-mcp-pixcode-roundtrip.mjs +426 -367
- package/scripts/smoke/hermes-rest-chat-api.mjs +162 -162
- package/scripts/smoke/hermes-rest-chat-live.mjs +45 -45
- package/scripts/smoke/hermes-rest-codex-launch.mjs +209 -209
- package/scripts/smoke/hermes-rest-gateway.mjs +79 -70
- package/scripts/smoke/hermes-rest-live.mjs +42 -42
- package/scripts/smoke/hermes-roundtrip.mjs +167 -167
- package/scripts/smoke/hermes-settings-commands.mjs +349 -346
- package/scripts/smoke/hermes-smoke-launcher-guard.mjs +34 -34
- package/scripts/smoke/live-view-diagnostics.mjs +53 -53
- package/scripts/smoke/live-view-environment.mjs +92 -92
- package/scripts/smoke/live-view-integration.mjs +450 -450
- package/scripts/smoke/mac-desktop-runtime.mjs +37 -37
- package/scripts/smoke/mobile-tunnel-guidance.mjs +29 -29
- package/scripts/smoke/model-registry.mjs +36 -36
- package/scripts/smoke/multi-project-ui.mjs +45 -45
- package/scripts/smoke/multi-worker-slots.mjs +42 -42
- package/scripts/smoke/notification-center.mjs +87 -87
- package/scripts/smoke/notification-inapp-preference.mjs +23 -23
- package/scripts/smoke/notification-taxonomy.mjs +58 -58
- package/scripts/smoke/orchestration-api.mjs +172 -172
- package/scripts/smoke/orchestration-execution-dashboard.mjs +33 -33
- package/scripts/smoke/orchestration-live-run.mjs +176 -176
- package/scripts/smoke/orchestration-mobile-scroll.mjs +29 -29
- package/scripts/smoke/orchestration-model-sync.mjs +30 -30
- package/scripts/smoke/orchestration-permission-fallback.mjs +34 -34
- package/scripts/smoke/orchestration-runtime-guards.mjs +48 -48
- package/scripts/smoke/orchestration-user-facing-output.mjs +25 -25
- package/scripts/smoke/permission-policy.mjs +50 -50
- package/scripts/smoke/pixcode-workbench-1-48.mjs +167 -164
- package/scripts/smoke/provider-models-opencode-live.mjs +66 -66
- package/scripts/smoke/provider-rest-api.mjs +124 -124
- package/scripts/smoke/provider-selection-status.mjs +52 -52
- package/scripts/smoke/run-state-refresh.mjs +52 -52
- package/scripts/smoke/runtime-manager.mjs +99 -99
- package/scripts/smoke/shell-manual-disconnect.mjs +30 -30
- package/scripts/smoke/side-panel-editor-layout.mjs +34 -34
- package/scripts/smoke/static-root-routing.mjs +21 -21
- package/scripts/smoke/strict-handoff-compact.mjs +60 -60
- package/scripts/smoke/taskmaster-config.mjs +24 -24
- package/scripts/smoke/taskmaster-execution-telegram.mjs +3 -3
- package/scripts/smoke/taskmaster-onboarding.mjs +3 -3
- package/scripts/smoke/taskmaster-run-graph.mjs +3 -3
- package/scripts/smoke/telegram-control.mjs +242 -242
- package/scripts/smoke/tunnel-persistence.mjs +56 -56
- package/scripts/smoke/update-issue-progress.mjs +69 -69
- package/scripts/smoke/update-ux.mjs +55 -55
- package/scripts/smoke/v138-completion.mjs +132 -132
- package/scripts/smoke/v138-desktop-release-hardening.mjs +69 -69
- package/scripts/smoke/v138-diagnostics.mjs +63 -63
- package/scripts/smoke/v138-issue-planner.mjs +33 -33
- package/scripts/smoke/v143-remote-control.mjs +76 -76
- package/scripts/smoke/v144-production-loop.mjs +47 -47
- package/scripts/smoke/v145-platformization.mjs +46 -46
- package/scripts/smoke/v146-control-room-ui.mjs +150 -150
- package/scripts/smoke/version-modal-autoshow.mjs +29 -29
- package/scripts/smoke/vscode-workbench-layout.mjs +63 -63
- package/scripts/smoke/vscode-workbench-polish.mjs +461 -436
- package/scripts/smoke/workflow-fallback-replay.mjs +56 -56
- package/scripts/smoke/workflow-templates.mjs +43 -43
- package/scripts/smoke/workflow-trace-timeline.mjs +46 -46
- package/scripts/update-git-install.mjs +293 -293
- package/server/claude-sdk.js +920 -920
- package/server/cli.js +1039 -1039
- package/server/constants/config.js +4 -4
- package/server/cursor-cli.js +344 -344
- package/server/daemon/manager.js +563 -563
- package/server/daemon-manager.js +964 -964
- package/server/database/db.js +921 -921
- package/server/database/json-store.js +197 -197
- package/server/gemini-cli.js +550 -550
- package/server/gemini-response-handler.js +79 -79
- package/server/index.js +131 -3
- package/server/load-env.js +35 -35
- package/server/middleware/auth.js +175 -175
- package/server/modules/orchestration/a2a/adapter-registry.ts +108 -108
- package/server/modules/orchestration/a2a/adapters/abstract-a2a.adapter.ts +63 -63
- package/server/modules/orchestration/a2a/adapters/claude-code.adapter.ts +286 -286
- package/server/modules/orchestration/a2a/adapters/codex.adapter.ts +244 -244
- package/server/modules/orchestration/a2a/adapters/cursor.adapter.ts +249 -249
- package/server/modules/orchestration/a2a/adapters/gemini.adapter.ts +248 -248
- package/server/modules/orchestration/a2a/adapters/json-event.adapter.test.ts +60 -0
- package/server/modules/orchestration/a2a/adapters/json-event.adapter.ts +101 -0
- package/server/modules/orchestration/a2a/adapters/opencode.adapter.ts +248 -248
- package/server/modules/orchestration/a2a/adapters/qwen.adapter.ts +248 -248
- package/server/modules/orchestration/a2a/agent-card.ts +55 -55
- package/server/modules/orchestration/a2a/routes.ts +590 -590
- package/server/modules/orchestration/a2a/task-store.ts +178 -178
- package/server/modules/orchestration/a2a/types.ts +126 -126
- package/server/modules/orchestration/a2a/validator.ts +113 -113
- package/server/modules/orchestration/hermes/hermes.routes.ts +642 -583
- package/server/modules/orchestration/index.ts +101 -100
- package/server/modules/orchestration/preview/port-watcher.ts +112 -112
- package/server/modules/orchestration/preview/preview-proxy.ts +60 -60
- package/server/modules/orchestration/preview/types.ts +19 -19
- package/server/modules/orchestration/security/permission-policy.ts +401 -401
- package/server/modules/orchestration/tasks/orchestration-task-store.ts +41 -41
- package/server/modules/orchestration/tasks/orchestration-task.routes.ts +64 -64
- package/server/modules/orchestration/tasks/orchestration-task.service.ts +209 -209
- package/server/modules/orchestration/tasks/orchestration-task.types.ts +40 -40
- package/server/modules/orchestration/tasks/task-run-graph.ts +155 -155
- package/server/modules/orchestration/workflows/approval-queue.ts +106 -106
- package/server/modules/orchestration/workflows/built-in-workflows.ts +127 -127
- package/server/modules/orchestration/workflows/context-packet.ts +186 -186
- package/server/modules/orchestration/workflows/handoff-artifact.ts +175 -175
- package/server/modules/orchestration/workflows/workflow-fallback-policy.ts +161 -161
- package/server/modules/orchestration/workflows/workflow-replay.ts +254 -254
- package/server/modules/orchestration/workflows/workflow-runner.ts +2070 -2070
- package/server/modules/orchestration/workflows/workflow-store.ts +97 -97
- package/server/modules/orchestration/workflows/workflow-templates.ts +272 -272
- package/server/modules/orchestration/workflows/workflow-trace.ts +424 -424
- package/server/modules/orchestration/workflows/workflow.routes.ts +586 -586
- package/server/modules/orchestration/workflows/workflow.types.ts +111 -111
- package/server/modules/orchestration/workflows/workspace-target.ts +122 -122
- package/server/modules/orchestration/workspace/docker-workspace.ts +136 -136
- package/server/modules/orchestration/workspace/path-safety.ts +55 -55
- package/server/modules/orchestration/workspace/types.ts +52 -52
- package/server/modules/orchestration/workspace/workspace-manager.ts +102 -102
- package/server/modules/orchestration/workspace/worktree-workspace.ts +126 -126
- package/server/modules/providers/index.ts +2 -2
- package/server/modules/providers/list/claude/claude-auth.provider.ts +146 -146
- package/server/modules/providers/list/claude/claude-mcp.provider.ts +135 -135
- package/server/modules/providers/list/claude/claude-sessions.provider.ts +306 -306
- package/server/modules/providers/list/claude/claude.provider.ts +15 -15
- package/server/modules/providers/list/codex/codex-auth.provider.ts +117 -117
- package/server/modules/providers/list/codex/codex-mcp.provider.ts +135 -135
- package/server/modules/providers/list/codex/codex-sessions.provider.ts +319 -319
- package/server/modules/providers/list/codex/codex.provider.ts +15 -15
- package/server/modules/providers/list/cursor/cursor-auth.provider.ts +147 -147
- package/server/modules/providers/list/cursor/cursor-mcp.provider.ts +108 -108
- package/server/modules/providers/list/cursor/cursor-sessions.provider.ts +421 -421
- package/server/modules/providers/list/cursor/cursor.provider.ts +15 -15
- package/server/modules/providers/list/gemini/gemini-auth.provider.ts +173 -173
- package/server/modules/providers/list/gemini/gemini-mcp.provider.ts +110 -110
- package/server/modules/providers/list/gemini/gemini-sessions.provider.ts +227 -227
- package/server/modules/providers/list/gemini/gemini.provider.ts +15 -15
- package/server/modules/providers/list/opencode/opencode-auth.provider.ts +131 -131
- package/server/modules/providers/list/opencode/opencode-mcp.provider.ts +126 -126
- package/server/modules/providers/list/opencode/opencode-sessions.provider.ts +286 -286
- package/server/modules/providers/list/opencode/opencode.provider.ts +29 -29
- package/server/modules/providers/list/qwen/qwen-auth.provider.ts +146 -146
- package/server/modules/providers/list/qwen/qwen-mcp.provider.ts +114 -114
- package/server/modules/providers/list/qwen/qwen-sessions.provider.ts +265 -265
- package/server/modules/providers/list/qwen/qwen.provider.ts +21 -21
- package/server/modules/providers/provider.registry.ts +40 -40
- package/server/modules/providers/provider.routes.ts +944 -944
- package/server/modules/providers/services/mcp.service.ts +86 -86
- package/server/modules/providers/services/provider-auth.service.ts +26 -26
- package/server/modules/providers/services/sessions.service.ts +45 -45
- package/server/modules/providers/shared/base/abstract.provider.ts +20 -20
- package/server/modules/providers/shared/mcp/mcp.provider.ts +151 -151
- package/server/modules/providers/shared/provider-configs.ts +142 -142
- package/server/modules/providers/tests/mcp.test.ts +293 -293
- package/server/openai-codex.js +462 -462
- package/server/opencode-cli.js +491 -491
- package/server/opencode-response-handler.js +111 -111
- package/server/projects.js +3008 -3008
- package/server/qwen-code-cli.js +410 -410
- package/server/qwen-response-handler.js +73 -73
- package/server/routes/agent.js +1435 -1435
- package/server/routes/auth.js +159 -159
- package/server/routes/codex.js +20 -20
- package/server/routes/commands.js +570 -570
- package/server/routes/cursor.js +61 -61
- package/server/routes/diagnostics.js +41 -41
- package/server/routes/gemini.js +25 -25
- package/server/routes/git.js +1650 -1650
- package/server/routes/live-view.js +411 -411
- package/server/routes/mcp-utils.js +13 -13
- package/server/routes/messages.js +62 -62
- package/server/routes/network.js +125 -125
- package/server/routes/platformization.js +212 -212
- package/server/routes/plugins.js +320 -320
- package/server/routes/production-agent-loop.js +90 -90
- package/server/routes/projects.js +917 -917
- package/server/routes/public-api.js +34 -34
- package/server/routes/qwen.js +27 -27
- package/server/routes/remote.js +55 -55
- package/server/routes/settings.js +321 -321
- package/server/routes/telegram.js +140 -140
- package/server/routes/user.js +125 -125
- package/server/routes/webhooks.js +63 -63
- package/server/services/control-room.js +102 -102
- package/server/services/diagnostics.js +165 -165
- package/server/services/external-access.js +375 -375
- package/server/services/hermes-gateway.js +1562 -1247
- package/server/services/hermes-install-jobs.js +729 -729
- package/server/services/install-jobs.js +715 -715
- package/server/services/live-view.js +956 -956
- package/server/services/managed-runtimes.js +493 -493
- package/server/services/model-registry.js +144 -144
- package/server/services/notification-orchestrator.js +365 -365
- package/server/services/notification-taxonomy.js +204 -204
- package/server/services/platformization.js +815 -815
- package/server/services/production-agent-loop.js +248 -248
- package/server/services/provider-cli-versions.js +149 -149
- package/server/services/provider-credentials.js +189 -189
- package/server/services/provider-models.js +396 -396
- package/server/services/public-api-manifest.js +190 -182
- package/server/services/remote-connection.js +127 -127
- package/server/services/runtime-manager.js +323 -323
- package/server/services/startup-update.js +234 -234
- package/server/services/telegram/bot.js +331 -331
- package/server/services/telegram/control-center.js +979 -979
- package/server/services/telegram/telegram-http-client.js +151 -151
- package/server/services/telegram/translations.js +340 -340
- package/server/services/vapid-keys.js +36 -36
- package/server/services/webhooks.js +216 -216
- package/server/sessionManager.js +225 -225
- package/server/shared/interfaces.ts +54 -54
- package/server/shared/types.ts +172 -172
- package/server/shared/utils.ts +193 -193
- package/server/tsconfig.json +36 -36
- package/server/utils/colors.js +21 -21
- package/server/utils/commandParser.js +305 -305
- package/server/utils/frontmatter.js +18 -18
- package/server/utils/gitConfig.js +34 -34
- package/server/utils/plugin-loader.js +457 -457
- package/server/utils/plugin-process-manager.js +185 -185
- package/server/utils/port-access.js +209 -209
- package/server/utils/runtime-paths.js +37 -37
- package/server/utils/url-detection.js +71 -71
- package/server/vite-daemon.js +79 -79
- package/shared/modelConstants.js +161 -161
- package/shared/networkHosts.js +22 -22
- package/dist/assets/index-DMz0zv6T.css +0 -32
package/README.md
CHANGED
|
@@ -1,419 +1,419 @@
|
|
|
1
|
-
<div align="center">
|
|
2
|
-
<img src="public/logo.png" alt="Pixcode logo" width="92" height="92" />
|
|
3
|
-
<h1>Pixcode</h1>
|
|
4
|
-
<p><strong>Self-hosted control plane for AI coding agents.</strong></p>
|
|
5
|
-
<p>
|
|
6
|
-
Pixcode lets you run AI coding CLIs, inspect files, manage shell and source control,
|
|
7
|
-
orchestrate agent teams, automate through APIs, and keep long-running work alive from
|
|
8
|
-
your own computer or server.
|
|
9
|
-
</p>
|
|
10
|
-
<p>
|
|
11
|
-
<a href="https://www.npmjs.com/package/@pixelbyte-software/pixcode"><img src="https://img.shields.io/npm/v/@pixelbyte-software/pixcode?style=for-the-badge&color=10b981" alt="npm version" /></a>
|
|
12
|
-
<a href="https://github.com/alicomert/pixcode/releases/latest"><img src="https://img.shields.io/github/v/release/alicomert/pixcode?style=for-the-badge&color=0ea5e9" alt="latest release" /></a>
|
|
13
|
-
<img src="https://img.shields.io/badge/Node.js-22%2B-3c873a?style=for-the-badge" alt="Node.js 22+" />
|
|
14
|
-
<img src="https://img.shields.io/badge/Desktop-Windows%20%7C%20macOS%20%7C%20Linux-6366f1?style=for-the-badge" alt="desktop platforms" />
|
|
15
|
-
</p>
|
|
16
|
-
<p>
|
|
17
|
-
<a href="https://buymeacoffee.com/alicomert" target="_blank" rel="noopener noreferrer"><img src="https://img.shields.io/badge/Buy%20me%20a%20coffee-support%20Pixcode-ffdd00?style=for-the-badge&logo=buymeacoffee&logoColor=000000" alt="Buy me a coffee" /></a>
|
|
18
|
-
</p>
|
|
19
|
-
<p>
|
|
20
|
-
<a href="https://www.producthunt.com/products/pixcode?embed=true&utm_source=badge-featured&utm_medium=badge&utm_campaign=badge-pixcode" target="_blank" rel="noopener noreferrer"><img alt="Pixcode - A self-hosted control room for AI coding agents. | Product Hunt" width="250" height="54" src="https://api.producthunt.com/widgets/embed-image/v1/featured.svg?post_id=1144104&theme=light&t=1778502023682"></a>
|
|
21
|
-
</p>
|
|
22
|
-
<p>
|
|
23
|
-
<a href="https://alicomert.github.io/pixcode/landing.html">Website</a> ·
|
|
24
|
-
<a href="https://github.com/alicomert/pixcode/releases/latest">Releases</a> ·
|
|
25
|
-
<a href="public/docs.html">Docs</a> ·
|
|
26
|
-
<a href="public/openapi.yaml">OpenAPI</a> ·
|
|
27
|
-
<a href="CONTRIBUTING.md">Contributing</a>
|
|
28
|
-
</p>
|
|
29
|
-
<p>
|
|
30
|
-
<a href="README.tr.md">Turkce</a> ·
|
|
31
|
-
<a href="README.de.md">Deutsch</a> ·
|
|
32
|
-
<a href="README.ru.md">Русский</a> ·
|
|
33
|
-
<a href="README.ja.md">日本語</a> ·
|
|
34
|
-
<a href="README.ko.md">한국어</a> ·
|
|
35
|
-
<a href="README.zh-CN.md">简体中文</a>
|
|
36
|
-
</p>
|
|
37
|
-
</div>
|
|
38
|
-
|
|
39
|
-
## What Pixcode Does
|
|
40
|
-
|
|
41
|
-
Pixcode is a local web and desktop workspace for AI coding agents. It wraps the
|
|
42
|
-
CLIs developers already use, then adds the missing control layer around them:
|
|
43
|
-
project selection, chat history, file navigation, shell access, Git/local change
|
|
44
|
-
tracking, orchestration, notifications, Telegram control, and API automation.
|
|
45
|
-
|
|
46
|
-
Use it when one terminal is not enough:
|
|
47
|
-
|
|
48
|
-
- You want Claude Code, Cursor CLI, Codex, Gemini CLI, Qwen Code, and OpenCode
|
|
49
|
-
available from the same project screen.
|
|
50
|
-
- You want agent output, edited files, shell commands, Git status, and task
|
|
51
|
-
planning visible without switching tools.
|
|
52
|
-
- You want a server or desktop app that keeps work running while you connect
|
|
53
|
-
from another computer, tablet, phone, or Telegram.
|
|
54
|
-
- You want a real API surface so other tools can create sessions, run agents,
|
|
55
|
-
inspect projects, and automate workflows with `px_` API keys.
|
|
56
|
-
|
|
57
|
-
Pixcode is not a hosted cloud IDE. Your source code, CLI sessions, credentials,
|
|
58
|
-
project paths, MCP configuration, local database, and automation keys stay on the
|
|
59
|
-
machine where Pixcode runs unless you intentionally expose or connect them.
|
|
60
|
-
|
|
61
|
-
## Screenshots
|
|
62
|
-
|
|
63
|
-
| Workspace control room | Mobile chat |
|
|
64
|
-
| --- | --- |
|
|
65
|
-
| <img src="public/screenshots/desktop-main.png" alt="Pixcode desktop workspace with chat, project controls, and side panels" width="480" /> | <img src="public/screenshots/mobile-chat.png" alt="Pixcode mobile chat" width="260" /> |
|
|
66
|
-
|
|
67
|
-
| CLI selection | Tools and MCP |
|
|
68
|
-
| --- | --- |
|
|
69
|
-
| <img src="public/screenshots/cli-selection.png" alt="Pixcode CLI selection" width="420" /> | <img src="public/screenshots/tools-modal.png" alt="Pixcode tools and MCP modal" width="420" /> |
|
|
70
|
-
|
|
71
|
-
## Core Features
|
|
72
|
-
|
|
73
|
-
### Multi-CLI agent workspace
|
|
74
|
-
|
|
75
|
-
Pixcode gives every supported coding CLI a shared workspace without hiding the
|
|
76
|
-
provider-native behavior. You can connect the providers you already use and move
|
|
77
|
-
between them from the same project.
|
|
78
|
-
|
|
79
|
-
- Claude Code
|
|
80
|
-
- Cursor CLI
|
|
81
|
-
- OpenAI Codex
|
|
82
|
-
- Gemini CLI
|
|
83
|
-
- Qwen Code
|
|
84
|
-
- OpenCode
|
|
85
|
-
|
|
86
|
-
Provider panels cover auth state, install checks, CLI versions, model choices,
|
|
87
|
-
MCP support, and session history. When an agent is thinking, running tools,
|
|
88
|
-
waiting for approval, or writing output, the UI keeps visible processing state
|
|
89
|
-
instead of leaving the screen feeling frozen.
|
|
90
|
-
|
|
91
|
-
### Chat built for development work
|
|
92
|
-
|
|
93
|
-
Pixcode chat is project-aware and designed for long-running coding sessions.
|
|
94
|
-
|
|
95
|
-
- Fixed bottom composer on chat/project screens.
|
|
96
|
-
- Session history per provider and project.
|
|
97
|
-
- Default, plan, and run-style modes where supported.
|
|
98
|
-
- Slash-command friendly input.
|
|
99
|
-
- Tool output rendering for plans, file operations, command output, and provider
|
|
100
|
-
status events.
|
|
101
|
-
- Telegram and browser/desktop notifications when work finishes, fails, or needs
|
|
102
|
-
attention.
|
|
103
|
-
|
|
104
|
-
### Files, shell, and source control
|
|
105
|
-
|
|
106
|
-
The side panels are built around the way coding agents change projects.
|
|
107
|
-
|
|
108
|
-
- Files panel with detailed and compact views.
|
|
109
|
-
- File open/edit flows that preserve the main chat or orchestration surface.
|
|
110
|
-
- Shell panel with split/full behavior on desktop and mobile-safe behavior on
|
|
111
|
-
smaller screens.
|
|
112
|
-
- Source Control panel for Git status, diffs, branches, commits, and changed
|
|
113
|
-
files when a project is a Git repository.
|
|
114
|
-
- Local change tracking for projects that are not Git repositories.
|
|
115
|
-
|
|
116
|
-
### Command Center for changed files
|
|
117
|
-
|
|
118
|
-
Command Center watches what changes while agents work. It can track Git changes
|
|
119
|
-
or local filesystem changes, show the changed file list next to the active chat,
|
|
120
|
-
highlight changed items, and open the edited file at the relevant location.
|
|
121
|
-
|
|
122
|
-
This is meant to answer the practical question: "What did the agent just touch?"
|
|
123
|
-
|
|
124
|
-
### Multi-agent orchestration
|
|
125
|
-
|
|
126
|
-
Pixcode can run structured agent workflows instead of sending every prompt to one
|
|
127
|
-
agent.
|
|
128
|
-
|
|
129
|
-
Built-in workflow styles include:
|
|
130
|
-
|
|
131
|
-
- Agent Team: split a job across implementation, review, docs, testing, or
|
|
132
|
-
custom roles.
|
|
133
|
-
- Sequential Handoff: pass compact context from one stage to the next.
|
|
134
|
-
- Multi-model Review: compare provider/model opinions on the same code or plan.
|
|
135
|
-
- Decision Debate: make multiple agents argue approaches before acting.
|
|
136
|
-
|
|
137
|
-
Orchestration controls include:
|
|
138
|
-
|
|
139
|
-
- per-agent provider and model selection,
|
|
140
|
-
- custom labels, roles, and instructions,
|
|
141
|
-
- duplicate providers when multiple workers should use the same CLI,
|
|
142
|
-
- fallback CLI selection for failed steps,
|
|
143
|
-
- run preview before execution,
|
|
144
|
-
- streamed step output and final report,
|
|
145
|
-
- resizable setup/output panes.
|
|
146
|
-
|
|
147
|
-
### Hermes Agent orchestration
|
|
148
|
-
|
|
149
|
-
Pixcode uses Hermes Agent as the orchestration control plane for background
|
|
150
|
-
agent work. Hermes runs inside the current Pixcode instance, understands the
|
|
151
|
-
active project context, and can route bounded tasks to Claude Code, Codex,
|
|
152
|
-
Cursor, Gemini, Qwen, or OpenCode through terminal-first CLI adapters.
|
|
153
|
-
|
|
154
|
-
Hermes controls include:
|
|
155
|
-
|
|
156
|
-
- project-scoped task context,
|
|
157
|
-
- provider/model routing,
|
|
158
|
-
- streamed task status and artifacts,
|
|
159
|
-
- workflow run coordination,
|
|
160
|
-
- background checks and previews,
|
|
161
|
-
- authenticated local APIs under `/api/orchestration/hermes`.
|
|
162
|
-
|
|
163
|
-
### API-first automation
|
|
164
|
-
|
|
165
|
-
Pixcode's frontend uses the same backend control plane exposed to external
|
|
166
|
-
automation. Generate a `px_` API key and call the REST/WebSocket APIs from your
|
|
167
|
-
own tools, scripts, CI, dashboards, or Telegram bridge.
|
|
168
|
-
|
|
169
|
-
List projects:
|
|
170
|
-
|
|
171
|
-
```bash
|
|
172
|
-
curl http://localhost:3001/api/projects \
|
|
173
|
-
-H "Authorization: Bearer px_your_key_here"
|
|
174
|
-
```
|
|
175
|
-
|
|
176
|
-
Run a provider task:
|
|
177
|
-
|
|
178
|
-
```bash
|
|
179
|
-
curl http://localhost:3001/api/agent \
|
|
180
|
-
-H "Authorization: Bearer px_your_key_here" \
|
|
181
|
-
-H "Content-Type: application/json" \
|
|
182
|
-
-d '{
|
|
183
|
-
"provider": "codex",
|
|
184
|
-
"projectPath": "/home/me/project",
|
|
185
|
-
"message": "Review the current diff and list risky changes.",
|
|
186
|
-
"stream": false
|
|
187
|
-
}'
|
|
188
|
-
```
|
|
189
|
-
|
|
190
|
-
Preview an orchestration workflow:
|
|
191
|
-
|
|
192
|
-
```bash
|
|
193
|
-
curl http://localhost:3001/api/orchestration/workflows/agent_team/preview \
|
|
194
|
-
-H "Authorization: Bearer px_your_key_here" \
|
|
195
|
-
-H "Content-Type: application/json" \
|
|
196
|
-
-d '{
|
|
197
|
-
"metadata": {
|
|
198
|
-
"agents": [
|
|
199
|
-
{ "adapterId": "codex", "label": "Backend", "role": "backend" },
|
|
200
|
-
{ "adapterId": "opencode", "label": "Reviewer", "role": "review" }
|
|
201
|
-
]
|
|
202
|
-
}
|
|
203
|
-
}'
|
|
204
|
-
```
|
|
205
|
-
|
|
206
|
-
Legacy `ck_` keys remain accepted for older installations, but `px_` is the
|
|
207
|
-
current prefix.
|
|
208
|
-
|
|
209
|
-
OpenAPI reference: [`public/openapi.yaml`](public/openapi.yaml)
|
|
210
|
-
|
|
211
|
-
### Telegram, notifications, and remote control
|
|
212
|
-
|
|
213
|
-
Pixcode can pair a Telegram chat with your account so completed tasks, failed
|
|
214
|
-
runs, and action-required states can reach you outside the browser. The goal is
|
|
215
|
-
not just a final notification: the Telegram bridge is a control surface for
|
|
216
|
-
remote prompts, provider/session selection, and long-running work.
|
|
217
|
-
|
|
218
|
-
Notification surfaces include:
|
|
219
|
-
|
|
220
|
-
- in-app alerts,
|
|
221
|
-
- browser/desktop notifications where the platform allows them,
|
|
222
|
-
- Telegram task notifications,
|
|
223
|
-
- update notices and release notes.
|
|
224
|
-
|
|
225
|
-
### Theme system
|
|
226
|
-
|
|
227
|
-
Pixcode has a real appearance system instead of one fixed blue/navy palette.
|
|
228
|
-
|
|
229
|
-
- Dark and light modes.
|
|
230
|
-
- Ready-made accent palettes, including emerald and VS Code-like options.
|
|
231
|
-
- Custom accent colors for dark and light themes.
|
|
232
|
-
- Token-based styling for focus rings, active controls, buttons, navigation, and
|
|
233
|
-
panels.
|
|
234
|
-
|
|
235
|
-
### MCP and plugins
|
|
236
|
-
|
|
237
|
-
Pixcode includes extension points for local workflows:
|
|
238
|
-
|
|
239
|
-
- MCP server management for supported providers.
|
|
240
|
-
- Provider-specific auth, MCP, and sessions panels.
|
|
241
|
-
- Plugin loading with optional frontend tabs and backend services.
|
|
242
|
-
- Local settings for API keys, base URLs, model catalogs, and provider install
|
|
243
|
-
state.
|
|
244
|
-
|
|
245
|
-
## Installation
|
|
246
|
-
|
|
247
|
-
### Requirements
|
|
248
|
-
|
|
249
|
-
- Node.js 22 or newer.
|
|
250
|
-
- The provider CLIs you want to use, installed and authenticated separately when
|
|
251
|
-
required.
|
|
252
|
-
|
|
253
|
-
### Run with npx
|
|
254
|
-
|
|
255
|
-
```bash
|
|
256
|
-
npx @pixelbyte-software/pixcode
|
|
257
|
-
```
|
|
258
|
-
|
|
259
|
-
Open:
|
|
260
|
-
|
|
261
|
-
```text
|
|
262
|
-
http://localhost:3001
|
|
263
|
-
```
|
|
264
|
-
|
|
265
|
-
### Install globally
|
|
266
|
-
|
|
267
|
-
```bash
|
|
268
|
-
npm install -g @pixelbyte-software/pixcode
|
|
269
|
-
pixcode
|
|
270
|
-
```
|
|
271
|
-
|
|
272
|
-
### Desktop installers
|
|
273
|
-
|
|
274
|
-
Download desktop builds from GitHub Releases:
|
|
275
|
-
|
|
276
|
-
- Windows: `.exe`
|
|
277
|
-
- macOS: `.dmg`
|
|
278
|
-
- Linux: AppImage or package asset, depending on the release
|
|
279
|
-
|
|
280
|
-
Releases: <https://github.com/alicomert/pixcode/releases/latest>
|
|
281
|
-
|
|
282
|
-
#### macOS Gatekeeper: "Pixcode is damaged"
|
|
283
|
-
|
|
284
|
-
Current macOS desktop builds can be unsigned. If macOS says `Pixcode is damaged
|
|
285
|
-
and can't be opened. You should move it to the Trash`, first make sure the DMG
|
|
286
|
-
came from the official Pixcode GitHub Releases page, then:
|
|
287
|
-
|
|
288
|
-
1. Open the DMG and drag `Pixcode.app` into `/Applications`.
|
|
289
|
-
2. Double-click `Fix Gatekeeper.command` inside the mounted DMG.
|
|
290
|
-
3. Pixcode removes the quarantine flag from `/Applications/Pixcode.app` and can
|
|
291
|
-
open normally.
|
|
292
|
-
|
|
293
|
-
Manual fallback:
|
|
294
|
-
|
|
295
|
-
```bash
|
|
296
|
-
xattr -dr com.apple.quarantine "/Applications/Pixcode.app"
|
|
297
|
-
open "/Applications/Pixcode.app"
|
|
298
|
-
```
|
|
299
|
-
|
|
300
|
-
### Linux daemon
|
|
301
|
-
|
|
302
|
-
For a server or VDS setup:
|
|
303
|
-
|
|
304
|
-
```bash
|
|
305
|
-
pixcode daemon install --mode auto --port 3001
|
|
306
|
-
pixcode daemon status --mode auto
|
|
307
|
-
pixcode daemon logs --mode auto
|
|
308
|
-
pixcode daemon restart --mode auto
|
|
309
|
-
```
|
|
310
|
-
|
|
311
|
-
Foreground mode:
|
|
312
|
-
|
|
313
|
-
```bash
|
|
314
|
-
pixcode --no-daemon
|
|
315
|
-
```
|
|
316
|
-
|
|
317
|
-
### Ports
|
|
318
|
-
|
|
319
|
-
- Installed backend and bundled frontend: `SERVER_PORT`, default `3001`.
|
|
320
|
-
- Vite-only frontend development: `VITE_PORT`, default `5173`.
|
|
321
|
-
|
|
322
|
-
For normal installed usage, think in terms of one port: `3001`. Port `5173` is
|
|
323
|
-
only for separate Vite frontend development.
|
|
324
|
-
|
|
325
|
-
## First Run
|
|
326
|
-
|
|
327
|
-
1. Open Pixcode and create or sign in to the local user account.
|
|
328
|
-
2. Add the project folders you want to manage.
|
|
329
|
-
3. Connect the CLI providers you actually use.
|
|
330
|
-
4. Open Settings and check provider install/auth/model status.
|
|
331
|
-
5. Use Hermes Agent if you want background workflow and review flows.
|
|
332
|
-
6. Generate a `px_` API key for external automation.
|
|
333
|
-
7. Pair Telegram if you want remote prompts and completion notifications.
|
|
334
|
-
8. Pick your theme palette under Appearance.
|
|
335
|
-
|
|
336
|
-
## Development
|
|
337
|
-
|
|
338
|
-
```bash
|
|
339
|
-
npm install
|
|
340
|
-
npm run typecheck
|
|
341
|
-
npm run lint
|
|
342
|
-
npm run build
|
|
343
|
-
```
|
|
344
|
-
|
|
345
|
-
Important development notes:
|
|
346
|
-
|
|
347
|
-
- `npm run dev` uses the daemon manager on Linux.
|
|
348
|
-
- For a foreground development loop, run `npm run client` and `npm run server`
|
|
349
|
-
separately, or run `pixcode --no-daemon`.
|
|
350
|
-
- `npm run server` runs built output from `dist-server/`; rebuild after backend
|
|
351
|
-
changes.
|
|
352
|
-
- There is no unit test suite configured today. Use smoke scripts, typecheck,
|
|
353
|
-
lint, build, and manual provider/API checks.
|
|
354
|
-
|
|
355
|
-
## Repository Map
|
|
356
|
-
|
|
357
|
-
- `src/` - React + Vite frontend.
|
|
358
|
-
- `server/` - Express, WebSocket, CLI adapters, routes, auth, daemon,
|
|
359
|
-
notifications.
|
|
360
|
-
- `server/modules/orchestration/` - Hermes-backed multi-agent workflow engine
|
|
361
|
-
and CLI adapters.
|
|
362
|
-
- `server/modules/providers/` - provider auth, MCP, sessions, model and install
|
|
363
|
-
endpoints.
|
|
364
|
-
- `shared/` - contracts shared by frontend and backend.
|
|
365
|
-
- `public/openapi.yaml` - API reference shipped with the app.
|
|
366
|
-
- `public/screenshots/` - README and product screenshots.
|
|
367
|
-
- `public/llms.txt` and `public/llms-full.txt` - AI-discovery summaries.
|
|
368
|
-
|
|
369
|
-
## Open Source Readiness
|
|
370
|
-
|
|
371
|
-
Pixcode is prepared for public contribution with the basics contributors expect:
|
|
372
|
-
|
|
373
|
-
- Clear README with purpose, install commands, screenshots, API examples, and
|
|
374
|
-
architecture map.
|
|
375
|
-
- Open-source license in [`LICENSE`](LICENSE).
|
|
376
|
-
- Contribution guide in [`CONTRIBUTING.md`](CONTRIBUTING.md).
|
|
377
|
-
- Code of conduct in [`CODE_OF_CONDUCT.md`](CODE_OF_CONDUCT.md).
|
|
378
|
-
- Security policy in [`SECURITY.md`](SECURITY.md).
|
|
379
|
-
- GitHub issue templates for bug reports, feature requests, and good first
|
|
380
|
-
issues.
|
|
381
|
-
- Releases and version tags published through GitHub Releases.
|
|
382
|
-
- Static website and documentation under [`public/`](public).
|
|
383
|
-
|
|
384
|
-
Good starter work should be labeled `good first issue` on GitHub. The repository
|
|
385
|
-
also includes a good-first-issue template so small, scoped tasks can be filed
|
|
386
|
-
without losing context.
|
|
387
|
-
|
|
388
|
-
## Security Model
|
|
389
|
-
|
|
390
|
-
- Pixcode is self-hosted. Treat it like a local control plane for your machine.
|
|
391
|
-
- Use strong local account credentials when exposing it on a network.
|
|
392
|
-
- Put public-server deployments behind a trusted reverse proxy, VPN, or firewall.
|
|
393
|
-
- API keys are intended for automation. Rotate them if they are exposed.
|
|
394
|
-
- Provider secrets are masked in APIs and UI responses where possible.
|
|
395
|
-
- Do not publish logs that contain provider tokens, session output, or private
|
|
396
|
-
project paths.
|
|
397
|
-
|
|
398
|
-
## Contributing
|
|
399
|
-
|
|
400
|
-
Read [`CONTRIBUTING.md`](CONTRIBUTING.md) before opening a pull request. Keep
|
|
401
|
-
changes scoped, run the verification commands above, and include screenshots or
|
|
402
|
-
short recordings for UI work when possible.
|
|
403
|
-
|
|
404
|
-
For community behavior expectations, read
|
|
405
|
-
[`CODE_OF_CONDUCT.md`](CODE_OF_CONDUCT.md). For private vulnerability reports,
|
|
406
|
-
read [`SECURITY.md`](SECURITY.md).
|
|
407
|
-
|
|
408
|
-
## Links
|
|
409
|
-
|
|
410
|
-
- Website: <https://alicomert.github.io/pixcode/landing.html>
|
|
411
|
-
- npm: <https://www.npmjs.com/package/@pixelbyte-software/pixcode>
|
|
412
|
-
- GitHub: <https://github.com/alicomert/pixcode>
|
|
413
|
-
- Releases: <https://github.com/alicomert/pixcode/releases/latest>
|
|
414
|
-
- API docs: [`public/openapi.yaml`](public/openapi.yaml)
|
|
415
|
-
- Static docs: [`public/docs.html`](public/docs.html), [`public/features.html`](public/features.html), [`public/orchestration.html`](public/orchestration.html), [`public/api-automation.html`](public/api-automation.html)
|
|
416
|
-
- AI discovery: [`public/llms.txt`](public/llms.txt), [`public/llms-full.txt`](public/llms-full.txt)
|
|
417
|
-
|
|
418
|
-
Pixcode is an independent open-source project and is not affiliated with OpenAI,
|
|
419
|
-
Anthropic, Google, Cursor, Alibaba/Qwen, or OpenCode.
|
|
1
|
+
<div align="center">
|
|
2
|
+
<img src="public/logo.png" alt="Pixcode logo" width="92" height="92" />
|
|
3
|
+
<h1>Pixcode</h1>
|
|
4
|
+
<p><strong>Self-hosted control plane for AI coding agents.</strong></p>
|
|
5
|
+
<p>
|
|
6
|
+
Pixcode lets you run AI coding CLIs, inspect files, manage shell and source control,
|
|
7
|
+
orchestrate agent teams, automate through APIs, and keep long-running work alive from
|
|
8
|
+
your own computer or server.
|
|
9
|
+
</p>
|
|
10
|
+
<p>
|
|
11
|
+
<a href="https://www.npmjs.com/package/@pixelbyte-software/pixcode"><img src="https://img.shields.io/npm/v/@pixelbyte-software/pixcode?style=for-the-badge&color=10b981" alt="npm version" /></a>
|
|
12
|
+
<a href="https://github.com/alicomert/pixcode/releases/latest"><img src="https://img.shields.io/github/v/release/alicomert/pixcode?style=for-the-badge&color=0ea5e9" alt="latest release" /></a>
|
|
13
|
+
<img src="https://img.shields.io/badge/Node.js-22%2B-3c873a?style=for-the-badge" alt="Node.js 22+" />
|
|
14
|
+
<img src="https://img.shields.io/badge/Desktop-Windows%20%7C%20macOS%20%7C%20Linux-6366f1?style=for-the-badge" alt="desktop platforms" />
|
|
15
|
+
</p>
|
|
16
|
+
<p>
|
|
17
|
+
<a href="https://buymeacoffee.com/alicomert" target="_blank" rel="noopener noreferrer"><img src="https://img.shields.io/badge/Buy%20me%20a%20coffee-support%20Pixcode-ffdd00?style=for-the-badge&logo=buymeacoffee&logoColor=000000" alt="Buy me a coffee" /></a>
|
|
18
|
+
</p>
|
|
19
|
+
<p>
|
|
20
|
+
<a href="https://www.producthunt.com/products/pixcode?embed=true&utm_source=badge-featured&utm_medium=badge&utm_campaign=badge-pixcode" target="_blank" rel="noopener noreferrer"><img alt="Pixcode - A self-hosted control room for AI coding agents. | Product Hunt" width="250" height="54" src="https://api.producthunt.com/widgets/embed-image/v1/featured.svg?post_id=1144104&theme=light&t=1778502023682"></a>
|
|
21
|
+
</p>
|
|
22
|
+
<p>
|
|
23
|
+
<a href="https://alicomert.github.io/pixcode/landing.html">Website</a> ·
|
|
24
|
+
<a href="https://github.com/alicomert/pixcode/releases/latest">Releases</a> ·
|
|
25
|
+
<a href="public/docs.html">Docs</a> ·
|
|
26
|
+
<a href="public/openapi.yaml">OpenAPI</a> ·
|
|
27
|
+
<a href="CONTRIBUTING.md">Contributing</a>
|
|
28
|
+
</p>
|
|
29
|
+
<p>
|
|
30
|
+
<a href="README.tr.md">Turkce</a> ·
|
|
31
|
+
<a href="README.de.md">Deutsch</a> ·
|
|
32
|
+
<a href="README.ru.md">Русский</a> ·
|
|
33
|
+
<a href="README.ja.md">日本語</a> ·
|
|
34
|
+
<a href="README.ko.md">한국어</a> ·
|
|
35
|
+
<a href="README.zh-CN.md">简体中文</a>
|
|
36
|
+
</p>
|
|
37
|
+
</div>
|
|
38
|
+
|
|
39
|
+
## What Pixcode Does
|
|
40
|
+
|
|
41
|
+
Pixcode is a local web and desktop workspace for AI coding agents. It wraps the
|
|
42
|
+
CLIs developers already use, then adds the missing control layer around them:
|
|
43
|
+
project selection, chat history, file navigation, shell access, Git/local change
|
|
44
|
+
tracking, orchestration, notifications, Telegram control, and API automation.
|
|
45
|
+
|
|
46
|
+
Use it when one terminal is not enough:
|
|
47
|
+
|
|
48
|
+
- You want Claude Code, Cursor CLI, Codex, Gemini CLI, Qwen Code, and OpenCode
|
|
49
|
+
available from the same project screen.
|
|
50
|
+
- You want agent output, edited files, shell commands, Git status, and task
|
|
51
|
+
planning visible without switching tools.
|
|
52
|
+
- You want a server or desktop app that keeps work running while you connect
|
|
53
|
+
from another computer, tablet, phone, or Telegram.
|
|
54
|
+
- You want a real API surface so other tools can create sessions, run agents,
|
|
55
|
+
inspect projects, and automate workflows with `px_` API keys.
|
|
56
|
+
|
|
57
|
+
Pixcode is not a hosted cloud IDE. Your source code, CLI sessions, credentials,
|
|
58
|
+
project paths, MCP configuration, local database, and automation keys stay on the
|
|
59
|
+
machine where Pixcode runs unless you intentionally expose or connect them.
|
|
60
|
+
|
|
61
|
+
## Screenshots
|
|
62
|
+
|
|
63
|
+
| Workspace control room | Mobile chat |
|
|
64
|
+
| --- | --- |
|
|
65
|
+
| <img src="public/screenshots/desktop-main.png" alt="Pixcode desktop workspace with chat, project controls, and side panels" width="480" /> | <img src="public/screenshots/mobile-chat.png" alt="Pixcode mobile chat" width="260" /> |
|
|
66
|
+
|
|
67
|
+
| CLI selection | Tools and MCP |
|
|
68
|
+
| --- | --- |
|
|
69
|
+
| <img src="public/screenshots/cli-selection.png" alt="Pixcode CLI selection" width="420" /> | <img src="public/screenshots/tools-modal.png" alt="Pixcode tools and MCP modal" width="420" /> |
|
|
70
|
+
|
|
71
|
+
## Core Features
|
|
72
|
+
|
|
73
|
+
### Multi-CLI agent workspace
|
|
74
|
+
|
|
75
|
+
Pixcode gives every supported coding CLI a shared workspace without hiding the
|
|
76
|
+
provider-native behavior. You can connect the providers you already use and move
|
|
77
|
+
between them from the same project.
|
|
78
|
+
|
|
79
|
+
- Claude Code
|
|
80
|
+
- Cursor CLI
|
|
81
|
+
- OpenAI Codex
|
|
82
|
+
- Gemini CLI
|
|
83
|
+
- Qwen Code
|
|
84
|
+
- OpenCode
|
|
85
|
+
|
|
86
|
+
Provider panels cover auth state, install checks, CLI versions, model choices,
|
|
87
|
+
MCP support, and session history. When an agent is thinking, running tools,
|
|
88
|
+
waiting for approval, or writing output, the UI keeps visible processing state
|
|
89
|
+
instead of leaving the screen feeling frozen.
|
|
90
|
+
|
|
91
|
+
### Chat built for development work
|
|
92
|
+
|
|
93
|
+
Pixcode chat is project-aware and designed for long-running coding sessions.
|
|
94
|
+
|
|
95
|
+
- Fixed bottom composer on chat/project screens.
|
|
96
|
+
- Session history per provider and project.
|
|
97
|
+
- Default, plan, and run-style modes where supported.
|
|
98
|
+
- Slash-command friendly input.
|
|
99
|
+
- Tool output rendering for plans, file operations, command output, and provider
|
|
100
|
+
status events.
|
|
101
|
+
- Telegram and browser/desktop notifications when work finishes, fails, or needs
|
|
102
|
+
attention.
|
|
103
|
+
|
|
104
|
+
### Files, shell, and source control
|
|
105
|
+
|
|
106
|
+
The side panels are built around the way coding agents change projects.
|
|
107
|
+
|
|
108
|
+
- Files panel with detailed and compact views.
|
|
109
|
+
- File open/edit flows that preserve the main chat or orchestration surface.
|
|
110
|
+
- Shell panel with split/full behavior on desktop and mobile-safe behavior on
|
|
111
|
+
smaller screens.
|
|
112
|
+
- Source Control panel for Git status, diffs, branches, commits, and changed
|
|
113
|
+
files when a project is a Git repository.
|
|
114
|
+
- Local change tracking for projects that are not Git repositories.
|
|
115
|
+
|
|
116
|
+
### Command Center for changed files
|
|
117
|
+
|
|
118
|
+
Command Center watches what changes while agents work. It can track Git changes
|
|
119
|
+
or local filesystem changes, show the changed file list next to the active chat,
|
|
120
|
+
highlight changed items, and open the edited file at the relevant location.
|
|
121
|
+
|
|
122
|
+
This is meant to answer the practical question: "What did the agent just touch?"
|
|
123
|
+
|
|
124
|
+
### Multi-agent orchestration
|
|
125
|
+
|
|
126
|
+
Pixcode can run structured agent workflows instead of sending every prompt to one
|
|
127
|
+
agent.
|
|
128
|
+
|
|
129
|
+
Built-in workflow styles include:
|
|
130
|
+
|
|
131
|
+
- Agent Team: split a job across implementation, review, docs, testing, or
|
|
132
|
+
custom roles.
|
|
133
|
+
- Sequential Handoff: pass compact context from one stage to the next.
|
|
134
|
+
- Multi-model Review: compare provider/model opinions on the same code or plan.
|
|
135
|
+
- Decision Debate: make multiple agents argue approaches before acting.
|
|
136
|
+
|
|
137
|
+
Orchestration controls include:
|
|
138
|
+
|
|
139
|
+
- per-agent provider and model selection,
|
|
140
|
+
- custom labels, roles, and instructions,
|
|
141
|
+
- duplicate providers when multiple workers should use the same CLI,
|
|
142
|
+
- fallback CLI selection for failed steps,
|
|
143
|
+
- run preview before execution,
|
|
144
|
+
- streamed step output and final report,
|
|
145
|
+
- resizable setup/output panes.
|
|
146
|
+
|
|
147
|
+
### Hermes Agent orchestration
|
|
148
|
+
|
|
149
|
+
Pixcode uses Hermes Agent as the orchestration control plane for background
|
|
150
|
+
agent work. Hermes runs inside the current Pixcode instance, understands the
|
|
151
|
+
active project context, and can route bounded tasks to Claude Code, Codex,
|
|
152
|
+
Cursor, Gemini, Qwen, or OpenCode through terminal-first CLI adapters.
|
|
153
|
+
|
|
154
|
+
Hermes controls include:
|
|
155
|
+
|
|
156
|
+
- project-scoped task context,
|
|
157
|
+
- provider/model routing,
|
|
158
|
+
- streamed task status and artifacts,
|
|
159
|
+
- workflow run coordination,
|
|
160
|
+
- background checks and previews,
|
|
161
|
+
- authenticated local APIs under `/api/orchestration/hermes`.
|
|
162
|
+
|
|
163
|
+
### API-first automation
|
|
164
|
+
|
|
165
|
+
Pixcode's frontend uses the same backend control plane exposed to external
|
|
166
|
+
automation. Generate a `px_` API key and call the REST/WebSocket APIs from your
|
|
167
|
+
own tools, scripts, CI, dashboards, or Telegram bridge.
|
|
168
|
+
|
|
169
|
+
List projects:
|
|
170
|
+
|
|
171
|
+
```bash
|
|
172
|
+
curl http://localhost:3001/api/projects \
|
|
173
|
+
-H "Authorization: Bearer px_your_key_here"
|
|
174
|
+
```
|
|
175
|
+
|
|
176
|
+
Run a provider task:
|
|
177
|
+
|
|
178
|
+
```bash
|
|
179
|
+
curl http://localhost:3001/api/agent \
|
|
180
|
+
-H "Authorization: Bearer px_your_key_here" \
|
|
181
|
+
-H "Content-Type: application/json" \
|
|
182
|
+
-d '{
|
|
183
|
+
"provider": "codex",
|
|
184
|
+
"projectPath": "/home/me/project",
|
|
185
|
+
"message": "Review the current diff and list risky changes.",
|
|
186
|
+
"stream": false
|
|
187
|
+
}'
|
|
188
|
+
```
|
|
189
|
+
|
|
190
|
+
Preview an orchestration workflow:
|
|
191
|
+
|
|
192
|
+
```bash
|
|
193
|
+
curl http://localhost:3001/api/orchestration/workflows/agent_team/preview \
|
|
194
|
+
-H "Authorization: Bearer px_your_key_here" \
|
|
195
|
+
-H "Content-Type: application/json" \
|
|
196
|
+
-d '{
|
|
197
|
+
"metadata": {
|
|
198
|
+
"agents": [
|
|
199
|
+
{ "adapterId": "codex", "label": "Backend", "role": "backend" },
|
|
200
|
+
{ "adapterId": "opencode", "label": "Reviewer", "role": "review" }
|
|
201
|
+
]
|
|
202
|
+
}
|
|
203
|
+
}'
|
|
204
|
+
```
|
|
205
|
+
|
|
206
|
+
Legacy `ck_` keys remain accepted for older installations, but `px_` is the
|
|
207
|
+
current prefix.
|
|
208
|
+
|
|
209
|
+
OpenAPI reference: [`public/openapi.yaml`](public/openapi.yaml)
|
|
210
|
+
|
|
211
|
+
### Telegram, notifications, and remote control
|
|
212
|
+
|
|
213
|
+
Pixcode can pair a Telegram chat with your account so completed tasks, failed
|
|
214
|
+
runs, and action-required states can reach you outside the browser. The goal is
|
|
215
|
+
not just a final notification: the Telegram bridge is a control surface for
|
|
216
|
+
remote prompts, provider/session selection, and long-running work.
|
|
217
|
+
|
|
218
|
+
Notification surfaces include:
|
|
219
|
+
|
|
220
|
+
- in-app alerts,
|
|
221
|
+
- browser/desktop notifications where the platform allows them,
|
|
222
|
+
- Telegram task notifications,
|
|
223
|
+
- update notices and release notes.
|
|
224
|
+
|
|
225
|
+
### Theme system
|
|
226
|
+
|
|
227
|
+
Pixcode has a real appearance system instead of one fixed blue/navy palette.
|
|
228
|
+
|
|
229
|
+
- Dark and light modes.
|
|
230
|
+
- Ready-made accent palettes, including emerald and VS Code-like options.
|
|
231
|
+
- Custom accent colors for dark and light themes.
|
|
232
|
+
- Token-based styling for focus rings, active controls, buttons, navigation, and
|
|
233
|
+
panels.
|
|
234
|
+
|
|
235
|
+
### MCP and plugins
|
|
236
|
+
|
|
237
|
+
Pixcode includes extension points for local workflows:
|
|
238
|
+
|
|
239
|
+
- MCP server management for supported providers.
|
|
240
|
+
- Provider-specific auth, MCP, and sessions panels.
|
|
241
|
+
- Plugin loading with optional frontend tabs and backend services.
|
|
242
|
+
- Local settings for API keys, base URLs, model catalogs, and provider install
|
|
243
|
+
state.
|
|
244
|
+
|
|
245
|
+
## Installation
|
|
246
|
+
|
|
247
|
+
### Requirements
|
|
248
|
+
|
|
249
|
+
- Node.js 22 or newer.
|
|
250
|
+
- The provider CLIs you want to use, installed and authenticated separately when
|
|
251
|
+
required.
|
|
252
|
+
|
|
253
|
+
### Run with npx
|
|
254
|
+
|
|
255
|
+
```bash
|
|
256
|
+
npx @pixelbyte-software/pixcode
|
|
257
|
+
```
|
|
258
|
+
|
|
259
|
+
Open:
|
|
260
|
+
|
|
261
|
+
```text
|
|
262
|
+
http://localhost:3001
|
|
263
|
+
```
|
|
264
|
+
|
|
265
|
+
### Install globally
|
|
266
|
+
|
|
267
|
+
```bash
|
|
268
|
+
npm install -g @pixelbyte-software/pixcode
|
|
269
|
+
pixcode
|
|
270
|
+
```
|
|
271
|
+
|
|
272
|
+
### Desktop installers
|
|
273
|
+
|
|
274
|
+
Download desktop builds from GitHub Releases:
|
|
275
|
+
|
|
276
|
+
- Windows: `.exe`
|
|
277
|
+
- macOS: `.dmg`
|
|
278
|
+
- Linux: AppImage or package asset, depending on the release
|
|
279
|
+
|
|
280
|
+
Releases: <https://github.com/alicomert/pixcode/releases/latest>
|
|
281
|
+
|
|
282
|
+
#### macOS Gatekeeper: "Pixcode is damaged"
|
|
283
|
+
|
|
284
|
+
Current macOS desktop builds can be unsigned. If macOS says `Pixcode is damaged
|
|
285
|
+
and can't be opened. You should move it to the Trash`, first make sure the DMG
|
|
286
|
+
came from the official Pixcode GitHub Releases page, then:
|
|
287
|
+
|
|
288
|
+
1. Open the DMG and drag `Pixcode.app` into `/Applications`.
|
|
289
|
+
2. Double-click `Fix Gatekeeper.command` inside the mounted DMG.
|
|
290
|
+
3. Pixcode removes the quarantine flag from `/Applications/Pixcode.app` and can
|
|
291
|
+
open normally.
|
|
292
|
+
|
|
293
|
+
Manual fallback:
|
|
294
|
+
|
|
295
|
+
```bash
|
|
296
|
+
xattr -dr com.apple.quarantine "/Applications/Pixcode.app"
|
|
297
|
+
open "/Applications/Pixcode.app"
|
|
298
|
+
```
|
|
299
|
+
|
|
300
|
+
### Linux daemon
|
|
301
|
+
|
|
302
|
+
For a server or VDS setup:
|
|
303
|
+
|
|
304
|
+
```bash
|
|
305
|
+
pixcode daemon install --mode auto --port 3001
|
|
306
|
+
pixcode daemon status --mode auto
|
|
307
|
+
pixcode daemon logs --mode auto
|
|
308
|
+
pixcode daemon restart --mode auto
|
|
309
|
+
```
|
|
310
|
+
|
|
311
|
+
Foreground mode:
|
|
312
|
+
|
|
313
|
+
```bash
|
|
314
|
+
pixcode --no-daemon
|
|
315
|
+
```
|
|
316
|
+
|
|
317
|
+
### Ports
|
|
318
|
+
|
|
319
|
+
- Installed backend and bundled frontend: `SERVER_PORT`, default `3001`.
|
|
320
|
+
- Vite-only frontend development: `VITE_PORT`, default `5173`.
|
|
321
|
+
|
|
322
|
+
For normal installed usage, think in terms of one port: `3001`. Port `5173` is
|
|
323
|
+
only for separate Vite frontend development.
|
|
324
|
+
|
|
325
|
+
## First Run
|
|
326
|
+
|
|
327
|
+
1. Open Pixcode and create or sign in to the local user account.
|
|
328
|
+
2. Add the project folders you want to manage.
|
|
329
|
+
3. Connect the CLI providers you actually use.
|
|
330
|
+
4. Open Settings and check provider install/auth/model status.
|
|
331
|
+
5. Use Hermes Agent if you want background workflow and review flows.
|
|
332
|
+
6. Generate a `px_` API key for external automation.
|
|
333
|
+
7. Pair Telegram if you want remote prompts and completion notifications.
|
|
334
|
+
8. Pick your theme palette under Appearance.
|
|
335
|
+
|
|
336
|
+
## Development
|
|
337
|
+
|
|
338
|
+
```bash
|
|
339
|
+
npm install
|
|
340
|
+
npm run typecheck
|
|
341
|
+
npm run lint
|
|
342
|
+
npm run build
|
|
343
|
+
```
|
|
344
|
+
|
|
345
|
+
Important development notes:
|
|
346
|
+
|
|
347
|
+
- `npm run dev` uses the daemon manager on Linux.
|
|
348
|
+
- For a foreground development loop, run `npm run client` and `npm run server`
|
|
349
|
+
separately, or run `pixcode --no-daemon`.
|
|
350
|
+
- `npm run server` runs built output from `dist-server/`; rebuild after backend
|
|
351
|
+
changes.
|
|
352
|
+
- There is no unit test suite configured today. Use smoke scripts, typecheck,
|
|
353
|
+
lint, build, and manual provider/API checks.
|
|
354
|
+
|
|
355
|
+
## Repository Map
|
|
356
|
+
|
|
357
|
+
- `src/` - React + Vite frontend.
|
|
358
|
+
- `server/` - Express, WebSocket, CLI adapters, routes, auth, daemon,
|
|
359
|
+
notifications.
|
|
360
|
+
- `server/modules/orchestration/` - Hermes-backed multi-agent workflow engine
|
|
361
|
+
and CLI adapters.
|
|
362
|
+
- `server/modules/providers/` - provider auth, MCP, sessions, model and install
|
|
363
|
+
endpoints.
|
|
364
|
+
- `shared/` - contracts shared by frontend and backend.
|
|
365
|
+
- `public/openapi.yaml` - API reference shipped with the app.
|
|
366
|
+
- `public/screenshots/` - README and product screenshots.
|
|
367
|
+
- `public/llms.txt` and `public/llms-full.txt` - AI-discovery summaries.
|
|
368
|
+
|
|
369
|
+
## Open Source Readiness
|
|
370
|
+
|
|
371
|
+
Pixcode is prepared for public contribution with the basics contributors expect:
|
|
372
|
+
|
|
373
|
+
- Clear README with purpose, install commands, screenshots, API examples, and
|
|
374
|
+
architecture map.
|
|
375
|
+
- Open-source license in [`LICENSE`](LICENSE).
|
|
376
|
+
- Contribution guide in [`CONTRIBUTING.md`](CONTRIBUTING.md).
|
|
377
|
+
- Code of conduct in [`CODE_OF_CONDUCT.md`](CODE_OF_CONDUCT.md).
|
|
378
|
+
- Security policy in [`SECURITY.md`](SECURITY.md).
|
|
379
|
+
- GitHub issue templates for bug reports, feature requests, and good first
|
|
380
|
+
issues.
|
|
381
|
+
- Releases and version tags published through GitHub Releases.
|
|
382
|
+
- Static website and documentation under [`public/`](public).
|
|
383
|
+
|
|
384
|
+
Good starter work should be labeled `good first issue` on GitHub. The repository
|
|
385
|
+
also includes a good-first-issue template so small, scoped tasks can be filed
|
|
386
|
+
without losing context.
|
|
387
|
+
|
|
388
|
+
## Security Model
|
|
389
|
+
|
|
390
|
+
- Pixcode is self-hosted. Treat it like a local control plane for your machine.
|
|
391
|
+
- Use strong local account credentials when exposing it on a network.
|
|
392
|
+
- Put public-server deployments behind a trusted reverse proxy, VPN, or firewall.
|
|
393
|
+
- API keys are intended for automation. Rotate them if they are exposed.
|
|
394
|
+
- Provider secrets are masked in APIs and UI responses where possible.
|
|
395
|
+
- Do not publish logs that contain provider tokens, session output, or private
|
|
396
|
+
project paths.
|
|
397
|
+
|
|
398
|
+
## Contributing
|
|
399
|
+
|
|
400
|
+
Read [`CONTRIBUTING.md`](CONTRIBUTING.md) before opening a pull request. Keep
|
|
401
|
+
changes scoped, run the verification commands above, and include screenshots or
|
|
402
|
+
short recordings for UI work when possible.
|
|
403
|
+
|
|
404
|
+
For community behavior expectations, read
|
|
405
|
+
[`CODE_OF_CONDUCT.md`](CODE_OF_CONDUCT.md). For private vulnerability reports,
|
|
406
|
+
read [`SECURITY.md`](SECURITY.md).
|
|
407
|
+
|
|
408
|
+
## Links
|
|
409
|
+
|
|
410
|
+
- Website: <https://alicomert.github.io/pixcode/landing.html>
|
|
411
|
+
- npm: <https://www.npmjs.com/package/@pixelbyte-software/pixcode>
|
|
412
|
+
- GitHub: <https://github.com/alicomert/pixcode>
|
|
413
|
+
- Releases: <https://github.com/alicomert/pixcode/releases/latest>
|
|
414
|
+
- API docs: [`public/openapi.yaml`](public/openapi.yaml)
|
|
415
|
+
- Static docs: [`public/docs.html`](public/docs.html), [`public/features.html`](public/features.html), [`public/orchestration.html`](public/orchestration.html), [`public/api-automation.html`](public/api-automation.html)
|
|
416
|
+
- AI discovery: [`public/llms.txt`](public/llms.txt), [`public/llms-full.txt`](public/llms-full.txt)
|
|
417
|
+
|
|
418
|
+
Pixcode is an independent open-source project and is not affiliated with OpenAI,
|
|
419
|
+
Anthropic, Google, Cursor, Alibaba/Qwen, or OpenCode.
|