@build-astron-co/nimbus 0.4.2 → 0.4.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 (430) hide show
  1. package/dist/src/agent/compaction-agent.js +24 -12
  2. package/dist/src/agent/context-manager.js +2 -1
  3. package/dist/src/agent/expand-files.js +2 -1
  4. package/dist/src/agent/loop.js +71 -33
  5. package/dist/src/agent/permissions.js +4 -2
  6. package/dist/src/agent/system-prompt.js +34 -17
  7. package/dist/src/app.js +1 -1
  8. package/dist/src/auth/keychain.js +8 -4
  9. package/dist/src/auth/store.js +70 -107
  10. package/dist/src/cli/init.js +35 -19
  11. package/dist/src/cli/run.js +18 -10
  12. package/dist/src/cli/serve.js +4 -2
  13. package/dist/src/cli.js +52 -11
  14. package/dist/src/commands/alias.js +5 -3
  15. package/dist/src/commands/audit/index.js +2 -1
  16. package/dist/src/commands/aws-terraform.js +36 -18
  17. package/dist/src/commands/completions.js +1 -1
  18. package/dist/src/commands/config.js +3 -2
  19. package/dist/src/commands/connect-github.js +92 -0
  20. package/dist/src/commands/cost/index.js +3 -2
  21. package/dist/src/commands/deploy.js +15 -10
  22. package/dist/src/commands/doctor.js +6 -3
  23. package/dist/src/commands/drift/index.js +2 -1
  24. package/dist/src/commands/export.js +5 -3
  25. package/dist/src/commands/generate-terraform.js +110 -2
  26. package/dist/src/commands/import.js +3 -3
  27. package/dist/src/commands/incident.js +10 -5
  28. package/dist/src/commands/login.js +8 -93
  29. package/dist/src/commands/logs.js +16 -8
  30. package/dist/src/commands/onboarding.js +6 -4
  31. package/dist/src/commands/pipeline.js +6 -3
  32. package/dist/src/commands/plugin.js +3 -2
  33. package/dist/src/commands/profile.js +27 -14
  34. package/dist/src/commands/questionnaire.js +1 -1
  35. package/dist/src/commands/rollback.js +3 -2
  36. package/dist/src/commands/rollout.js +5 -3
  37. package/dist/src/commands/runbook.js +17 -10
  38. package/dist/src/commands/schedule.js +10 -5
  39. package/dist/src/commands/status.js +2 -1
  40. package/dist/src/commands/team-context.js +12 -7
  41. package/dist/src/commands/template.js +1 -1
  42. package/dist/src/commands/tf/index.js +6 -3
  43. package/dist/src/commands/version.js +6 -3
  44. package/dist/src/commands/watch.js +6 -3
  45. package/dist/src/compat/sqlite.js +5 -3
  46. package/dist/src/config/mode-store.js +2 -1
  47. package/dist/src/config/profiles.js +4 -2
  48. package/dist/src/config/types.js +2 -1
  49. package/dist/src/engine/executor.js +8 -4
  50. package/dist/src/engine/planner.js +9 -5
  51. package/dist/src/llm/providers/anthropic.js +6 -3
  52. package/dist/src/llm/providers/ollama.js +1 -1
  53. package/dist/src/llm/router.js +22 -7
  54. package/dist/src/sessions/manager.js +6 -3
  55. package/dist/src/sharing/viewer.js +2 -1
  56. package/dist/src/tools/file-ops.js +1 -2
  57. package/dist/src/tools/schemas/devops.js +197 -108
  58. package/dist/src/tools/schemas/standard.js +1 -1
  59. package/dist/src/ui/App.js +25 -13
  60. package/dist/src/ui/FileDiffModal.js +22 -11
  61. package/dist/src/ui/HelpModal.js +2 -1
  62. package/dist/src/ui/InputBox.js +6 -3
  63. package/dist/src/ui/MessageList.js +40 -20
  64. package/dist/src/ui/TerminalPane.js +2 -1
  65. package/dist/src/ui/ToolCallDisplay.js +12 -6
  66. package/dist/src/ui/TreePane.js +2 -1
  67. package/dist/src/ui/ink/index.js +37 -21
  68. package/dist/src/watcher/index.js +8 -4
  69. package/package.json +3 -5
  70. package/src/__tests__/alias.test.ts +0 -133
  71. package/src/__tests__/app.test.ts +0 -76
  72. package/src/__tests__/audit.test.ts +0 -877
  73. package/src/__tests__/circuit-breaker.test.ts +0 -116
  74. package/src/__tests__/cli-run.test.ts +0 -351
  75. package/src/__tests__/compat-sqlite.test.ts +0 -68
  76. package/src/__tests__/context-manager.test.ts +0 -632
  77. package/src/__tests__/context.test.ts +0 -242
  78. package/src/__tests__/devops-terminal-gaps.test.ts +0 -718
  79. package/src/__tests__/doctor.test.ts +0 -48
  80. package/src/__tests__/enterprise.test.ts +0 -401
  81. package/src/__tests__/export.test.ts +0 -236
  82. package/src/__tests__/gap-11-18-20.test.ts +0 -958
  83. package/src/__tests__/generator.test.ts +0 -433
  84. package/src/__tests__/helm-streaming.test.ts +0 -127
  85. package/src/__tests__/hooks.test.ts +0 -582
  86. package/src/__tests__/incident.test.ts +0 -179
  87. package/src/__tests__/init.test.ts +0 -487
  88. package/src/__tests__/intent-parser.test.ts +0 -229
  89. package/src/__tests__/llm-router.test.ts +0 -209
  90. package/src/__tests__/logs.test.ts +0 -107
  91. package/src/__tests__/loop-errors.test.ts +0 -244
  92. package/src/__tests__/lsp.test.ts +0 -293
  93. package/src/__tests__/modes.test.ts +0 -336
  94. package/src/__tests__/perf-optimizations.test.ts +0 -847
  95. package/src/__tests__/permissions.test.ts +0 -338
  96. package/src/__tests__/pipeline.test.ts +0 -50
  97. package/src/__tests__/polish-phase3.test.ts +0 -340
  98. package/src/__tests__/profile.test.ts +0 -237
  99. package/src/__tests__/rollback.test.ts +0 -83
  100. package/src/__tests__/runbook.test.ts +0 -219
  101. package/src/__tests__/schedule.test.ts +0 -206
  102. package/src/__tests__/serve.test.ts +0 -275
  103. package/src/__tests__/sessions.test.ts +0 -322
  104. package/src/__tests__/sharing.test.ts +0 -340
  105. package/src/__tests__/snapshots.test.ts +0 -581
  106. package/src/__tests__/standalone-migration.test.ts +0 -199
  107. package/src/__tests__/state-db.test.ts +0 -334
  108. package/src/__tests__/status.test.ts +0 -158
  109. package/src/__tests__/stream-with-tools.test.ts +0 -778
  110. package/src/__tests__/subagents.test.ts +0 -176
  111. package/src/__tests__/system-prompt.test.ts +0 -248
  112. package/src/__tests__/terminal-gap-v2.test.ts +0 -395
  113. package/src/__tests__/terminal-parity.test.ts +0 -393
  114. package/src/__tests__/tf-apply.test.ts +0 -187
  115. package/src/__tests__/tool-converter.test.ts +0 -256
  116. package/src/__tests__/tool-schemas.test.ts +0 -602
  117. package/src/__tests__/tools.test.ts +0 -144
  118. package/src/__tests__/version-json.test.ts +0 -184
  119. package/src/__tests__/version.test.ts +0 -49
  120. package/src/__tests__/watch.test.ts +0 -129
  121. package/src/agent/compaction-agent.ts +0 -266
  122. package/src/agent/context-manager.ts +0 -499
  123. package/src/agent/context.ts +0 -427
  124. package/src/agent/deploy-preview.ts +0 -487
  125. package/src/agent/expand-files.ts +0 -108
  126. package/src/agent/index.ts +0 -68
  127. package/src/agent/loop.ts +0 -1998
  128. package/src/agent/modes.ts +0 -429
  129. package/src/agent/permissions.ts +0 -513
  130. package/src/agent/subagents/base.ts +0 -116
  131. package/src/agent/subagents/cost.ts +0 -51
  132. package/src/agent/subagents/explore.ts +0 -42
  133. package/src/agent/subagents/general.ts +0 -54
  134. package/src/agent/subagents/index.ts +0 -102
  135. package/src/agent/subagents/infra.ts +0 -59
  136. package/src/agent/subagents/security.ts +0 -69
  137. package/src/agent/system-prompt.ts +0 -990
  138. package/src/app.ts +0 -180
  139. package/src/audit/activity-log.ts +0 -290
  140. package/src/audit/compliance-checker.ts +0 -540
  141. package/src/audit/cost-tracker.ts +0 -318
  142. package/src/audit/index.ts +0 -23
  143. package/src/audit/security-scanner.ts +0 -641
  144. package/src/auth/guard.ts +0 -75
  145. package/src/auth/index.ts +0 -56
  146. package/src/auth/keychain.ts +0 -82
  147. package/src/auth/oauth.ts +0 -465
  148. package/src/auth/providers.ts +0 -470
  149. package/src/auth/sso.ts +0 -113
  150. package/src/auth/store.ts +0 -505
  151. package/src/auth/types.ts +0 -187
  152. package/src/build.ts +0 -141
  153. package/src/cli/index.ts +0 -16
  154. package/src/cli/init.ts +0 -1227
  155. package/src/cli/openapi-spec.ts +0 -356
  156. package/src/cli/run.ts +0 -628
  157. package/src/cli/serve-auth.ts +0 -80
  158. package/src/cli/serve.ts +0 -539
  159. package/src/cli/web.ts +0 -71
  160. package/src/cli.ts +0 -1728
  161. package/src/clients/core-engine-client.ts +0 -227
  162. package/src/clients/enterprise-client.ts +0 -334
  163. package/src/clients/generator-client.ts +0 -351
  164. package/src/clients/git-client.ts +0 -627
  165. package/src/clients/github-client.ts +0 -410
  166. package/src/clients/helm-client.ts +0 -504
  167. package/src/clients/index.ts +0 -80
  168. package/src/clients/k8s-client.ts +0 -497
  169. package/src/clients/llm-client.ts +0 -161
  170. package/src/clients/rest-client.ts +0 -130
  171. package/src/clients/service-discovery.ts +0 -38
  172. package/src/clients/terraform-client.ts +0 -482
  173. package/src/clients/tools-client.ts +0 -1843
  174. package/src/clients/ws-client.ts +0 -115
  175. package/src/commands/alias.ts +0 -100
  176. package/src/commands/analyze/index.ts +0 -352
  177. package/src/commands/apply/helm.ts +0 -473
  178. package/src/commands/apply/index.ts +0 -213
  179. package/src/commands/apply/k8s.ts +0 -454
  180. package/src/commands/apply/terraform.ts +0 -582
  181. package/src/commands/ask.ts +0 -167
  182. package/src/commands/audit/index.ts +0 -357
  183. package/src/commands/auth-cloud.ts +0 -407
  184. package/src/commands/auth-list.ts +0 -134
  185. package/src/commands/auth-profile.ts +0 -121
  186. package/src/commands/auth-refresh.ts +0 -187
  187. package/src/commands/auth-status.ts +0 -141
  188. package/src/commands/aws/ec2.ts +0 -501
  189. package/src/commands/aws/iam.ts +0 -397
  190. package/src/commands/aws/index.ts +0 -133
  191. package/src/commands/aws/lambda.ts +0 -396
  192. package/src/commands/aws/rds.ts +0 -439
  193. package/src/commands/aws/s3.ts +0 -439
  194. package/src/commands/aws/vpc.ts +0 -393
  195. package/src/commands/aws-discover.ts +0 -542
  196. package/src/commands/aws-terraform.ts +0 -755
  197. package/src/commands/azure/aks.ts +0 -376
  198. package/src/commands/azure/functions.ts +0 -253
  199. package/src/commands/azure/index.ts +0 -116
  200. package/src/commands/azure/storage.ts +0 -478
  201. package/src/commands/azure/vm.ts +0 -355
  202. package/src/commands/billing/index.ts +0 -256
  203. package/src/commands/chat.ts +0 -320
  204. package/src/commands/completions.ts +0 -268
  205. package/src/commands/config.ts +0 -372
  206. package/src/commands/cost/cloud-cost-estimator.ts +0 -266
  207. package/src/commands/cost/estimator.ts +0 -79
  208. package/src/commands/cost/index.ts +0 -810
  209. package/src/commands/cost/parsers/terraform.ts +0 -273
  210. package/src/commands/cost/parsers/types.ts +0 -25
  211. package/src/commands/cost/pricing/aws.ts +0 -544
  212. package/src/commands/cost/pricing/azure.ts +0 -499
  213. package/src/commands/cost/pricing/gcp.ts +0 -396
  214. package/src/commands/cost/pricing/index.ts +0 -40
  215. package/src/commands/demo.ts +0 -250
  216. package/src/commands/deploy.ts +0 -260
  217. package/src/commands/doctor.ts +0 -1386
  218. package/src/commands/drift/index.ts +0 -787
  219. package/src/commands/explain.ts +0 -277
  220. package/src/commands/export.ts +0 -146
  221. package/src/commands/feedback.ts +0 -389
  222. package/src/commands/fix.ts +0 -324
  223. package/src/commands/fs/index.ts +0 -402
  224. package/src/commands/gcp/compute.ts +0 -325
  225. package/src/commands/gcp/functions.ts +0 -271
  226. package/src/commands/gcp/gke.ts +0 -438
  227. package/src/commands/gcp/iam.ts +0 -344
  228. package/src/commands/gcp/index.ts +0 -129
  229. package/src/commands/gcp/storage.ts +0 -284
  230. package/src/commands/generate-helm.ts +0 -1249
  231. package/src/commands/generate-k8s.ts +0 -1508
  232. package/src/commands/generate-terraform.ts +0 -1202
  233. package/src/commands/gh/index.ts +0 -863
  234. package/src/commands/git/index.ts +0 -1343
  235. package/src/commands/helm/index.ts +0 -1126
  236. package/src/commands/help.ts +0 -715
  237. package/src/commands/history.ts +0 -149
  238. package/src/commands/import.ts +0 -868
  239. package/src/commands/incident.ts +0 -166
  240. package/src/commands/index.ts +0 -367
  241. package/src/commands/init.ts +0 -1051
  242. package/src/commands/k8s/index.ts +0 -1137
  243. package/src/commands/login.ts +0 -716
  244. package/src/commands/logout.ts +0 -83
  245. package/src/commands/logs.ts +0 -167
  246. package/src/commands/onboarding.ts +0 -405
  247. package/src/commands/pipeline.ts +0 -186
  248. package/src/commands/plan/display.ts +0 -279
  249. package/src/commands/plan/index.ts +0 -599
  250. package/src/commands/plugin.ts +0 -398
  251. package/src/commands/preview.ts +0 -452
  252. package/src/commands/profile.ts +0 -342
  253. package/src/commands/questionnaire.ts +0 -1172
  254. package/src/commands/resume.ts +0 -47
  255. package/src/commands/rollback.ts +0 -315
  256. package/src/commands/rollout.ts +0 -88
  257. package/src/commands/runbook.ts +0 -346
  258. package/src/commands/schedule.ts +0 -236
  259. package/src/commands/status.ts +0 -252
  260. package/src/commands/team/index.ts +0 -346
  261. package/src/commands/team-context.ts +0 -220
  262. package/src/commands/template.ts +0 -233
  263. package/src/commands/tf/index.ts +0 -1093
  264. package/src/commands/upgrade.ts +0 -609
  265. package/src/commands/usage/index.ts +0 -134
  266. package/src/commands/version.ts +0 -174
  267. package/src/commands/watch.ts +0 -153
  268. package/src/compat/index.ts +0 -2
  269. package/src/compat/runtime.ts +0 -12
  270. package/src/compat/sqlite.ts +0 -177
  271. package/src/config/index.ts +0 -17
  272. package/src/config/manager.ts +0 -530
  273. package/src/config/mode-store.ts +0 -62
  274. package/src/config/profiles.ts +0 -84
  275. package/src/config/safety-policy.ts +0 -358
  276. package/src/config/schema.ts +0 -125
  277. package/src/config/types.ts +0 -609
  278. package/src/config/workspace-state.ts +0 -53
  279. package/src/context/context-db.ts +0 -199
  280. package/src/demo/index.ts +0 -349
  281. package/src/demo/scenarios/full-journey.ts +0 -229
  282. package/src/demo/scenarios/getting-started.ts +0 -127
  283. package/src/demo/scenarios/helm-release.ts +0 -341
  284. package/src/demo/scenarios/k8s-deployment.ts +0 -194
  285. package/src/demo/scenarios/terraform-vpc.ts +0 -170
  286. package/src/demo/types.ts +0 -92
  287. package/src/engine/cost-estimator.ts +0 -480
  288. package/src/engine/diagram-generator.ts +0 -256
  289. package/src/engine/drift-detector.ts +0 -902
  290. package/src/engine/executor.ts +0 -1066
  291. package/src/engine/index.ts +0 -76
  292. package/src/engine/orchestrator.ts +0 -636
  293. package/src/engine/planner.ts +0 -787
  294. package/src/engine/safety.ts +0 -743
  295. package/src/engine/verifier.ts +0 -770
  296. package/src/enterprise/audit.ts +0 -348
  297. package/src/enterprise/auth.ts +0 -270
  298. package/src/enterprise/billing.ts +0 -822
  299. package/src/enterprise/index.ts +0 -17
  300. package/src/enterprise/teams.ts +0 -443
  301. package/src/generator/best-practices.ts +0 -1608
  302. package/src/generator/helm.ts +0 -630
  303. package/src/generator/index.ts +0 -37
  304. package/src/generator/intent-parser.ts +0 -514
  305. package/src/generator/kubernetes.ts +0 -976
  306. package/src/generator/terraform.ts +0 -1875
  307. package/src/history/index.ts +0 -8
  308. package/src/history/manager.ts +0 -250
  309. package/src/history/types.ts +0 -34
  310. package/src/hooks/config.ts +0 -432
  311. package/src/hooks/engine.ts +0 -392
  312. package/src/hooks/index.ts +0 -4
  313. package/src/llm/auth-bridge.ts +0 -198
  314. package/src/llm/circuit-breaker.ts +0 -140
  315. package/src/llm/config-loader.ts +0 -201
  316. package/src/llm/cost-calculator.ts +0 -171
  317. package/src/llm/index.ts +0 -8
  318. package/src/llm/model-aliases.ts +0 -115
  319. package/src/llm/provider-registry.ts +0 -63
  320. package/src/llm/providers/anthropic.ts +0 -462
  321. package/src/llm/providers/bedrock.ts +0 -477
  322. package/src/llm/providers/google.ts +0 -405
  323. package/src/llm/providers/ollama.ts +0 -767
  324. package/src/llm/providers/openai-compatible.ts +0 -340
  325. package/src/llm/providers/openai.ts +0 -328
  326. package/src/llm/providers/openrouter.ts +0 -338
  327. package/src/llm/router.ts +0 -1104
  328. package/src/llm/types.ts +0 -232
  329. package/src/lsp/client.ts +0 -298
  330. package/src/lsp/languages.ts +0 -119
  331. package/src/lsp/manager.ts +0 -294
  332. package/src/mcp/client.ts +0 -402
  333. package/src/mcp/index.ts +0 -5
  334. package/src/mcp/manager.ts +0 -133
  335. package/src/nimbus.ts +0 -234
  336. package/src/plugins/index.ts +0 -27
  337. package/src/plugins/loader.ts +0 -334
  338. package/src/plugins/manager.ts +0 -376
  339. package/src/plugins/types.ts +0 -284
  340. package/src/scanners/cicd-scanner.ts +0 -258
  341. package/src/scanners/cloud-scanner.ts +0 -466
  342. package/src/scanners/framework-scanner.ts +0 -469
  343. package/src/scanners/iac-scanner.ts +0 -388
  344. package/src/scanners/index.ts +0 -539
  345. package/src/scanners/language-scanner.ts +0 -276
  346. package/src/scanners/package-manager-scanner.ts +0 -277
  347. package/src/scanners/types.ts +0 -172
  348. package/src/sessions/manager.ts +0 -472
  349. package/src/sessions/types.ts +0 -44
  350. package/src/sharing/sync.ts +0 -300
  351. package/src/sharing/viewer.ts +0 -163
  352. package/src/snapshots/index.ts +0 -2
  353. package/src/snapshots/manager.ts +0 -530
  354. package/src/state/artifacts.ts +0 -147
  355. package/src/state/audit.ts +0 -137
  356. package/src/state/billing.ts +0 -240
  357. package/src/state/checkpoints.ts +0 -117
  358. package/src/state/config.ts +0 -67
  359. package/src/state/conversations.ts +0 -14
  360. package/src/state/credentials.ts +0 -154
  361. package/src/state/db.ts +0 -58
  362. package/src/state/index.ts +0 -26
  363. package/src/state/messages.ts +0 -115
  364. package/src/state/projects.ts +0 -123
  365. package/src/state/schema.ts +0 -236
  366. package/src/state/sessions.ts +0 -147
  367. package/src/state/teams.ts +0 -200
  368. package/src/telemetry.ts +0 -108
  369. package/src/tools/aws-ops.ts +0 -952
  370. package/src/tools/azure-ops.ts +0 -579
  371. package/src/tools/file-ops.ts +0 -615
  372. package/src/tools/gcp-ops.ts +0 -625
  373. package/src/tools/git-ops.ts +0 -773
  374. package/src/tools/github-ops.ts +0 -799
  375. package/src/tools/helm-ops.ts +0 -943
  376. package/src/tools/index.ts +0 -17
  377. package/src/tools/k8s-ops.ts +0 -819
  378. package/src/tools/schemas/converter.ts +0 -184
  379. package/src/tools/schemas/devops.ts +0 -3502
  380. package/src/tools/schemas/index.ts +0 -73
  381. package/src/tools/schemas/standard.ts +0 -1148
  382. package/src/tools/schemas/types.ts +0 -735
  383. package/src/tools/spawn-exec.ts +0 -148
  384. package/src/tools/terraform-ops.ts +0 -862
  385. package/src/types/ambient.d.ts +0 -193
  386. package/src/types/config.ts +0 -83
  387. package/src/types/drift.ts +0 -116
  388. package/src/types/enterprise.ts +0 -335
  389. package/src/types/index.ts +0 -20
  390. package/src/types/plan.ts +0 -44
  391. package/src/types/request.ts +0 -65
  392. package/src/types/response.ts +0 -54
  393. package/src/types/service.ts +0 -51
  394. package/src/ui/App.tsx +0 -2114
  395. package/src/ui/DeployPreview.tsx +0 -174
  396. package/src/ui/FileDiffModal.tsx +0 -162
  397. package/src/ui/Header.tsx +0 -131
  398. package/src/ui/HelpModal.tsx +0 -57
  399. package/src/ui/InputBox.tsx +0 -503
  400. package/src/ui/MessageList.tsx +0 -1032
  401. package/src/ui/PermissionPrompt.tsx +0 -163
  402. package/src/ui/StatusBar.tsx +0 -277
  403. package/src/ui/TerminalPane.tsx +0 -84
  404. package/src/ui/ToolCallDisplay.tsx +0 -643
  405. package/src/ui/TreePane.tsx +0 -132
  406. package/src/ui/chat-ui.ts +0 -850
  407. package/src/ui/index.ts +0 -33
  408. package/src/ui/ink/index.ts +0 -1444
  409. package/src/ui/streaming.ts +0 -176
  410. package/src/ui/theme.ts +0 -104
  411. package/src/ui/types.ts +0 -75
  412. package/src/utils/analytics.ts +0 -72
  413. package/src/utils/cost-warning.ts +0 -27
  414. package/src/utils/env.ts +0 -46
  415. package/src/utils/errors.ts +0 -69
  416. package/src/utils/event-bus.ts +0 -38
  417. package/src/utils/index.ts +0 -24
  418. package/src/utils/logger.ts +0 -171
  419. package/src/utils/rate-limiter.ts +0 -121
  420. package/src/utils/service-auth.ts +0 -49
  421. package/src/utils/validation.ts +0 -53
  422. package/src/version.ts +0 -4
  423. package/src/watcher/index.ts +0 -214
  424. package/src/wizard/approval.ts +0 -383
  425. package/src/wizard/index.ts +0 -25
  426. package/src/wizard/prompts.ts +0 -338
  427. package/src/wizard/types.ts +0 -172
  428. package/src/wizard/ui.ts +0 -556
  429. package/src/wizard/wizard.ts +0 -304
  430. package/tsconfig.json +0 -24
