@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.
Files changed (320) hide show
  1. package/CODE_OF_CONDUCT.md +41 -41
  2. package/CONTRIBUTING.md +155 -155
  3. package/LICENSE +718 -718
  4. package/README.de.md +169 -169
  5. package/README.ja.md +167 -167
  6. package/README.ko.md +167 -167
  7. package/README.md +419 -419
  8. package/README.ru.md +169 -169
  9. package/README.tr.md +298 -298
  10. package/README.zh-CN.md +167 -167
  11. package/SECURITY.md +46 -46
  12. package/dist/api-automation.html +110 -110
  13. package/dist/api-docs.html +548 -548
  14. package/dist/assets/{index-DARIZgoD.js → index-17CwxHSZ.js} +185 -185
  15. package/dist/assets/index-B9N-gfOQ.css +32 -0
  16. package/dist/clear-cache.html +85 -85
  17. package/dist/convert-icons.md +52 -52
  18. package/dist/docs.html +308 -308
  19. package/dist/favicon.svg +8 -8
  20. package/dist/features.html +133 -133
  21. package/dist/generate-icons.js +48 -48
  22. package/dist/humans.txt +15 -15
  23. package/dist/icons/codex-white.svg +3 -3
  24. package/dist/icons/codex.svg +3 -3
  25. package/dist/icons/cursor-white.svg +11 -11
  26. package/dist/icons/icon-128x128.svg +9 -9
  27. package/dist/icons/icon-144x144.svg +9 -9
  28. package/dist/icons/icon-152x152.svg +9 -9
  29. package/dist/icons/icon-192x192.svg +9 -9
  30. package/dist/icons/icon-384x384.svg +9 -9
  31. package/dist/icons/icon-512x512.svg +9 -9
  32. package/dist/icons/icon-72x72.svg +9 -9
  33. package/dist/icons/icon-96x96.svg +9 -9
  34. package/dist/icons/icon-template.svg +9 -9
  35. package/dist/icons/qwen-logo.svg +14 -14
  36. package/dist/index.html +59 -59
  37. package/dist/landing.html +268 -268
  38. package/dist/llms-full.txt +119 -119
  39. package/dist/llms.txt +53 -53
  40. package/dist/logo.svg +12 -12
  41. package/dist/manifest.json +60 -60
  42. package/dist/openapi.yaml +1696 -1696
  43. package/dist/orchestration.html +125 -125
  44. package/dist/robots.txt +4 -4
  45. package/dist/site.css +692 -692
  46. package/dist/sitemap.xml +51 -51
  47. package/dist/sw.js +132 -132
  48. package/dist-server/server/cli.js +96 -96
  49. package/dist-server/server/daemon/manager.js +33 -33
  50. package/dist-server/server/daemon-manager.js +64 -64
  51. package/dist-server/server/index.js +125 -4
  52. package/dist-server/server/index.js.map +1 -1
  53. package/dist-server/server/modules/orchestration/a2a/adapters/json-event.adapter.js +84 -0
  54. package/dist-server/server/modules/orchestration/a2a/adapters/json-event.adapter.js.map +1 -0
  55. package/dist-server/server/modules/orchestration/a2a/adapters/json-event.adapter.test.js +43 -0
  56. package/dist-server/server/modules/orchestration/a2a/adapters/json-event.adapter.test.js.map +1 -0
  57. package/dist-server/server/modules/orchestration/hermes/hermes.routes.js +55 -1
  58. package/dist-server/server/modules/orchestration/hermes/hermes.routes.js.map +1 -1
  59. package/dist-server/server/modules/orchestration/index.js +1 -0
  60. package/dist-server/server/modules/orchestration/index.js.map +1 -1
  61. package/dist-server/server/routes/commands.js +25 -25
  62. package/dist-server/server/routes/git.js +17 -17
  63. package/dist-server/server/routes/live-view.js +46 -46
  64. package/dist-server/server/services/hermes-gateway.js +310 -0
  65. package/dist-server/server/services/hermes-gateway.js.map +1 -1
  66. package/dist-server/server/services/public-api-manifest.js +59 -51
  67. package/dist-server/server/services/public-api-manifest.js.map +1 -1
  68. package/package.json +222 -222
  69. package/scripts/fix-node-pty.js +67 -67
  70. package/scripts/github/create-v1.38-issues.mjs +351 -351
  71. package/scripts/github/create-vscode-workbench-issues.mjs +121 -121
  72. package/scripts/hermes/configure-pixcode-mcp.mjs +165 -163
  73. package/scripts/hermes/pixcode-mcp-server.mjs +1009 -958
  74. package/scripts/smoke/changes-panel-layout.mjs +48 -48
  75. package/scripts/smoke/chat-composer-fixed-layout.mjs +55 -55
  76. package/scripts/smoke/chat-message-timeline-order.mjs +41 -41
  77. package/scripts/smoke/chat-realtime-hydration.mjs +44 -44
  78. package/scripts/smoke/chat-session-provider-pools.mjs +35 -35
  79. package/scripts/smoke/chat-session-state.mjs +19 -19
  80. package/scripts/smoke/code-editor-theme.mjs +55 -55
  81. package/scripts/smoke/code-editor-vscode-engine.mjs +91 -91
  82. package/scripts/smoke/command-center-agent-writes.mjs +79 -79
  83. package/scripts/smoke/command-center-non-git.mjs +46 -46
  84. package/scripts/smoke/context-packet.mjs +43 -43
  85. package/scripts/smoke/control-room-ux-redesign.mjs +91 -91
  86. package/scripts/smoke/daemon-entrypoint.mjs +20 -20
  87. package/scripts/smoke/default-landing-routing.mjs +33 -33
  88. package/scripts/smoke/desktop-native-notifications.mjs +30 -30
  89. package/scripts/smoke/desktop-tray-icon.mjs +33 -33
  90. package/scripts/smoke/discord-release-workflow.mjs +24 -24
  91. package/scripts/smoke/git-install-update.mjs +255 -255
  92. package/scripts/smoke/handoff-artifact-protocol.mjs +50 -50
  93. package/scripts/smoke/hermes-api-install.mjs +56 -56
  94. package/scripts/smoke/hermes-gateway-persistence.mjs +104 -104
  95. package/scripts/smoke/hermes-mcp-pixcode-roundtrip.mjs +426 -367
  96. package/scripts/smoke/hermes-rest-chat-api.mjs +162 -162
  97. package/scripts/smoke/hermes-rest-chat-live.mjs +45 -45
  98. package/scripts/smoke/hermes-rest-codex-launch.mjs +209 -209
  99. package/scripts/smoke/hermes-rest-gateway.mjs +79 -70
  100. package/scripts/smoke/hermes-rest-live.mjs +42 -42
  101. package/scripts/smoke/hermes-roundtrip.mjs +167 -167
  102. package/scripts/smoke/hermes-settings-commands.mjs +349 -346
  103. package/scripts/smoke/hermes-smoke-launcher-guard.mjs +34 -34
  104. package/scripts/smoke/live-view-diagnostics.mjs +53 -53
  105. package/scripts/smoke/live-view-environment.mjs +92 -92
  106. package/scripts/smoke/live-view-integration.mjs +450 -450
  107. package/scripts/smoke/mac-desktop-runtime.mjs +37 -37
  108. package/scripts/smoke/mobile-tunnel-guidance.mjs +29 -29
  109. package/scripts/smoke/model-registry.mjs +36 -36
  110. package/scripts/smoke/multi-project-ui.mjs +45 -45
  111. package/scripts/smoke/multi-worker-slots.mjs +42 -42
  112. package/scripts/smoke/notification-center.mjs +87 -87
  113. package/scripts/smoke/notification-inapp-preference.mjs +23 -23
  114. package/scripts/smoke/notification-taxonomy.mjs +58 -58
  115. package/scripts/smoke/orchestration-api.mjs +172 -172
  116. package/scripts/smoke/orchestration-execution-dashboard.mjs +33 -33
  117. package/scripts/smoke/orchestration-live-run.mjs +176 -176
  118. package/scripts/smoke/orchestration-mobile-scroll.mjs +29 -29
  119. package/scripts/smoke/orchestration-model-sync.mjs +30 -30
  120. package/scripts/smoke/orchestration-permission-fallback.mjs +34 -34
  121. package/scripts/smoke/orchestration-runtime-guards.mjs +48 -48
  122. package/scripts/smoke/orchestration-user-facing-output.mjs +25 -25
  123. package/scripts/smoke/permission-policy.mjs +50 -50
  124. package/scripts/smoke/pixcode-workbench-1-48.mjs +167 -164
  125. package/scripts/smoke/provider-models-opencode-live.mjs +66 -66
  126. package/scripts/smoke/provider-rest-api.mjs +124 -124
  127. package/scripts/smoke/provider-selection-status.mjs +52 -52
  128. package/scripts/smoke/run-state-refresh.mjs +52 -52
  129. package/scripts/smoke/runtime-manager.mjs +99 -99
  130. package/scripts/smoke/shell-manual-disconnect.mjs +30 -30
  131. package/scripts/smoke/side-panel-editor-layout.mjs +34 -34
  132. package/scripts/smoke/static-root-routing.mjs +21 -21
  133. package/scripts/smoke/strict-handoff-compact.mjs +60 -60
  134. package/scripts/smoke/taskmaster-config.mjs +24 -24
  135. package/scripts/smoke/taskmaster-execution-telegram.mjs +3 -3
  136. package/scripts/smoke/taskmaster-onboarding.mjs +3 -3
  137. package/scripts/smoke/taskmaster-run-graph.mjs +3 -3
  138. package/scripts/smoke/telegram-control.mjs +242 -242
  139. package/scripts/smoke/tunnel-persistence.mjs +56 -56
  140. package/scripts/smoke/update-issue-progress.mjs +69 -69
  141. package/scripts/smoke/update-ux.mjs +55 -55
  142. package/scripts/smoke/v138-completion.mjs +132 -132
  143. package/scripts/smoke/v138-desktop-release-hardening.mjs +69 -69
  144. package/scripts/smoke/v138-diagnostics.mjs +63 -63
  145. package/scripts/smoke/v138-issue-planner.mjs +33 -33
  146. package/scripts/smoke/v143-remote-control.mjs +76 -76
  147. package/scripts/smoke/v144-production-loop.mjs +47 -47
  148. package/scripts/smoke/v145-platformization.mjs +46 -46
  149. package/scripts/smoke/v146-control-room-ui.mjs +150 -150
  150. package/scripts/smoke/version-modal-autoshow.mjs +29 -29
  151. package/scripts/smoke/vscode-workbench-layout.mjs +63 -63
  152. package/scripts/smoke/vscode-workbench-polish.mjs +461 -436
  153. package/scripts/smoke/workflow-fallback-replay.mjs +56 -56
  154. package/scripts/smoke/workflow-templates.mjs +43 -43
  155. package/scripts/smoke/workflow-trace-timeline.mjs +46 -46
  156. package/scripts/update-git-install.mjs +293 -293
  157. package/server/claude-sdk.js +920 -920
  158. package/server/cli.js +1039 -1039
  159. package/server/constants/config.js +4 -4
  160. package/server/cursor-cli.js +344 -344
  161. package/server/daemon/manager.js +563 -563
  162. package/server/daemon-manager.js +964 -964
  163. package/server/database/db.js +921 -921
  164. package/server/database/json-store.js +197 -197
  165. package/server/gemini-cli.js +550 -550
  166. package/server/gemini-response-handler.js +79 -79
  167. package/server/index.js +131 -3
  168. package/server/load-env.js +35 -35
  169. package/server/middleware/auth.js +175 -175
  170. package/server/modules/orchestration/a2a/adapter-registry.ts +108 -108
  171. package/server/modules/orchestration/a2a/adapters/abstract-a2a.adapter.ts +63 -63
  172. package/server/modules/orchestration/a2a/adapters/claude-code.adapter.ts +286 -286
  173. package/server/modules/orchestration/a2a/adapters/codex.adapter.ts +244 -244
  174. package/server/modules/orchestration/a2a/adapters/cursor.adapter.ts +249 -249
  175. package/server/modules/orchestration/a2a/adapters/gemini.adapter.ts +248 -248
  176. package/server/modules/orchestration/a2a/adapters/json-event.adapter.test.ts +60 -0
  177. package/server/modules/orchestration/a2a/adapters/json-event.adapter.ts +101 -0
  178. package/server/modules/orchestration/a2a/adapters/opencode.adapter.ts +248 -248
  179. package/server/modules/orchestration/a2a/adapters/qwen.adapter.ts +248 -248
  180. package/server/modules/orchestration/a2a/agent-card.ts +55 -55
  181. package/server/modules/orchestration/a2a/routes.ts +590 -590
  182. package/server/modules/orchestration/a2a/task-store.ts +178 -178
  183. package/server/modules/orchestration/a2a/types.ts +126 -126
  184. package/server/modules/orchestration/a2a/validator.ts +113 -113
  185. package/server/modules/orchestration/hermes/hermes.routes.ts +642 -583
  186. package/server/modules/orchestration/index.ts +101 -100
  187. package/server/modules/orchestration/preview/port-watcher.ts +112 -112
  188. package/server/modules/orchestration/preview/preview-proxy.ts +60 -60
  189. package/server/modules/orchestration/preview/types.ts +19 -19
  190. package/server/modules/orchestration/security/permission-policy.ts +401 -401
  191. package/server/modules/orchestration/tasks/orchestration-task-store.ts +41 -41
  192. package/server/modules/orchestration/tasks/orchestration-task.routes.ts +64 -64
  193. package/server/modules/orchestration/tasks/orchestration-task.service.ts +209 -209
  194. package/server/modules/orchestration/tasks/orchestration-task.types.ts +40 -40
  195. package/server/modules/orchestration/tasks/task-run-graph.ts +155 -155
  196. package/server/modules/orchestration/workflows/approval-queue.ts +106 -106
  197. package/server/modules/orchestration/workflows/built-in-workflows.ts +127 -127
  198. package/server/modules/orchestration/workflows/context-packet.ts +186 -186
  199. package/server/modules/orchestration/workflows/handoff-artifact.ts +175 -175
  200. package/server/modules/orchestration/workflows/workflow-fallback-policy.ts +161 -161
  201. package/server/modules/orchestration/workflows/workflow-replay.ts +254 -254
  202. package/server/modules/orchestration/workflows/workflow-runner.ts +2070 -2070
  203. package/server/modules/orchestration/workflows/workflow-store.ts +97 -97
  204. package/server/modules/orchestration/workflows/workflow-templates.ts +272 -272
  205. package/server/modules/orchestration/workflows/workflow-trace.ts +424 -424
  206. package/server/modules/orchestration/workflows/workflow.routes.ts +586 -586
  207. package/server/modules/orchestration/workflows/workflow.types.ts +111 -111
  208. package/server/modules/orchestration/workflows/workspace-target.ts +122 -122
  209. package/server/modules/orchestration/workspace/docker-workspace.ts +136 -136
  210. package/server/modules/orchestration/workspace/path-safety.ts +55 -55
  211. package/server/modules/orchestration/workspace/types.ts +52 -52
  212. package/server/modules/orchestration/workspace/workspace-manager.ts +102 -102
  213. package/server/modules/orchestration/workspace/worktree-workspace.ts +126 -126
  214. package/server/modules/providers/index.ts +2 -2
  215. package/server/modules/providers/list/claude/claude-auth.provider.ts +146 -146
  216. package/server/modules/providers/list/claude/claude-mcp.provider.ts +135 -135
  217. package/server/modules/providers/list/claude/claude-sessions.provider.ts +306 -306
  218. package/server/modules/providers/list/claude/claude.provider.ts +15 -15
  219. package/server/modules/providers/list/codex/codex-auth.provider.ts +117 -117
  220. package/server/modules/providers/list/codex/codex-mcp.provider.ts +135 -135
  221. package/server/modules/providers/list/codex/codex-sessions.provider.ts +319 -319
  222. package/server/modules/providers/list/codex/codex.provider.ts +15 -15
  223. package/server/modules/providers/list/cursor/cursor-auth.provider.ts +147 -147
  224. package/server/modules/providers/list/cursor/cursor-mcp.provider.ts +108 -108
  225. package/server/modules/providers/list/cursor/cursor-sessions.provider.ts +421 -421
  226. package/server/modules/providers/list/cursor/cursor.provider.ts +15 -15
  227. package/server/modules/providers/list/gemini/gemini-auth.provider.ts +173 -173
  228. package/server/modules/providers/list/gemini/gemini-mcp.provider.ts +110 -110
  229. package/server/modules/providers/list/gemini/gemini-sessions.provider.ts +227 -227
  230. package/server/modules/providers/list/gemini/gemini.provider.ts +15 -15
  231. package/server/modules/providers/list/opencode/opencode-auth.provider.ts +131 -131
  232. package/server/modules/providers/list/opencode/opencode-mcp.provider.ts +126 -126
  233. package/server/modules/providers/list/opencode/opencode-sessions.provider.ts +286 -286
  234. package/server/modules/providers/list/opencode/opencode.provider.ts +29 -29
  235. package/server/modules/providers/list/qwen/qwen-auth.provider.ts +146 -146
  236. package/server/modules/providers/list/qwen/qwen-mcp.provider.ts +114 -114
  237. package/server/modules/providers/list/qwen/qwen-sessions.provider.ts +265 -265
  238. package/server/modules/providers/list/qwen/qwen.provider.ts +21 -21
  239. package/server/modules/providers/provider.registry.ts +40 -40
  240. package/server/modules/providers/provider.routes.ts +944 -944
  241. package/server/modules/providers/services/mcp.service.ts +86 -86
  242. package/server/modules/providers/services/provider-auth.service.ts +26 -26
  243. package/server/modules/providers/services/sessions.service.ts +45 -45
  244. package/server/modules/providers/shared/base/abstract.provider.ts +20 -20
  245. package/server/modules/providers/shared/mcp/mcp.provider.ts +151 -151
  246. package/server/modules/providers/shared/provider-configs.ts +142 -142
  247. package/server/modules/providers/tests/mcp.test.ts +293 -293
  248. package/server/openai-codex.js +462 -462
  249. package/server/opencode-cli.js +491 -491
  250. package/server/opencode-response-handler.js +111 -111
  251. package/server/projects.js +3008 -3008
  252. package/server/qwen-code-cli.js +410 -410
  253. package/server/qwen-response-handler.js +73 -73
  254. package/server/routes/agent.js +1435 -1435
  255. package/server/routes/auth.js +159 -159
  256. package/server/routes/codex.js +20 -20
  257. package/server/routes/commands.js +570 -570
  258. package/server/routes/cursor.js +61 -61
  259. package/server/routes/diagnostics.js +41 -41
  260. package/server/routes/gemini.js +25 -25
  261. package/server/routes/git.js +1650 -1650
  262. package/server/routes/live-view.js +411 -411
  263. package/server/routes/mcp-utils.js +13 -13
  264. package/server/routes/messages.js +62 -62
  265. package/server/routes/network.js +125 -125
  266. package/server/routes/platformization.js +212 -212
  267. package/server/routes/plugins.js +320 -320
  268. package/server/routes/production-agent-loop.js +90 -90
  269. package/server/routes/projects.js +917 -917
  270. package/server/routes/public-api.js +34 -34
  271. package/server/routes/qwen.js +27 -27
  272. package/server/routes/remote.js +55 -55
  273. package/server/routes/settings.js +321 -321
  274. package/server/routes/telegram.js +140 -140
  275. package/server/routes/user.js +125 -125
  276. package/server/routes/webhooks.js +63 -63
  277. package/server/services/control-room.js +102 -102
  278. package/server/services/diagnostics.js +165 -165
  279. package/server/services/external-access.js +375 -375
  280. package/server/services/hermes-gateway.js +1562 -1247
  281. package/server/services/hermes-install-jobs.js +729 -729
  282. package/server/services/install-jobs.js +715 -715
  283. package/server/services/live-view.js +956 -956
  284. package/server/services/managed-runtimes.js +493 -493
  285. package/server/services/model-registry.js +144 -144
  286. package/server/services/notification-orchestrator.js +365 -365
  287. package/server/services/notification-taxonomy.js +204 -204
  288. package/server/services/platformization.js +815 -815
  289. package/server/services/production-agent-loop.js +248 -248
  290. package/server/services/provider-cli-versions.js +149 -149
  291. package/server/services/provider-credentials.js +189 -189
  292. package/server/services/provider-models.js +396 -396
  293. package/server/services/public-api-manifest.js +190 -182
  294. package/server/services/remote-connection.js +127 -127
  295. package/server/services/runtime-manager.js +323 -323
  296. package/server/services/startup-update.js +234 -234
  297. package/server/services/telegram/bot.js +331 -331
  298. package/server/services/telegram/control-center.js +979 -979
  299. package/server/services/telegram/telegram-http-client.js +151 -151
  300. package/server/services/telegram/translations.js +340 -340
  301. package/server/services/vapid-keys.js +36 -36
  302. package/server/services/webhooks.js +216 -216
  303. package/server/sessionManager.js +225 -225
  304. package/server/shared/interfaces.ts +54 -54
  305. package/server/shared/types.ts +172 -172
  306. package/server/shared/utils.ts +193 -193
  307. package/server/tsconfig.json +36 -36
  308. package/server/utils/colors.js +21 -21
  309. package/server/utils/commandParser.js +305 -305
  310. package/server/utils/frontmatter.js +18 -18
  311. package/server/utils/gitConfig.js +34 -34
  312. package/server/utils/plugin-loader.js +457 -457
  313. package/server/utils/plugin-process-manager.js +185 -185
  314. package/server/utils/port-access.js +209 -209
  315. package/server/utils/runtime-paths.js +37 -37
  316. package/server/utils/url-detection.js +71 -71
  317. package/server/vite-daemon.js +79 -79
  318. package/shared/modelConstants.js +161 -161
  319. package/shared/networkHosts.js +22 -22
  320. 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&amp;utm_source=badge-featured&amp;utm_medium=badge&amp;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&amp;theme=light&amp;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&amp;utm_source=badge-featured&amp;utm_medium=badge&amp;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&amp;theme=light&amp;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.