@pixelbyte-software/pixcode 1.51.2 → 1.51.4

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