@@ -1,389 +0,0 @@
1
- /**
2
- * Feedback Command
3
- *
4
- * Collect and submit user feedback via GitHub issues or browser
5
- *
6
- * Usage: nimbus feedback [options]
7
- */
8
-
9
- import { logger } from '../utils';
10
- import { ui } from '../wizard';
11
- import { input, select } from '../wizard/prompts';
12
-
13
- /**
14
- * Command options
15
- */
16
- export interface FeedbackOptions {
17
- bug?: boolean;
18
- feature?: boolean;
19
- question?: boolean;
20
- title?: string;
21
- body?: string;
22
- open?: boolean;
23
- json?: boolean;
24
- }
25
-
26
- /**
27
- * Feedback type configuration
28
- */
29
- interface FeedbackType {
30
- label: string;
31
- emoji: string;
32
- template: string;
33
- labels: string[];
34
- }
35
-
36
- const FEEDBACK_TYPES: Record<string, FeedbackType> = {
37
- bug: {
38
- label: 'Bug Report',
39
- emoji: 'bug',
40
- template: `## Bug Description
41
- <!-- A clear and concise description of what the bug is -->
42
-
43
- ## Steps to Reproduce
44
- 1.
45
- 2.
46
- 3.
47
-
48
- ## Expected Behavior
49
- <!-- What you expected to happen -->
50
-
51
- ## Actual Behavior
52
- <!-- What actually happened -->
53
-
54
- ## Environment
55
- - Nimbus Version:
56
- - OS:
57
- - Node Version:
58
-
59
- ## Additional Context
60
- <!-- Any other relevant information -->
61
- `,
62
- labels: ['bug', 'triage'],
63
- },
64
- feature: {
65
- label: 'Feature Request',
66
- emoji: 'sparkles',
67
- template: `## Feature Description
68
- <!-- A clear and concise description of the feature -->
69
-
70
- ## Use Case
71
- <!-- Why do you need this feature? What problem does it solve? -->
72
-
73
- ## Proposed Solution
74
- <!-- How do you think this should work? -->
75
-
76
- ## Alternatives Considered
77
- <!-- Any alternative solutions or features you've considered -->
78
-
79
- ## Additional Context
80
- <!-- Any other relevant information -->
81
- `,
82
- labels: ['enhancement', 'feature-request'],
83
- },
84
- question: {
85
- label: 'Question',
86
- emoji: 'question',
87
- template: `## Question
88
- <!-- What would you like to know? -->
89
-
90
- ## Context
91
- <!-- What are you trying to accomplish? -->
92
-
93
- ## What I've Tried
94
- <!-- What documentation or approaches have you already tried? -->
95
- `,
96
- labels: ['question', 'help-wanted'],
97
- },
98
- };
99
-
100
- const GITHUB_REPO = 'the-ai-project-co/nimbus';
101
- const GITHUB_ISSUES_URL = `https://github.com/${GITHUB_REPO}/issues`;
102
-
103
- /**
104
- * Get system information for bug reports
105
- */
106
- async function getSystemInfo(): Promise<Record<string, string>> {
107
- const os = await import('os');
108
- const { execFileSync } = await import('child_process');
109
-
110
- const info: Record<string, string> = {
111
- OS: `${os.platform()} ${os.release()}`,
112
- Architecture: os.arch(),
113
- 'Node Version': process.version,
114
- };
115
-
116
- // Try to get Nimbus version
117
- try {
118
- const fs = await import('fs/promises');
119
- const path = await import('path');
120
- const packagePath = path.join(__dirname, '../../package.json');
121
- const packageJson = JSON.parse(await fs.readFile(packagePath, 'utf-8'));
122
- info['Nimbus Version'] = packageJson.version;
123
- } catch {
124
- info['Nimbus Version'] = 'unknown';
125
- }
126
-
127
- // Try to get Bun version
128
- try {
129
- const bunVersion = execFileSync('bun', ['--version'], { encoding: 'utf-8' }).trim();
130
- info['Bun Version'] = bunVersion;
131
- } catch {
132
- // Bun not installed
133
- }
134
-
135
- return info;
136
- }
137
-
138
- /**
139
- * Open URL in browser
140
- */
141
- async function openInBrowser(url: string): Promise<boolean> {
142
- const { exec } = await import('child_process');
143
- const { promisify } = await import('util');
144
- const execAsync = promisify(exec);
145
-
146
- try {
147
- const platform = process.platform;
148
- let command: string;
149
-
150
- if (platform === 'darwin') {
151
- command = `open "${url}"`;
152
- } else if (platform === 'win32') {
153
- command = `start "" "${url}"`;
154
- } else {
155
- command = `xdg-open "${url}"`;
156
- }
157
-
158
- await execAsync(command);
159
- return true;
160
- } catch {
161
- return false;
162
- }
163
- }
164
-
165
- /**
166
- * Build GitHub issue URL with pre-filled content
167
- */
168
- function buildIssueUrl(type: string, title: string, body: string, labels: string[]): string {
169
- const params = new URLSearchParams({
170
- title,
171
- body,
172
- labels: labels.join(','),
173
- });
174
-
175
- return `${GITHUB_ISSUES_URL}/new?${params.toString()}`;
176
- }
177
-
178
- /**
179
- * Interactive feedback collection
180
- */
181
- async function collectFeedbackInteractively(
182
- options: FeedbackOptions
183
- ): Promise<{ type: string; title: string; body: string } | null> {
184
- // Determine feedback type
185
- let feedbackType: string | undefined;
186
-
187
- if (options.bug) {
188
- feedbackType = 'bug';
189
- } else if (options.feature) {
190
- feedbackType = 'feature';
191
- } else if (options.question) {
192
- feedbackType = 'question';
193
- } else {
194
- // Ask user to select type
195
- feedbackType = await select({
196
- message: 'What type of feedback would you like to provide?',
197
- options: [
198
- { label: 'Bug Report', value: 'bug' },
199
- { label: 'Feature Request', value: 'feature' },
200
- { label: 'Question', value: 'question' },
201
- ],
202
- });
203
-
204
- if (!feedbackType) {
205
- return null;
206
- }
207
- }
208
-
209
- const typeConfig = FEEDBACK_TYPES[feedbackType];
210
-
211
- ui.newLine();
212
- ui.print(ui.bold(`${typeConfig.label}`));
213
- ui.newLine();
214
-
215
- // Get title
216
- let title = options.title;
217
- if (!title) {
218
- title = await input({
219
- message: 'Brief summary (title):',
220
- placeholder: `Enter a short description of your ${feedbackType === 'bug' ? 'issue' : feedbackType === 'feature' ? 'request' : 'question'}`,
221
- });
222
-
223
- if (!title || title.trim() === '') {
224
- ui.warning('Feedback cancelled - no title provided');
225
- return null;
226
- }
227
- }
228
-
229
- // Get body/description
230
- let body = options.body;
231
- if (!body) {
232
- ui.newLine();
233
- ui.info('Please provide details (press Enter twice to finish):');
234
- ui.dim('Tip: You can also edit the full template on GitHub');
235
- ui.newLine();
236
-
237
- body = await input({
238
- message: 'Details (optional):',
239
- placeholder: 'Describe the issue, feature, or question in detail...',
240
- });
241
- }
242
-
243
- // Build full body with template
244
- let fullBody = typeConfig.template;
245
-
246
- if (body && body.trim()) {
247
- // Replace first section placeholder with user's input
248
- fullBody = fullBody.replace(/<!-- .+? -->/, body.trim());
249
- }
250
-
251
- // Add system info for bug reports
252
- if (feedbackType === 'bug') {
253
- const systemInfo = await getSystemInfo();
254
- const envSection = Object.entries(systemInfo)
255
- .map(([key, value]) => `- ${key}: ${value}`)
256
- .join('\n');
257
-
258
- fullBody = fullBody.replace(
259
- '## Environment\n- Nimbus Version: \n- OS: \n- Node Version:',
260
- `## Environment\n${envSection}`
261
- );
262
- }
263
-
264
- return {
265
- type: feedbackType,
266
- title: title.trim(),
267
- body: fullBody,
268
- };
269
- }
270
-
271
- /**
272
- * Run the feedback command
273
- */
274
- export async function feedbackCommand(options: FeedbackOptions = {}): Promise<void> {
275
- logger.debug('Running feedback command', { options });
276
-
277
- ui.header('Nimbus Feedback');
278
- ui.info('Help us improve Nimbus by sharing your feedback!');
279
- ui.newLine();
280
-
281
- // Quick open mode - just open GitHub issues
282
- if (options.open) {
283
- ui.info('Opening GitHub issues page...');
284
- const opened = await openInBrowser(GITHUB_ISSUES_URL);
285
-
286
- if (opened) {
287
- ui.success('Opened in browser');
288
- } else {
289
- ui.print(`Visit: ${GITHUB_ISSUES_URL}`);
290
- }
291
- return;
292
- }
293
-
294
- // Collect feedback interactively
295
- const feedback = await collectFeedbackInteractively(options);
296
-
297
- if (!feedback) {
298
- return;
299
- }
300
-
301
- const typeConfig = FEEDBACK_TYPES[feedback.type];
302
- const issueUrl = buildIssueUrl(feedback.type, feedback.title, feedback.body, typeConfig.labels);
303
-
304
- // JSON output
305
- if (options.json) {
306
- console.log(
307
- JSON.stringify(
308
- {
309
- type: feedback.type,
310
- title: feedback.title,
311
- url: issueUrl,
312
- labels: typeConfig.labels,
313
- },
314
- null,
315
- 2
316
- )
317
- );
318
- return;
319
- }
320
-
321
- ui.newLine();
322
- ui.print(ui.bold('Feedback Summary'));
323
- ui.print(` Type: ${typeConfig.label}`);
324
- ui.print(` Title: ${feedback.title}`);
325
- ui.newLine();
326
-
327
- // Open in browser
328
- ui.info('Opening GitHub to submit your feedback...');
329
-
330
- const opened = await openInBrowser(issueUrl);
331
-
332
- if (opened) {
333
- ui.success('Opened in browser - please review and submit the issue');
334
- } else {
335
- ui.warning('Could not open browser automatically');
336
- ui.newLine();
337
- ui.print('Please copy and paste this URL to submit your feedback:');
338
- ui.print(issueUrl);
339
- }
340
-
341
- ui.newLine();
342
- ui.info('Thank you for your feedback!');
343
- }
344
-
345
- /**
346
- * Parse feedback command options from CLI args
347
- */
348
- export function parseFeedbackOptions(args: string[]): FeedbackOptions {
349
- const options: FeedbackOptions = {};
350
-
351
- for (let i = 0; i < args.length; i++) {
352
- const arg = args[i];
353
-
354
- switch (arg) {
355
- case '--bug':
356
- case '-b':
357
- options.bug = true;
358
- break;
359
- case '--feature':
360
- case '-f':
361
- options.feature = true;
362
- break;
363
- case '--question':
364
- case '-q':
365
- options.question = true;
366
- break;
367
- case '--title':
368
- case '-t':
369
- options.title = args[++i];
370
- break;
371
- case '--body':
372
- case '-m':
373
- options.body = args[++i];
374
- break;
375
- case '--open':
376
- case '-o':
377
- options.open = true;
378
- break;
379
- case '--json':
380
- options.json = true;
381
- break;
382
- }
383
- }
384
-
385
- return options;
386
- }
387
-
388
- // Export as default command
389
- export default feedbackCommand;
@@ -1,324 +0,0 @@
1
- /**
2
- * Fix Command
3
- *
4
- * AI-assisted error fixing
5
- *
6
- * Usage: nimbus fix <error-or-file> [options]
7
- */
8
-
9
- import { logger } from '../utils';
10
- import { ui, confirm } from '../wizard';
11
- import { llmClient } from '../clients';
12
-
13
- /**
14
- * Command options
15
- */
16
- export interface FixOptions {
17
- file?: string;
18
- autoApply?: boolean;
19
- dryRun?: boolean;
20
- json?: boolean;
21
- }
22
-
23
- /**
24
- * Fix suggestion from AI
25
- */
26
- interface FixSuggestion {
27
- problem: string;
28
- explanation: string;
29
- fix: string;
30
- originalCode?: string;
31
- fixedCode?: string;
32
- filePath?: string;
33
- lineNumber?: number;
34
- }
35
-
36
- /**
37
- * Parse fix response from AI
38
- */
39
- function parseFixResponse(response: string): FixSuggestion {
40
- // Try to extract structured sections from the response
41
- const problemMatch = response.match(
42
- /(?:problem|issue|error):\s*(.+?)(?=\n(?:explanation|fix|solution)|$)/is
43
- );
44
- const explanationMatch = response.match(
45
- /(?:explanation|cause|reason):\s*(.+?)(?=\n(?:fix|solution)|$)/is
46
- );
47
- const fixMatch = response.match(
48
- /(?:fix|solution|resolution):\s*(.+?)(?=\n(?:original|fixed)|$)/is
49
- );
50
- const originalMatch = response.match(/(?:original|before)[^:]*:\s*```[\w]*\n([\s\S]*?)```/i);
51
- const fixedMatch = response.match(/(?:fixed|after|corrected)[^:]*:\s*```[\w]*\n([\s\S]*?)```/i);
52
-
53
- return {
54
- problem: problemMatch?.[1]?.trim() || 'Unable to parse problem description',
55
- explanation: explanationMatch?.[1]?.trim() || response.split('\n').slice(0, 3).join('\n'),
56
- fix: fixMatch?.[1]?.trim() || 'See suggested code below',
57
- originalCode: originalMatch?.[1]?.trim(),
58
- fixedCode: fixedMatch?.[1]?.trim(),
59
- };
60
- }
61
-
62
- /**
63
- * Build the fix prompt
64
- */
65
- function buildFixPrompt(errorContent: string, fileContent?: string, filePath?: string): string {
66
- let prompt = `Please help fix this error. Analyze the problem and provide a solution.
67
-
68
- Error:
69
- \`\`\`
70
- ${errorContent}
71
- \`\`\`
72
- `;
73
-
74
- if (fileContent && filePath) {
75
- prompt += `
76
- Source file (${filePath}):
77
- \`\`\`
78
- ${fileContent}
79
- \`\`\`
80
- `;
81
- }
82
-
83
- prompt += `
84
- Please provide:
85
- 1. **Problem**: A brief description of what's wrong
86
- 2. **Explanation**: Why this error occurs
87
- 3. **Fix**: How to fix it
88
-
89
- If you can provide code changes, please show:
90
- - **Original**: The problematic code
91
- - **Fixed**: The corrected code
92
-
93
- Format your response with clear section headers.`;
94
-
95
- return prompt;
96
- }
97
-
98
- /**
99
- * Display fix suggestion
100
- */
101
- function displayFixSuggestion(suggestion: FixSuggestion): void {
102
- ui.newLine();
103
-
104
- // Problem
105
- ui.print(ui.color('Problem:', 'yellow'));
106
- ui.print(` ${suggestion.problem}`);
107
- ui.newLine();
108
-
109
- // Explanation
110
- ui.print(ui.color('Explanation:', 'blue'));
111
- for (const line of suggestion.explanation.split('\n')) {
112
- ui.print(` ${line}`);
113
- }
114
- ui.newLine();
115
-
116
- // Fix
117
- ui.print(ui.color('Suggested Fix:', 'green'));
118
- for (const line of suggestion.fix.split('\n')) {
119
- ui.print(` ${line}`);
120
- }
121
-
122
- // Show diff if we have original and fixed code
123
- if (suggestion.originalCode && suggestion.fixedCode) {
124
- ui.newLine();
125
- ui.print(ui.color('Code Changes:', 'cyan'));
126
- ui.newLine();
127
-
128
- // Show original
129
- ui.print(ui.color('Before:', 'red'));
130
- ui.print('```');
131
- for (const line of suggestion.originalCode.split('\n')) {
132
- ui.print(ui.color(`- ${line}`, 'red'));
133
- }
134
- ui.print('```');
135
-
136
- ui.newLine();
137
-
138
- // Show fixed
139
- ui.print(ui.color('After:', 'green'));
140
- ui.print('```');
141
- for (const line of suggestion.fixedCode.split('\n')) {
142
- ui.print(ui.color(`+ ${line}`, 'green'));
143
- }
144
- ui.print('```');
145
- }
146
- }
147
-
148
- /**
149
- * Apply the fix to a file
150
- */
151
- async function applyFix(suggestion: FixSuggestion, filePath: string): Promise<boolean> {
152
- if (!suggestion.originalCode || !suggestion.fixedCode) {
153
- ui.warning('Cannot auto-apply: No code diff provided');
154
- return false;
155
- }
156
-
157
- try {
158
- const fs = await import('fs/promises');
159
- const content = await fs.readFile(filePath, 'utf-8');
160
-
161
- // Try to find and replace the original code
162
- if (content.includes(suggestion.originalCode)) {
163
- const newContent = content.replace(suggestion.originalCode, suggestion.fixedCode);
164
- await fs.writeFile(filePath, newContent, 'utf-8');
165
- return true;
166
- } else {
167
- ui.warning('Could not find the original code in the file');
168
- ui.info('The file may have been modified since the analysis');
169
- return false;
170
- }
171
- } catch (error: any) {
172
- ui.error(`Failed to apply fix: ${error.message}`);
173
- return false;
174
- }
175
- }
176
-
177
- /**
178
- * Run the fix command
179
- */
180
- export async function fixCommand(errorOrFile: string, options: FixOptions = {}): Promise<void> {
181
- logger.info('Running fix command', { errorOrFile, options });
182
-
183
- let errorContent: string;
184
- let fileContent: string | undefined;
185
- let filePath: string | undefined;
186
-
187
- // Determine what we're fixing
188
- if (options.file) {
189
- // Error content with explicit file
190
- errorContent = errorOrFile;
191
- filePath = options.file;
192
-
193
- try {
194
- const fs = await import('fs/promises');
195
- fileContent = await fs.readFile(filePath, 'utf-8');
196
- } catch (error: any) {
197
- ui.warning(`Could not read file ${filePath}: ${error.message}`);
198
- }
199
- } else if (errorOrFile) {
200
- // Check if it's a file path
201
- try {
202
- const fs = await import('fs/promises');
203
- const stat = await fs.stat(errorOrFile);
204
-
205
- if (stat.isFile()) {
206
- filePath = errorOrFile;
207
- fileContent = await fs.readFile(errorOrFile, 'utf-8');
208
-
209
- // For a file without explicit error, we'll analyze the whole file
210
- errorContent = `Please analyze this file for potential issues and errors:\n${errorOrFile}`;
211
- } else {
212
- errorContent = errorOrFile;
213
- }
214
- } catch {
215
- // Not a file, treat as error message
216
- errorContent = errorOrFile;
217
- }
218
- } else {
219
- ui.error('Please provide an error message or file to fix');
220
- ui.newLine();
221
- ui.print('Usage: nimbus fix <error-or-file> [options]');
222
- ui.newLine();
223
- ui.print('Examples:');
224
- ui.print(' nimbus fix "Error: undefined variable"');
225
- ui.print(' nimbus fix ./broken.tf');
226
- ui.print(' nimbus fix "Error: invalid syntax" --file ./app.py');
227
- ui.print(' nimbus fix ./config.yaml --auto-apply');
228
- process.exit(1);
229
- }
230
-
231
- // Display header
232
- ui.header('Nimbus Fix');
233
- if (filePath) {
234
- ui.info(`File: ${filePath}`);
235
- }
236
- ui.info(`Error: ${errorContent.slice(0, 100)}${errorContent.length > 100 ? '...' : ''}`);
237
- ui.newLine();
238
-
239
- // Check if LLM is available
240
- const llmAvailable = await llmClient.isAvailable();
241
-
242
- if (!llmAvailable) {
243
- ui.error('LLM service is not available');
244
- ui.info('Make sure you have configured an LLM provider with "nimbus login"');
245
- process.exit(1);
246
- }
247
-
248
- // Build prompt
249
- const prompt = buildFixPrompt(errorContent, fileContent, filePath);
250
-
251
- ui.startSpinner({ message: 'Analyzing error...' });
252
-
253
- try {
254
- let response = '';
255
-
256
- for await (const chunk of llmClient.chat(prompt, [])) {
257
- if (chunk.type === 'content' && chunk.content) {
258
- response += chunk.content;
259
- } else if (chunk.type === 'error') {
260
- ui.stopSpinnerFail('Error');
261
- ui.error(chunk.message || chunk.error || 'Unknown error');
262
- process.exit(1);
263
- }
264
- }
265
-
266
- ui.stopSpinnerSuccess('Analysis complete');
267
-
268
- // Parse and display the suggestion
269
- const suggestion = parseFixResponse(response);
270
- suggestion.filePath = filePath;
271
-
272
- displayFixSuggestion(suggestion);
273
-
274
- // JSON output mode
275
- if (options.json) {
276
- console.log(JSON.stringify(suggestion, null, 2));
277
- return;
278
- }
279
-
280
- // Dry run - don't apply
281
- if (options.dryRun) {
282
- ui.newLine();
283
- ui.info('Dry run mode - no changes applied');
284
- return;
285
- }
286
-
287
- // Apply the fix if requested and possible
288
- if (filePath && suggestion.originalCode && suggestion.fixedCode) {
289
- ui.newLine();
290
-
291
- const shouldApply =
292
- options.autoApply ||
293
- (await confirm({
294
- message: 'Apply this fix?',
295
- defaultValue: false,
296
- }));
297
-
298
- if (shouldApply) {
299
- ui.startSpinner({ message: 'Applying fix...' });
300
-
301
- const applied = await applyFix(suggestion, filePath);
302
-
303
- if (applied) {
304
- ui.stopSpinnerSuccess('Fix applied successfully!');
305
- ui.newLine();
306
- ui.info(`File updated: ${filePath}`);
307
- ui.info('Please review the changes and test your code');
308
- } else {
309
- ui.stopSpinnerFail('Could not apply fix automatically');
310
- ui.info('Please apply the suggested changes manually');
311
- }
312
- } else {
313
- ui.info('Fix not applied');
314
- }
315
- }
316
- } catch (error: any) {
317
- ui.stopSpinnerFail('Failed');
318
- ui.error(error.message);
319
- process.exit(1);
320
- }
321
- }
322
-
323
- // Export as default
324
- export default fixCommand;