@build-astron-co/nimbus 0.2.0 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (469) hide show
  1. package/bin/nimbus +26 -10
  2. package/bin/nimbus.cmd +41 -0
  3. package/bin/nimbus.mjs +70 -0
  4. package/completions/nimbus.bash +38 -0
  5. package/completions/nimbus.fish +48 -0
  6. package/completions/nimbus.zsh +81 -0
  7. package/dist/src/agent/compaction-agent.js +215 -0
  8. package/dist/src/agent/context-manager.js +385 -0
  9. package/dist/src/agent/context.js +322 -0
  10. package/dist/src/agent/deploy-preview.js +395 -0
  11. package/dist/src/agent/expand-files.js +95 -0
  12. package/dist/src/agent/index.js +18 -0
  13. package/dist/src/agent/loop.js +1535 -0
  14. package/dist/src/agent/modes.js +347 -0
  15. package/dist/src/agent/permissions.js +396 -0
  16. package/dist/src/agent/subagents/base.js +67 -0
  17. package/dist/src/agent/subagents/cost.js +45 -0
  18. package/dist/src/agent/subagents/explore.js +36 -0
  19. package/dist/src/agent/subagents/general.js +41 -0
  20. package/dist/src/agent/subagents/index.js +88 -0
  21. package/dist/src/agent/subagents/infra.js +52 -0
  22. package/dist/src/agent/subagents/security.js +60 -0
  23. package/dist/src/agent/system-prompt.js +860 -0
  24. package/dist/src/app.js +152 -0
  25. package/dist/src/audit/activity-log.js +209 -0
  26. package/dist/src/audit/compliance-checker.js +419 -0
  27. package/dist/src/audit/cost-tracker.js +231 -0
  28. package/dist/src/audit/index.js +10 -0
  29. package/dist/src/audit/security-scanner.js +490 -0
  30. package/dist/src/auth/guard.js +64 -0
  31. package/dist/src/auth/index.js +19 -0
  32. package/dist/src/auth/keychain.js +79 -0
  33. package/dist/src/auth/oauth.js +389 -0
  34. package/dist/src/auth/providers.js +415 -0
  35. package/dist/src/auth/sso.js +87 -0
  36. package/dist/src/auth/store.js +424 -0
  37. package/dist/src/auth/types.js +5 -0
  38. package/dist/src/cli/index.js +8 -0
  39. package/dist/src/cli/init.js +1048 -0
  40. package/dist/src/cli/openapi-spec.js +346 -0
  41. package/dist/src/cli/run.js +505 -0
  42. package/dist/src/cli/serve-auth.js +56 -0
  43. package/dist/src/cli/serve.js +432 -0
  44. package/dist/src/cli/web.js +50 -0
  45. package/dist/src/cli.js +1574 -0
  46. package/dist/src/clients/core-engine-client.js +156 -0
  47. package/dist/src/clients/enterprise-client.js +246 -0
  48. package/dist/src/clients/generator-client.js +219 -0
  49. package/dist/src/clients/git-client.js +367 -0
  50. package/dist/src/clients/github-client.js +229 -0
  51. package/dist/src/clients/helm-client.js +299 -0
  52. package/dist/src/clients/index.js +18 -0
  53. package/dist/src/clients/k8s-client.js +270 -0
  54. package/dist/src/clients/llm-client.js +119 -0
  55. package/dist/src/clients/rest-client.js +104 -0
  56. package/dist/src/clients/service-discovery.js +35 -0
  57. package/dist/src/clients/terraform-client.js +302 -0
  58. package/dist/src/clients/tools-client.js +1227 -0
  59. package/dist/src/clients/ws-client.js +93 -0
  60. package/dist/src/commands/alias.js +91 -0
  61. package/dist/src/commands/analyze/index.js +313 -0
  62. package/dist/src/commands/apply/helm.js +375 -0
  63. package/dist/src/commands/apply/index.js +176 -0
  64. package/dist/src/commands/apply/k8s.js +350 -0
  65. package/dist/src/commands/apply/terraform.js +465 -0
  66. package/dist/src/commands/ask.js +137 -0
  67. package/dist/src/commands/audit/index.js +322 -0
  68. package/dist/src/commands/auth-cloud.js +345 -0
  69. package/dist/src/commands/auth-list.js +112 -0
  70. package/dist/src/commands/auth-profile.js +104 -0
  71. package/dist/src/commands/auth-refresh.js +161 -0
  72. package/dist/src/commands/auth-status.js +122 -0
  73. package/dist/src/commands/aws/ec2.js +402 -0
  74. package/dist/src/commands/aws/iam.js +304 -0
  75. package/dist/src/commands/aws/index.js +108 -0
  76. package/dist/src/commands/aws/lambda.js +317 -0
  77. package/dist/src/commands/aws/rds.js +345 -0
  78. package/dist/src/commands/aws/s3.js +346 -0
  79. package/dist/src/commands/aws/vpc.js +302 -0
  80. package/dist/src/commands/aws-discover.js +413 -0
  81. package/dist/src/commands/aws-terraform.js +618 -0
  82. package/dist/src/commands/azure/aks.js +305 -0
  83. package/dist/src/commands/azure/functions.js +200 -0
  84. package/dist/src/commands/azure/index.js +93 -0
  85. package/dist/src/commands/azure/storage.js +378 -0
  86. package/dist/src/commands/azure/vm.js +291 -0
  87. package/dist/src/commands/billing/index.js +224 -0
  88. package/dist/src/commands/chat.js +259 -0
  89. package/dist/src/commands/completions.js +255 -0
  90. package/dist/src/commands/config.js +291 -0
  91. package/dist/src/commands/cost/cloud-cost-estimator.js +211 -0
  92. package/dist/src/commands/cost/estimator.js +73 -0
  93. package/dist/src/commands/cost/index.js +625 -0
  94. package/dist/src/commands/cost/parsers/terraform.js +234 -0
  95. package/dist/src/commands/cost/parsers/types.js +4 -0
  96. package/dist/src/commands/cost/pricing/aws.js +501 -0
  97. package/dist/src/commands/cost/pricing/azure.js +462 -0
  98. package/dist/src/commands/cost/pricing/gcp.js +359 -0
  99. package/dist/src/commands/cost/pricing/index.js +24 -0
  100. package/dist/src/commands/demo.js +196 -0
  101. package/dist/src/commands/deploy.js +215 -0
  102. package/dist/src/commands/doctor.js +1291 -0
  103. package/dist/src/commands/drift/index.js +674 -0
  104. package/dist/src/commands/explain.js +235 -0
  105. package/dist/src/commands/export.js +120 -0
  106. package/dist/src/commands/feedback.js +319 -0
  107. package/dist/src/commands/fix.js +263 -0
  108. package/dist/src/commands/fs/index.js +338 -0
  109. package/dist/src/commands/gcp/compute.js +266 -0
  110. package/dist/src/commands/gcp/functions.js +221 -0
  111. package/dist/src/commands/gcp/gke.js +357 -0
  112. package/dist/src/commands/gcp/iam.js +295 -0
  113. package/dist/src/commands/gcp/index.js +105 -0
  114. package/dist/src/commands/gcp/storage.js +232 -0
  115. package/dist/src/commands/generate-helm.js +1026 -0
  116. package/dist/src/commands/generate-k8s.js +1263 -0
  117. package/dist/src/commands/generate-terraform.js +1058 -0
  118. package/dist/src/commands/gh/index.js +663 -0
  119. package/dist/src/commands/git/index.js +1208 -0
  120. package/dist/src/commands/helm/index.js +985 -0
  121. package/dist/src/commands/help.js +639 -0
  122. package/dist/src/commands/history.js +120 -0
  123. package/dist/src/commands/import.js +782 -0
  124. package/dist/src/commands/incident.js +144 -0
  125. package/dist/src/commands/index.js +109 -0
  126. package/dist/src/commands/init.js +955 -0
  127. package/dist/src/commands/k8s/index.js +979 -0
  128. package/dist/src/commands/login.js +588 -0
  129. package/dist/src/commands/logout.js +61 -0
  130. package/dist/src/commands/logs.js +160 -0
  131. package/dist/src/commands/onboarding.js +382 -0
  132. package/dist/src/commands/pipeline.js +153 -0
  133. package/dist/src/commands/plan/display.js +216 -0
  134. package/dist/src/commands/plan/index.js +525 -0
  135. package/dist/src/commands/plugin.js +325 -0
  136. package/dist/src/commands/preview.js +356 -0
  137. package/dist/src/commands/profile.js +297 -0
  138. package/dist/src/commands/questionnaire.js +1021 -0
  139. package/dist/src/commands/resume.js +35 -0
  140. package/dist/src/commands/rollback.js +259 -0
  141. package/dist/src/commands/rollout.js +74 -0
  142. package/dist/src/commands/runbook.js +307 -0
  143. package/dist/src/commands/schedule.js +202 -0
  144. package/dist/src/commands/status.js +213 -0
  145. package/dist/src/commands/team/index.js +309 -0
  146. package/dist/src/commands/team-context.js +200 -0
  147. package/dist/src/commands/template.js +204 -0
  148. package/dist/src/commands/tf/index.js +989 -0
  149. package/dist/src/commands/upgrade.js +515 -0
  150. package/dist/src/commands/usage/index.js +118 -0
  151. package/dist/src/commands/version.js +145 -0
  152. package/dist/src/commands/watch.js +127 -0
  153. package/dist/src/compat/index.js +2 -0
  154. package/dist/src/compat/runtime.js +10 -0
  155. package/dist/src/compat/sqlite.js +144 -0
  156. package/dist/src/config/index.js +6 -0
  157. package/dist/src/config/manager.js +469 -0
  158. package/dist/src/config/mode-store.js +57 -0
  159. package/dist/src/config/profiles.js +66 -0
  160. package/dist/src/config/safety-policy.js +251 -0
  161. package/dist/src/config/schema.js +107 -0
  162. package/dist/src/config/types.js +311 -0
  163. package/dist/src/config/workspace-state.js +38 -0
  164. package/dist/src/context/context-db.js +138 -0
  165. package/dist/src/demo/index.js +295 -0
  166. package/dist/src/demo/scenarios/full-journey.js +226 -0
  167. package/dist/src/demo/scenarios/getting-started.js +124 -0
  168. package/dist/src/demo/scenarios/helm-release.js +334 -0
  169. package/dist/src/demo/scenarios/k8s-deployment.js +190 -0
  170. package/dist/src/demo/scenarios/terraform-vpc.js +167 -0
  171. package/dist/src/demo/types.js +6 -0
  172. package/dist/src/engine/cost-estimator.js +334 -0
  173. package/dist/src/engine/diagram-generator.js +192 -0
  174. package/dist/src/engine/drift-detector.js +688 -0
  175. package/dist/src/engine/executor.js +832 -0
  176. package/dist/src/engine/index.js +39 -0
  177. package/dist/src/engine/orchestrator.js +436 -0
  178. package/dist/src/engine/planner.js +616 -0
  179. package/dist/src/engine/safety.js +609 -0
  180. package/dist/src/engine/verifier.js +664 -0
  181. package/dist/src/enterprise/audit.js +241 -0
  182. package/dist/src/enterprise/auth.js +189 -0
  183. package/dist/src/enterprise/billing.js +512 -0
  184. package/dist/src/enterprise/index.js +16 -0
  185. package/dist/src/enterprise/teams.js +315 -0
  186. package/dist/src/generator/best-practices.js +1375 -0
  187. package/dist/src/generator/helm.js +495 -0
  188. package/dist/src/generator/index.js +11 -0
  189. package/dist/src/generator/intent-parser.js +420 -0
  190. package/dist/src/generator/kubernetes.js +773 -0
  191. package/dist/src/generator/terraform.js +1472 -0
  192. package/dist/src/history/index.js +6 -0
  193. package/dist/src/history/manager.js +199 -0
  194. package/dist/src/history/types.js +6 -0
  195. package/dist/src/hooks/config.js +318 -0
  196. package/dist/src/hooks/engine.js +317 -0
  197. package/dist/src/hooks/index.js +2 -0
  198. package/dist/src/llm/auth-bridge.js +157 -0
  199. package/dist/src/llm/circuit-breaker.js +116 -0
  200. package/dist/src/llm/config-loader.js +172 -0
  201. package/dist/src/llm/cost-calculator.js +137 -0
  202. package/dist/src/llm/index.js +7 -0
  203. package/dist/src/llm/model-aliases.js +99 -0
  204. package/dist/src/llm/provider-registry.js +57 -0
  205. package/dist/src/llm/providers/anthropic.js +430 -0
  206. package/dist/src/llm/providers/bedrock.js +409 -0
  207. package/dist/src/llm/providers/google.js +344 -0
  208. package/dist/src/llm/providers/ollama.js +661 -0
  209. package/dist/src/llm/providers/openai-compatible.js +289 -0
  210. package/dist/src/llm/providers/openai.js +284 -0
  211. package/dist/src/llm/providers/openrouter.js +293 -0
  212. package/dist/src/llm/router.js +844 -0
  213. package/dist/src/llm/types.js +69 -0
  214. package/dist/src/lsp/client.js +239 -0
  215. package/dist/src/lsp/languages.js +95 -0
  216. package/dist/src/lsp/manager.js +243 -0
  217. package/dist/src/mcp/client.js +289 -0
  218. package/dist/src/mcp/index.js +5 -0
  219. package/dist/src/mcp/manager.js +113 -0
  220. package/dist/src/nimbus.js +212 -0
  221. package/dist/src/plugins/index.js +13 -0
  222. package/dist/src/plugins/loader.js +280 -0
  223. package/dist/src/plugins/manager.js +282 -0
  224. package/dist/src/plugins/types.js +23 -0
  225. package/dist/src/scanners/cicd-scanner.js +230 -0
  226. package/dist/src/scanners/cloud-scanner.js +415 -0
  227. package/dist/src/scanners/framework-scanner.js +430 -0
  228. package/dist/src/scanners/iac-scanner.js +350 -0
  229. package/dist/src/scanners/index.js +454 -0
  230. package/dist/src/scanners/language-scanner.js +258 -0
  231. package/dist/src/scanners/package-manager-scanner.js +252 -0
  232. package/dist/src/scanners/types.js +6 -0
  233. package/dist/src/sessions/manager.js +395 -0
  234. package/dist/src/sessions/types.js +4 -0
  235. package/dist/src/sharing/sync.js +238 -0
  236. package/dist/src/sharing/viewer.js +131 -0
  237. package/dist/src/snapshots/index.js +1 -0
  238. package/dist/src/snapshots/manager.js +432 -0
  239. package/dist/src/state/artifacts.js +94 -0
  240. package/dist/src/state/audit.js +73 -0
  241. package/dist/src/state/billing.js +126 -0
  242. package/dist/src/state/checkpoints.js +81 -0
  243. package/dist/src/state/config.js +58 -0
  244. package/dist/src/state/conversations.js +7 -0
  245. package/dist/src/state/credentials.js +96 -0
  246. package/dist/src/state/db.js +53 -0
  247. package/dist/src/state/index.js +23 -0
  248. package/dist/src/state/messages.js +76 -0
  249. package/dist/src/state/projects.js +92 -0
  250. package/dist/src/state/schema.js +233 -0
  251. package/dist/src/state/sessions.js +79 -0
  252. package/dist/src/state/teams.js +131 -0
  253. package/dist/src/telemetry.js +91 -0
  254. package/dist/src/tools/aws-ops.js +747 -0
  255. package/dist/src/tools/azure-ops.js +491 -0
  256. package/dist/src/tools/file-ops.js +451 -0
  257. package/dist/src/tools/gcp-ops.js +559 -0
  258. package/dist/src/tools/git-ops.js +557 -0
  259. package/dist/src/tools/github-ops.js +460 -0
  260. package/dist/src/tools/helm-ops.js +634 -0
  261. package/dist/src/tools/index.js +16 -0
  262. package/dist/src/tools/k8s-ops.js +579 -0
  263. package/dist/src/tools/schemas/converter.js +129 -0
  264. package/dist/src/tools/schemas/devops.js +3319 -0
  265. package/dist/src/tools/schemas/index.js +19 -0
  266. package/dist/src/tools/schemas/standard.js +966 -0
  267. package/dist/src/tools/schemas/types.js +409 -0
  268. package/dist/src/tools/spawn-exec.js +109 -0
  269. package/dist/src/tools/terraform-ops.js +627 -0
  270. package/dist/src/types/config.js +1 -0
  271. package/dist/src/types/drift.js +4 -0
  272. package/dist/src/types/enterprise.js +5 -0
  273. package/dist/src/types/index.js +14 -0
  274. package/dist/src/types/plan.js +1 -0
  275. package/dist/src/types/request.js +1 -0
  276. package/dist/src/types/response.js +1 -0
  277. package/dist/src/types/service.js +1 -0
  278. package/dist/src/ui/App.js +1672 -0
  279. package/dist/src/ui/DeployPreview.js +60 -0
  280. package/dist/src/ui/FileDiffModal.js +108 -0
  281. package/dist/src/ui/Header.js +46 -0
  282. package/dist/src/ui/HelpModal.js +9 -0
  283. package/dist/src/ui/InputBox.js +408 -0
  284. package/dist/src/ui/MessageList.js +795 -0
  285. package/dist/src/ui/PermissionPrompt.js +72 -0
  286. package/dist/src/ui/StatusBar.js +109 -0
  287. package/dist/src/ui/TerminalPane.js +31 -0
  288. package/dist/src/ui/ToolCallDisplay.js +303 -0
  289. package/dist/src/ui/TreePane.js +83 -0
  290. package/dist/src/ui/chat-ui.js +721 -0
  291. package/dist/src/ui/index.js +11 -0
  292. package/dist/src/ui/ink/index.js +1325 -0
  293. package/dist/src/ui/streaming.js +137 -0
  294. package/dist/src/ui/theme.js +78 -0
  295. package/dist/src/ui/types.js +7 -0
  296. package/dist/src/utils/analytics.js +61 -0
  297. package/dist/src/utils/cost-warning.js +25 -0
  298. package/dist/src/utils/env.js +42 -0
  299. package/dist/src/utils/errors.js +54 -0
  300. package/dist/src/utils/event-bus.js +22 -0
  301. package/dist/src/utils/index.js +16 -0
  302. package/dist/src/utils/logger.js +150 -0
  303. package/dist/src/utils/rate-limiter.js +90 -0
  304. package/dist/src/utils/service-auth.js +36 -0
  305. package/dist/src/utils/validation.js +39 -0
  306. package/dist/src/version.js +3 -0
  307. package/dist/src/watcher/index.js +192 -0
  308. package/dist/src/wizard/approval.js +275 -0
  309. package/dist/src/wizard/index.js +13 -0
  310. package/dist/src/wizard/prompts.js +273 -0
  311. package/dist/src/wizard/types.js +4 -0
  312. package/dist/src/wizard/ui.js +453 -0
  313. package/dist/src/wizard/wizard.js +227 -0
  314. package/package.json +31 -23
  315. package/src/__tests__/alias.test.ts +133 -0
  316. package/src/__tests__/app.test.ts +1 -1
  317. package/src/__tests__/audit.test.ts +1 -1
  318. package/src/__tests__/circuit-breaker.test.ts +1 -1
  319. package/src/__tests__/cli-run.test.ts +237 -1
  320. package/src/__tests__/compat-sqlite.test.ts +68 -0
  321. package/src/__tests__/context-manager.test.ts +131 -1
  322. package/src/__tests__/context.test.ts +1 -1
  323. package/src/__tests__/devops-terminal-gaps.test.ts +718 -0
  324. package/src/__tests__/doctor.test.ts +48 -0
  325. package/src/__tests__/enterprise.test.ts +1 -1
  326. package/src/__tests__/export.test.ts +236 -0
  327. package/src/__tests__/gap-11-18-20.test.ts +958 -0
  328. package/src/__tests__/generator.test.ts +1 -1
  329. package/src/__tests__/helm-streaming.test.ts +127 -0
  330. package/src/__tests__/hooks.test.ts +1 -1
  331. package/src/__tests__/incident.test.ts +179 -0
  332. package/src/__tests__/init.test.ts +55 -4
  333. package/src/__tests__/intent-parser.test.ts +1 -1
  334. package/src/__tests__/llm-router.test.ts +1 -1
  335. package/src/__tests__/logs.test.ts +107 -0
  336. package/src/__tests__/loop-errors.test.ts +244 -0
  337. package/src/__tests__/lsp.test.ts +1 -1
  338. package/src/__tests__/modes.test.ts +1 -1
  339. package/src/__tests__/perf-optimizations.test.ts +847 -0
  340. package/src/__tests__/permissions.test.ts +1 -1
  341. package/src/__tests__/pipeline.test.ts +50 -0
  342. package/src/__tests__/polish-phase3.test.ts +340 -0
  343. package/src/__tests__/profile.test.ts +237 -0
  344. package/src/__tests__/rollback.test.ts +83 -0
  345. package/src/__tests__/runbook.test.ts +219 -0
  346. package/src/__tests__/schedule.test.ts +206 -0
  347. package/src/__tests__/serve.test.ts +1 -1
  348. package/src/__tests__/sessions.test.ts +96 -1
  349. package/src/__tests__/sharing.test.ts +53 -1
  350. package/src/__tests__/snapshots.test.ts +1 -1
  351. package/src/__tests__/standalone-migration.test.ts +199 -0
  352. package/src/__tests__/state-db.test.ts +1 -1
  353. package/src/__tests__/status.test.ts +158 -0
  354. package/src/__tests__/stream-with-tools.test.ts +71 -25
  355. package/src/__tests__/subagents.test.ts +1 -1
  356. package/src/__tests__/system-prompt.test.ts +82 -3
  357. package/src/__tests__/terminal-gap-v2.test.ts +395 -0
  358. package/src/__tests__/terminal-parity.test.ts +393 -0
  359. package/src/__tests__/tf-apply.test.ts +187 -0
  360. package/src/__tests__/tool-converter.test.ts +1 -1
  361. package/src/__tests__/tool-schemas.test.ts +209 -4
  362. package/src/__tests__/tools.test.ts +4 -3
  363. package/src/__tests__/version-json.test.ts +184 -0
  364. package/src/__tests__/version.test.ts +1 -1
  365. package/src/__tests__/watch.test.ts +129 -0
  366. package/src/agent/compaction-agent.ts +40 -1
  367. package/src/agent/context-manager.ts +67 -3
  368. package/src/agent/deploy-preview.ts +62 -1
  369. package/src/agent/expand-files.ts +108 -0
  370. package/src/agent/loop.ts +1312 -31
  371. package/src/agent/permissions.ts +51 -4
  372. package/src/agent/system-prompt.ts +573 -19
  373. package/src/app.ts +58 -0
  374. package/src/audit/security-scanner.ts +45 -0
  375. package/src/auth/keychain.ts +82 -0
  376. package/src/auth/oauth.ts +15 -5
  377. package/src/cli/init.ts +378 -5
  378. package/src/cli/run.ts +407 -16
  379. package/src/cli/serve.ts +78 -1
  380. package/src/cli/web.ts +10 -6
  381. package/src/cli.ts +312 -1
  382. package/src/clients/service-discovery.ts +30 -25
  383. package/src/commands/alias.ts +100 -0
  384. package/src/commands/audit/index.ts +121 -2
  385. package/src/commands/auth-cloud.ts +113 -0
  386. package/src/commands/auth-refresh.ts +187 -0
  387. package/src/commands/aws-discover.ts +144 -251
  388. package/src/commands/aws-terraform.ts +68 -118
  389. package/src/commands/chat.ts +9 -3
  390. package/src/commands/completions.ts +268 -0
  391. package/src/commands/config.ts +26 -0
  392. package/src/commands/cost/index.ts +218 -2
  393. package/src/commands/deploy.ts +260 -0
  394. package/src/commands/doctor.ts +744 -152
  395. package/src/commands/drift/index.ts +371 -23
  396. package/src/commands/export.ts +146 -0
  397. package/src/commands/generate-k8s.ts +9 -61
  398. package/src/commands/generate-terraform.ts +191 -449
  399. package/src/commands/help.ts +212 -36
  400. package/src/commands/history.ts +8 -1
  401. package/src/commands/incident.ts +166 -0
  402. package/src/commands/init.ts +5 -0
  403. package/src/commands/login.ts +86 -1
  404. package/src/commands/logs.ts +167 -0
  405. package/src/commands/onboarding.ts +211 -34
  406. package/src/commands/pipeline.ts +186 -0
  407. package/src/commands/plugin.ts +398 -0
  408. package/src/commands/profile.ts +342 -0
  409. package/src/commands/questionnaire.ts +0 -98
  410. package/src/commands/resume.ts +26 -34
  411. package/src/commands/rollback.ts +315 -0
  412. package/src/commands/rollout.ts +88 -0
  413. package/src/commands/runbook.ts +346 -0
  414. package/src/commands/schedule.ts +236 -0
  415. package/src/commands/status.ts +252 -0
  416. package/src/commands/team-context.ts +220 -0
  417. package/src/commands/template.ts +58 -57
  418. package/src/commands/tf/index.ts +70 -11
  419. package/src/commands/upgrade.ts +57 -0
  420. package/src/commands/version.ts +54 -50
  421. package/src/commands/watch.ts +153 -0
  422. package/src/compat/runtime.ts +1 -1
  423. package/src/compat/sqlite.ts +75 -5
  424. package/src/config/mode-store.ts +62 -0
  425. package/src/config/profiles.ts +84 -0
  426. package/src/config/types.ts +83 -1
  427. package/src/config/workspace-state.ts +53 -0
  428. package/src/engine/cost-estimator.ts +52 -10
  429. package/src/engine/executor.ts +33 -2
  430. package/src/engine/planner.ts +68 -1
  431. package/src/generator/terraform.ts +8 -0
  432. package/src/history/manager.ts +2 -74
  433. package/src/hooks/engine.ts +5 -4
  434. package/src/llm/cost-calculator.ts +2 -2
  435. package/src/llm/providers/anthropic.ts +50 -21
  436. package/src/llm/router.ts +76 -7
  437. package/src/lsp/languages.ts +3 -0
  438. package/src/lsp/manager.ts +21 -5
  439. package/src/nimbus.ts +37 -18
  440. package/src/sessions/manager.ts +108 -1
  441. package/src/sharing/sync.ts +4 -0
  442. package/src/sharing/viewer.ts +66 -0
  443. package/src/tools/file-ops.ts +22 -0
  444. package/src/tools/schemas/devops.ts +3007 -117
  445. package/src/tools/schemas/standard.ts +5 -1
  446. package/src/tools/schemas/types.ts +31 -1
  447. package/src/tools/spawn-exec.ts +148 -0
  448. package/src/ui/App.tsx +1183 -66
  449. package/src/ui/DeployPreview.tsx +62 -57
  450. package/src/ui/FileDiffModal.tsx +162 -0
  451. package/src/ui/Header.tsx +87 -24
  452. package/src/ui/HelpModal.tsx +57 -0
  453. package/src/ui/InputBox.tsx +163 -10
  454. package/src/ui/MessageList.tsx +487 -40
  455. package/src/ui/PermissionPrompt.tsx +17 -5
  456. package/src/ui/StatusBar.tsx +122 -3
  457. package/src/ui/TerminalPane.tsx +84 -0
  458. package/src/ui/ToolCallDisplay.tsx +252 -18
  459. package/src/ui/TreePane.tsx +132 -0
  460. package/src/ui/chat-ui.ts +41 -44
  461. package/src/ui/ink/index.ts +771 -38
  462. package/src/ui/streaming.ts +1 -1
  463. package/src/ui/theme.ts +104 -0
  464. package/src/ui/types.ts +18 -0
  465. package/src/version.ts +1 -1
  466. package/src/watcher/index.ts +66 -15
  467. package/src/wizard/types.ts +1 -0
  468. package/src/wizard/ui.ts +1 -1
  469. package/tsconfig.json +2 -2
@@ -0,0 +1,773 @@
1
+ /**
2
+ * Kubernetes Manifest Generator
3
+ *
4
+ * Generates Kubernetes manifests from configuration
5
+ */
6
+ import * as yaml from 'js-yaml';
7
+ import * as path from 'node:path';
8
+ import * as fs from 'node:fs';
9
+ // ==========================================
10
+ // Generator Class
11
+ // ==========================================
12
+ export class KubernetesGenerator {
13
+ config;
14
+ constructor(config) {
15
+ this.config = {
16
+ namespace: 'default',
17
+ imageTag: 'latest',
18
+ replicas: 1,
19
+ containerPort: 8080,
20
+ serviceType: 'ClusterIP',
21
+ ...config,
22
+ };
23
+ }
24
+ /**
25
+ * Generate all manifests based on configuration
26
+ */
27
+ generate() {
28
+ const manifests = [];
29
+ // Namespace (if not default)
30
+ if (this.config.namespace && this.config.namespace !== 'default') {
31
+ manifests.push(this.generateNamespace());
32
+ }
33
+ // ServiceAccount
34
+ if (this.config.serviceAccount?.create) {
35
+ manifests.push(this.generateServiceAccount());
36
+ }
37
+ // ConfigMap
38
+ if (this.config.configMap) {
39
+ manifests.push(this.generateConfigMap());
40
+ }
41
+ // Secret
42
+ if (this.config.secret) {
43
+ manifests.push(this.generateSecret());
44
+ }
45
+ // Workload (Deployment, StatefulSet, etc.)
46
+ manifests.push(this.generateWorkload());
47
+ // Service
48
+ if (this.config.serviceType !== 'None') {
49
+ manifests.push(this.generateService());
50
+ }
51
+ // Ingress
52
+ if (this.config.ingressEnabled) {
53
+ manifests.push(this.generateIngress());
54
+ }
55
+ // HPA
56
+ if (this.config.hpa?.enabled) {
57
+ manifests.push(this.generateHPA());
58
+ }
59
+ // PDB
60
+ if (this.config.pdb?.enabled) {
61
+ manifests.push(this.generatePDB());
62
+ }
63
+ // RBAC
64
+ if (this.config.rbac?.enabled) {
65
+ manifests.push(this.generateRole());
66
+ manifests.push(this.generateRoleBinding());
67
+ if (this.config.rbac?.clusterWide) {
68
+ manifests.push(this.generateClusterRole());
69
+ manifests.push(this.generateClusterRoleBinding());
70
+ }
71
+ }
72
+ // NetworkPolicy
73
+ if (this.config.networkPolicy?.enabled) {
74
+ manifests.push(this.generateNetworkPolicy());
75
+ }
76
+ // PersistentVolumeClaim
77
+ if (this.config.persistence?.enabled) {
78
+ manifests.push(this.generatePersistentVolumeClaim());
79
+ }
80
+ return manifests;
81
+ }
82
+ /**
83
+ * Generate combined YAML file
84
+ */
85
+ generateCombined() {
86
+ const manifests = this.generate();
87
+ return manifests.map(m => m.content).join('\n---\n');
88
+ }
89
+ /**
90
+ * Write manifests to files
91
+ */
92
+ writeToFiles(outputDir) {
93
+ const manifests = this.generate();
94
+ const files = [];
95
+ if (!fs.existsSync(outputDir)) {
96
+ fs.mkdirSync(outputDir, { recursive: true });
97
+ }
98
+ for (const manifest of manifests) {
99
+ const filename = `${manifest.name}.yaml`;
100
+ const filepath = path.join(outputDir, filename);
101
+ fs.writeFileSync(filepath, manifest.content);
102
+ files.push(filepath);
103
+ }
104
+ // Write kustomization.yaml
105
+ const kustomization = this.generateKustomization(manifests);
106
+ const kustomizationPath = path.join(outputDir, 'kustomization.yaml');
107
+ fs.writeFileSync(kustomizationPath, kustomization);
108
+ files.push(kustomizationPath);
109
+ return files;
110
+ }
111
+ // ==========================================
112
+ // Private Generator Methods
113
+ // ==========================================
114
+ getLabels() {
115
+ return {
116
+ 'app.kubernetes.io/name': this.config.appName,
117
+ 'app.kubernetes.io/instance': this.config.appName,
118
+ 'app.kubernetes.io/managed-by': 'nimbus',
119
+ ...this.config.labels,
120
+ };
121
+ }
122
+ getSelectorLabels() {
123
+ return {
124
+ 'app.kubernetes.io/name': this.config.appName,
125
+ 'app.kubernetes.io/instance': this.config.appName,
126
+ };
127
+ }
128
+ generateNamespace() {
129
+ const manifest = {
130
+ apiVersion: 'v1',
131
+ kind: 'Namespace',
132
+ metadata: {
133
+ name: this.config.namespace,
134
+ labels: this.getLabels(),
135
+ },
136
+ };
137
+ return {
138
+ name: 'namespace',
139
+ kind: 'Namespace',
140
+ content: yaml.dump(manifest),
141
+ };
142
+ }
143
+ generateServiceAccount() {
144
+ const manifest = {
145
+ apiVersion: 'v1',
146
+ kind: 'ServiceAccount',
147
+ metadata: {
148
+ name: this.config.serviceAccount?.name || this.config.appName,
149
+ namespace: this.config.namespace,
150
+ labels: this.getLabels(),
151
+ ...(this.config.serviceAccount?.annotations && {
152
+ annotations: this.config.serviceAccount.annotations,
153
+ }),
154
+ },
155
+ };
156
+ return {
157
+ name: 'serviceaccount',
158
+ kind: 'ServiceAccount',
159
+ content: yaml.dump(manifest),
160
+ };
161
+ }
162
+ generateConfigMap() {
163
+ const manifest = {
164
+ apiVersion: 'v1',
165
+ kind: 'ConfigMap',
166
+ metadata: {
167
+ name: `${this.config.appName}-config`,
168
+ namespace: this.config.namespace,
169
+ labels: this.getLabels(),
170
+ },
171
+ data: this.config.configMap?.data || {},
172
+ };
173
+ return {
174
+ name: 'configmap',
175
+ kind: 'ConfigMap',
176
+ content: yaml.dump(manifest),
177
+ };
178
+ }
179
+ generateSecret() {
180
+ const data = {};
181
+ for (const [key, value] of Object.entries(this.config.secret?.data || {})) {
182
+ data[key] = Buffer.from(value).toString('base64');
183
+ }
184
+ const manifest = {
185
+ apiVersion: 'v1',
186
+ kind: 'Secret',
187
+ metadata: {
188
+ name: `${this.config.appName}-secret`,
189
+ namespace: this.config.namespace,
190
+ labels: this.getLabels(),
191
+ },
192
+ type: this.config.secret?.type || 'Opaque',
193
+ data,
194
+ };
195
+ return {
196
+ name: 'secret',
197
+ kind: 'Secret',
198
+ content: yaml.dump(manifest),
199
+ };
200
+ }
201
+ generateWorkload() {
202
+ const container = this.buildContainer();
203
+ const volumes = this.buildVolumes();
204
+ let manifest;
205
+ switch (this.config.workloadType) {
206
+ case 'deployment':
207
+ manifest = this.buildDeployment(container, volumes);
208
+ break;
209
+ case 'statefulset':
210
+ manifest = this.buildStatefulSet(container, volumes);
211
+ break;
212
+ case 'daemonset':
213
+ manifest = this.buildDaemonSet(container, volumes);
214
+ break;
215
+ case 'job':
216
+ manifest = this.buildJob(container, volumes);
217
+ break;
218
+ case 'cronjob':
219
+ manifest = this.buildCronJob(container, volumes);
220
+ break;
221
+ default:
222
+ manifest = this.buildDeployment(container, volumes);
223
+ }
224
+ return {
225
+ name: this.config.workloadType,
226
+ kind: manifest.kind,
227
+ content: yaml.dump(manifest),
228
+ };
229
+ }
230
+ buildContainer() {
231
+ const container = {
232
+ name: this.config.appName,
233
+ image: `${this.config.image}:${this.config.imageTag}`,
234
+ ports: [
235
+ {
236
+ name: 'http',
237
+ containerPort: this.config.containerPort,
238
+ protocol: 'TCP',
239
+ },
240
+ ],
241
+ };
242
+ // Resources
243
+ if (this.config.resources) {
244
+ container.resources = this.config.resources;
245
+ }
246
+ // Environment variables
247
+ if (this.config.env && this.config.env.length > 0) {
248
+ container.env = this.config.env;
249
+ }
250
+ // Environment from ConfigMaps/Secrets
251
+ if (this.config.envFrom && this.config.envFrom.length > 0) {
252
+ container.envFrom = this.config.envFrom.map(ef => {
253
+ if (ef.configMapRef) {
254
+ return { configMapRef: { name: ef.configMapRef } };
255
+ }
256
+ if (ef.secretRef) {
257
+ return { secretRef: { name: ef.secretRef } };
258
+ }
259
+ return {};
260
+ });
261
+ }
262
+ // Volume mounts
263
+ if (this.config.volumes && this.config.volumes.length > 0) {
264
+ container.volumeMounts = this.config.volumes.map(v => ({
265
+ name: v.name,
266
+ mountPath: v.mountPath,
267
+ ...(v.subPath && { subPath: v.subPath }),
268
+ }));
269
+ }
270
+ // Health checks
271
+ if (this.config.healthChecks) {
272
+ if (this.config.healthChecks.livenessProbe) {
273
+ container.livenessProbe = this.config.healthChecks.livenessProbe;
274
+ }
275
+ if (this.config.healthChecks.readinessProbe) {
276
+ container.readinessProbe = this.config.healthChecks.readinessProbe;
277
+ }
278
+ if (this.config.healthChecks.startupProbe) {
279
+ container.startupProbe = this.config.healthChecks.startupProbe;
280
+ }
281
+ }
282
+ return container;
283
+ }
284
+ buildVolumes() {
285
+ if (!this.config.volumes || this.config.volumes.length === 0) {
286
+ return [];
287
+ }
288
+ return this.config.volumes.map(v => {
289
+ const volume = { name: v.name };
290
+ switch (v.type) {
291
+ case 'emptyDir':
292
+ volume.emptyDir = {};
293
+ break;
294
+ case 'configMap':
295
+ volume.configMap = { name: v.configMapName };
296
+ break;
297
+ case 'secret':
298
+ volume.secret = { secretName: v.secretName };
299
+ break;
300
+ case 'persistentVolumeClaim':
301
+ volume.persistentVolumeClaim = { claimName: v.pvcName };
302
+ break;
303
+ case 'hostPath':
304
+ volume.hostPath = { path: v.hostPath };
305
+ break;
306
+ }
307
+ return volume;
308
+ });
309
+ }
310
+ buildPodSpec(container, volumes) {
311
+ const spec = {
312
+ containers: [container],
313
+ };
314
+ if (this.config.serviceAccount?.create || this.config.serviceAccount?.name) {
315
+ spec.serviceAccountName = this.config.serviceAccount?.name || this.config.appName;
316
+ }
317
+ if (volumes.length > 0) {
318
+ spec.volumes = volumes;
319
+ }
320
+ if (this.config.nodeSelector) {
321
+ spec.nodeSelector = this.config.nodeSelector;
322
+ }
323
+ if (this.config.tolerations && this.config.tolerations.length > 0) {
324
+ spec.tolerations = this.config.tolerations;
325
+ }
326
+ if (this.config.affinity) {
327
+ spec.affinity = this.config.affinity;
328
+ }
329
+ return spec;
330
+ }
331
+ buildDeployment(container, volumes) {
332
+ return {
333
+ apiVersion: 'apps/v1',
334
+ kind: 'Deployment',
335
+ metadata: {
336
+ name: this.config.appName,
337
+ namespace: this.config.namespace,
338
+ labels: this.getLabels(),
339
+ ...(this.config.annotations && { annotations: this.config.annotations }),
340
+ },
341
+ spec: {
342
+ replicas: this.config.replicas,
343
+ selector: {
344
+ matchLabels: this.getSelectorLabels(),
345
+ },
346
+ template: {
347
+ metadata: {
348
+ labels: this.getLabels(),
349
+ },
350
+ spec: this.buildPodSpec(container, volumes),
351
+ },
352
+ },
353
+ };
354
+ }
355
+ buildStatefulSet(container, volumes) {
356
+ return {
357
+ apiVersion: 'apps/v1',
358
+ kind: 'StatefulSet',
359
+ metadata: {
360
+ name: this.config.appName,
361
+ namespace: this.config.namespace,
362
+ labels: this.getLabels(),
363
+ },
364
+ spec: {
365
+ serviceName: this.config.appName,
366
+ replicas: this.config.replicas,
367
+ selector: {
368
+ matchLabels: this.getSelectorLabels(),
369
+ },
370
+ template: {
371
+ metadata: {
372
+ labels: this.getLabels(),
373
+ },
374
+ spec: this.buildPodSpec(container, volumes),
375
+ },
376
+ },
377
+ };
378
+ }
379
+ buildDaemonSet(container, volumes) {
380
+ return {
381
+ apiVersion: 'apps/v1',
382
+ kind: 'DaemonSet',
383
+ metadata: {
384
+ name: this.config.appName,
385
+ namespace: this.config.namespace,
386
+ labels: this.getLabels(),
387
+ },
388
+ spec: {
389
+ selector: {
390
+ matchLabels: this.getSelectorLabels(),
391
+ },
392
+ template: {
393
+ metadata: {
394
+ labels: this.getLabels(),
395
+ },
396
+ spec: this.buildPodSpec(container, volumes),
397
+ },
398
+ },
399
+ };
400
+ }
401
+ buildJob(container, volumes) {
402
+ return {
403
+ apiVersion: 'batch/v1',
404
+ kind: 'Job',
405
+ metadata: {
406
+ name: this.config.appName,
407
+ namespace: this.config.namespace,
408
+ labels: this.getLabels(),
409
+ },
410
+ spec: {
411
+ template: {
412
+ metadata: {
413
+ labels: this.getLabels(),
414
+ },
415
+ spec: {
416
+ ...this.buildPodSpec(container, volumes),
417
+ restartPolicy: 'OnFailure',
418
+ },
419
+ },
420
+ },
421
+ };
422
+ }
423
+ buildCronJob(container, volumes) {
424
+ return {
425
+ apiVersion: 'batch/v1',
426
+ kind: 'CronJob',
427
+ metadata: {
428
+ name: this.config.appName,
429
+ namespace: this.config.namespace,
430
+ labels: this.getLabels(),
431
+ },
432
+ spec: {
433
+ schedule: '0 * * * *', // Default: every hour
434
+ jobTemplate: {
435
+ spec: {
436
+ template: {
437
+ metadata: {
438
+ labels: this.getLabels(),
439
+ },
440
+ spec: {
441
+ ...this.buildPodSpec(container, volumes),
442
+ restartPolicy: 'OnFailure',
443
+ },
444
+ },
445
+ },
446
+ },
447
+ },
448
+ };
449
+ }
450
+ generateService() {
451
+ const manifest = {
452
+ apiVersion: 'v1',
453
+ kind: 'Service',
454
+ metadata: {
455
+ name: this.config.appName,
456
+ namespace: this.config.namespace,
457
+ labels: this.getLabels(),
458
+ },
459
+ spec: {
460
+ type: this.config.serviceType,
461
+ ports: [
462
+ {
463
+ port: this.config.containerPort,
464
+ targetPort: 'http',
465
+ protocol: 'TCP',
466
+ name: 'http',
467
+ },
468
+ ],
469
+ selector: this.getSelectorLabels(),
470
+ },
471
+ };
472
+ return {
473
+ name: 'service',
474
+ kind: 'Service',
475
+ content: yaml.dump(manifest),
476
+ };
477
+ }
478
+ generateIngress() {
479
+ const manifest = {
480
+ apiVersion: 'networking.k8s.io/v1',
481
+ kind: 'Ingress',
482
+ metadata: {
483
+ name: this.config.appName,
484
+ namespace: this.config.namespace,
485
+ labels: this.getLabels(),
486
+ annotations: {
487
+ 'kubernetes.io/ingress.class': 'nginx',
488
+ },
489
+ },
490
+ spec: {
491
+ rules: [
492
+ {
493
+ host: this.config.ingressHost || `${this.config.appName}.example.com`,
494
+ http: {
495
+ paths: [
496
+ {
497
+ path: '/',
498
+ pathType: 'Prefix',
499
+ backend: {
500
+ service: {
501
+ name: this.config.appName,
502
+ port: {
503
+ number: this.config.containerPort,
504
+ },
505
+ },
506
+ },
507
+ },
508
+ ],
509
+ },
510
+ },
511
+ ],
512
+ },
513
+ };
514
+ return {
515
+ name: 'ingress',
516
+ kind: 'Ingress',
517
+ content: yaml.dump(manifest),
518
+ };
519
+ }
520
+ generateHPA() {
521
+ const manifest = {
522
+ apiVersion: 'autoscaling/v2',
523
+ kind: 'HorizontalPodAutoscaler',
524
+ metadata: {
525
+ name: this.config.appName,
526
+ namespace: this.config.namespace,
527
+ labels: this.getLabels(),
528
+ },
529
+ spec: {
530
+ scaleTargetRef: {
531
+ apiVersion: 'apps/v1',
532
+ kind: 'Deployment',
533
+ name: this.config.appName,
534
+ },
535
+ minReplicas: this.config.hpa?.minReplicas || 1,
536
+ maxReplicas: this.config.hpa?.maxReplicas || 10,
537
+ metrics: [
538
+ {
539
+ type: 'Resource',
540
+ resource: {
541
+ name: 'cpu',
542
+ target: {
543
+ type: 'Utilization',
544
+ averageUtilization: this.config.hpa?.targetCPUUtilization || 80,
545
+ },
546
+ },
547
+ },
548
+ ],
549
+ },
550
+ };
551
+ return {
552
+ name: 'hpa',
553
+ kind: 'HorizontalPodAutoscaler',
554
+ content: yaml.dump(manifest),
555
+ };
556
+ }
557
+ generatePDB() {
558
+ const manifest = {
559
+ apiVersion: 'policy/v1',
560
+ kind: 'PodDisruptionBudget',
561
+ metadata: {
562
+ name: this.config.appName,
563
+ namespace: this.config.namespace,
564
+ labels: this.getLabels(),
565
+ },
566
+ spec: {
567
+ minAvailable: this.config.pdb?.minAvailable || 1,
568
+ selector: {
569
+ matchLabels: this.getSelectorLabels(),
570
+ },
571
+ },
572
+ };
573
+ return {
574
+ name: 'pdb',
575
+ kind: 'PodDisruptionBudget',
576
+ content: yaml.dump(manifest),
577
+ };
578
+ }
579
+ generateRole() {
580
+ const rules = this.config.rbac?.rules || [
581
+ {
582
+ apiGroups: [''],
583
+ resources: ['pods', 'services', 'configmaps'],
584
+ verbs: ['get', 'list', 'watch'],
585
+ },
586
+ ];
587
+ const manifest = {
588
+ apiVersion: 'rbac.authorization.k8s.io/v1',
589
+ kind: 'Role',
590
+ metadata: {
591
+ name: `${this.config.appName}-role`,
592
+ namespace: this.config.namespace,
593
+ labels: this.getLabels(),
594
+ },
595
+ rules,
596
+ };
597
+ return {
598
+ name: 'role',
599
+ kind: 'Role',
600
+ content: yaml.dump(manifest),
601
+ };
602
+ }
603
+ generateRoleBinding() {
604
+ const manifest = {
605
+ apiVersion: 'rbac.authorization.k8s.io/v1',
606
+ kind: 'RoleBinding',
607
+ metadata: {
608
+ name: `${this.config.appName}-rolebinding`,
609
+ namespace: this.config.namespace,
610
+ labels: this.getLabels(),
611
+ },
612
+ subjects: [
613
+ {
614
+ kind: 'ServiceAccount',
615
+ name: this.config.serviceAccount?.name || this.config.appName,
616
+ namespace: this.config.namespace,
617
+ },
618
+ ],
619
+ roleRef: {
620
+ kind: 'Role',
621
+ name: `${this.config.appName}-role`,
622
+ apiGroup: 'rbac.authorization.k8s.io',
623
+ },
624
+ };
625
+ return {
626
+ name: 'rolebinding',
627
+ kind: 'RoleBinding',
628
+ content: yaml.dump(manifest),
629
+ };
630
+ }
631
+ generateClusterRole() {
632
+ const rules = this.config.rbac?.rules || [
633
+ {
634
+ apiGroups: [''],
635
+ resources: ['pods', 'services', 'configmaps'],
636
+ verbs: ['get', 'list', 'watch'],
637
+ },
638
+ ];
639
+ const manifest = {
640
+ apiVersion: 'rbac.authorization.k8s.io/v1',
641
+ kind: 'ClusterRole',
642
+ metadata: {
643
+ name: `${this.config.appName}-clusterrole`,
644
+ labels: this.getLabels(),
645
+ },
646
+ rules,
647
+ };
648
+ return {
649
+ name: 'clusterrole',
650
+ kind: 'ClusterRole',
651
+ content: yaml.dump(manifest),
652
+ };
653
+ }
654
+ generateClusterRoleBinding() {
655
+ const manifest = {
656
+ apiVersion: 'rbac.authorization.k8s.io/v1',
657
+ kind: 'ClusterRoleBinding',
658
+ metadata: {
659
+ name: `${this.config.appName}-clusterrolebinding`,
660
+ labels: this.getLabels(),
661
+ },
662
+ subjects: [
663
+ {
664
+ kind: 'ServiceAccount',
665
+ name: this.config.serviceAccount?.name || this.config.appName,
666
+ namespace: this.config.namespace,
667
+ },
668
+ ],
669
+ roleRef: {
670
+ kind: 'ClusterRole',
671
+ name: `${this.config.appName}-clusterrole`,
672
+ apiGroup: 'rbac.authorization.k8s.io',
673
+ },
674
+ };
675
+ return {
676
+ name: 'clusterrolebinding',
677
+ kind: 'ClusterRoleBinding',
678
+ content: yaml.dump(manifest),
679
+ };
680
+ }
681
+ generateNetworkPolicy() {
682
+ const spec = {
683
+ podSelector: {
684
+ matchLabels: this.getSelectorLabels(),
685
+ },
686
+ policyTypes: [],
687
+ };
688
+ if (this.config.networkPolicy?.ingressRules) {
689
+ spec.policyTypes.push('Ingress');
690
+ spec.ingress = this.config.networkPolicy.ingressRules;
691
+ }
692
+ else {
693
+ spec.policyTypes.push('Ingress');
694
+ spec.ingress = [
695
+ {
696
+ from: [
697
+ {
698
+ podSelector: {
699
+ matchLabels: this.getSelectorLabels(),
700
+ },
701
+ },
702
+ ],
703
+ ports: [
704
+ {
705
+ protocol: 'TCP',
706
+ port: this.config.containerPort,
707
+ },
708
+ ],
709
+ },
710
+ ];
711
+ }
712
+ if (this.config.networkPolicy?.egressRules) {
713
+ spec.policyTypes.push('Egress');
714
+ spec.egress = this.config.networkPolicy.egressRules;
715
+ }
716
+ const manifest = {
717
+ apiVersion: 'networking.k8s.io/v1',
718
+ kind: 'NetworkPolicy',
719
+ metadata: {
720
+ name: `${this.config.appName}-netpol`,
721
+ namespace: this.config.namespace,
722
+ labels: this.getLabels(),
723
+ },
724
+ spec,
725
+ };
726
+ return {
727
+ name: 'networkpolicy',
728
+ kind: 'NetworkPolicy',
729
+ content: yaml.dump(manifest),
730
+ };
731
+ }
732
+ generatePersistentVolumeClaim() {
733
+ const manifest = {
734
+ apiVersion: 'v1',
735
+ kind: 'PersistentVolumeClaim',
736
+ metadata: {
737
+ name: `${this.config.appName}-pvc`,
738
+ namespace: this.config.namespace,
739
+ labels: this.getLabels(),
740
+ },
741
+ spec: {
742
+ accessModes: this.config.persistence?.accessModes || ['ReadWriteOnce'],
743
+ storageClassName: this.config.persistence?.storageClass || 'standard',
744
+ resources: {
745
+ requests: {
746
+ storage: this.config.persistence?.size || '10Gi',
747
+ },
748
+ },
749
+ },
750
+ };
751
+ return {
752
+ name: 'pvc',
753
+ kind: 'PersistentVolumeClaim',
754
+ content: yaml.dump(manifest),
755
+ };
756
+ }
757
+ generateKustomization(manifests) {
758
+ const kustomization = {
759
+ apiVersion: 'kustomize.config.k8s.io/v1beta1',
760
+ kind: 'Kustomization',
761
+ namespace: this.config.namespace,
762
+ resources: manifests.map(m => `${m.name}.yaml`),
763
+ commonLabels: this.getSelectorLabels(),
764
+ };
765
+ return yaml.dump(kustomization);
766
+ }
767
+ }
768
+ /**
769
+ * Factory function for creating a Kubernetes generator
770
+ */
771
+ export function createKubernetesGenerator(config) {
772
+ return new KubernetesGenerator(config);
773
+ }