agent-devkit 0.1.6 → 0.2.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 (551) hide show
  1. package/README.md +13 -1
  2. package/package.json +1 -1
  3. package/runtime/README.md +53 -1
  4. package/runtime/agent +5 -0
  5. package/runtime/agents/README.md +26 -0
  6. package/runtime/agents/agent-devkit-agent-builder/AGENTS.md +24 -0
  7. package/runtime/agents/agent-devkit-agent-builder/README.md +37 -0
  8. package/runtime/agents/agent-devkit-agent-builder/agent.yaml +46 -0
  9. package/runtime/agents/agent-devkit-agent-builder/capabilities/plan-agent/capability.yaml +29 -0
  10. package/runtime/agents/agent-devkit-agent-builder/capabilities/plan-agent/decision-rules.md +7 -0
  11. package/runtime/agents/agent-devkit-agent-builder/capabilities/plan-agent/runner.py +33 -0
  12. package/runtime/agents/agent-devkit-agent-builder/capabilities/plan-agent/workflow.md +8 -0
  13. package/runtime/agents/agent-devkit-agent-builder/capabilities/scaffold-agent/capability.yaml +31 -0
  14. package/runtime/agents/agent-devkit-agent-builder/capabilities/scaffold-agent/decision-rules.md +9 -0
  15. package/runtime/agents/agent-devkit-agent-builder/capabilities/scaffold-agent/runner.py +39 -0
  16. package/runtime/agents/agent-devkit-agent-builder/capabilities/scaffold-agent/workflow.md +8 -0
  17. package/runtime/agents/agent-devkit-agent-builder/capabilities/validate-agent-contract/capability.yaml +28 -0
  18. package/runtime/agents/agent-devkit-agent-builder/capabilities/validate-agent-contract/decision-rules.md +6 -0
  19. package/runtime/agents/agent-devkit-agent-builder/capabilities/validate-agent-contract/runner.py +33 -0
  20. package/runtime/agents/agent-devkit-agent-builder/capabilities/validate-agent-contract/workflow.md +7 -0
  21. package/runtime/agents/agent-devkit-agent-builder/infra/integrations/agent-devkit/agent_builder_repository.py +527 -0
  22. package/runtime/agents/agent-devkit-agent-builder/knowledge/context.md +15 -0
  23. package/runtime/agents/agent-devkit-agent-builder/knowledge/policies.yaml +11 -0
  24. package/runtime/agents/agent-devkit-agent-builder/knowledge/system.md +11 -0
  25. package/runtime/agents/agent-devkit-agent-builder/templates/agent-plan-output.md +20 -0
  26. package/runtime/agents/agent-devkit-agent-builder/templates/scaffold-plan-output.md +13 -0
  27. package/runtime/agents/agent-devkit-agent-builder/templates/validation-report-output.md +13 -0
  28. package/runtime/agents/agent-devkit-agent-builder/tests/test_runners.py +188 -0
  29. package/runtime/agents/automation-architect/AGENTS.md +11 -0
  30. package/runtime/agents/automation-architect/README.md +27 -0
  31. package/runtime/agents/automation-architect/agent.yaml +57 -0
  32. package/runtime/agents/automation-architect/capabilities/classify-automation-request/capability.yaml +35 -0
  33. package/runtime/agents/automation-architect/capabilities/classify-automation-request/decision-rules.md +10 -0
  34. package/runtime/agents/automation-architect/capabilities/classify-automation-request/runner.py +37 -0
  35. package/runtime/agents/automation-architect/capabilities/classify-automation-request/workflow.md +7 -0
  36. package/runtime/agents/automation-architect/capabilities/delegate-automation-build/capability.yaml +34 -0
  37. package/runtime/agents/automation-architect/capabilities/delegate-automation-build/decision-rules.md +7 -0
  38. package/runtime/agents/automation-architect/capabilities/delegate-automation-build/runner.py +37 -0
  39. package/runtime/agents/automation-architect/capabilities/delegate-automation-build/workflow.md +6 -0
  40. package/runtime/agents/automation-architect/capabilities/plan-automation-solution/capability.yaml +35 -0
  41. package/runtime/agents/automation-architect/capabilities/plan-automation-solution/decision-rules.md +7 -0
  42. package/runtime/agents/automation-architect/capabilities/plan-automation-solution/runner.py +37 -0
  43. package/runtime/agents/automation-architect/capabilities/plan-automation-solution/workflow.md +7 -0
  44. package/runtime/agents/automation-architect/capabilities/review-automation-solution/capability.yaml +36 -0
  45. package/runtime/agents/automation-architect/capabilities/review-automation-solution/decision-rules.md +7 -0
  46. package/runtime/agents/automation-architect/capabilities/review-automation-solution/runner.py +39 -0
  47. package/runtime/agents/automation-architect/capabilities/review-automation-solution/workflow.md +7 -0
  48. package/runtime/agents/automation-architect/infra/integrations/automation-architecture/automation_architecture_repository.py +481 -0
  49. package/runtime/agents/automation-architect/knowledge/context.md +22 -0
  50. package/runtime/agents/automation-architect/knowledge/policies.yaml +20 -0
  51. package/runtime/agents/automation-architect/knowledge/system.md +8 -0
  52. package/runtime/agents/automation-architect/templates/automation-classification.md +6 -0
  53. package/runtime/agents/automation-architect/templates/automation-plan.md +5 -0
  54. package/runtime/agents/automation-architect/tests/test_runners.py +135 -0
  55. package/runtime/agents/aws-architecture-analyst/agent.yaml +17 -4
  56. package/runtime/agents/aws-cloudwatch-log-analyzer/agent.yaml +12 -2
  57. package/runtime/agents/aws-cloudwatch-log-analyzer/capabilities/analyze-service-error/capability.yaml +16 -0
  58. package/runtime/agents/aws-lambda-builder/AGENTS.md +27 -0
  59. package/runtime/agents/aws-lambda-builder/README.md +21 -0
  60. package/runtime/agents/aws-lambda-builder/agent.yaml +46 -0
  61. package/runtime/agents/aws-lambda-builder/capabilities/deploy-lambda-plan/capability.yaml +18 -0
  62. package/runtime/agents/aws-lambda-builder/capabilities/deploy-lambda-plan/decision-rules.md +6 -0
  63. package/runtime/agents/aws-lambda-builder/capabilities/deploy-lambda-plan/runner.py +33 -0
  64. package/runtime/agents/aws-lambda-builder/capabilities/deploy-lambda-plan/workflow.md +6 -0
  65. package/runtime/agents/aws-lambda-builder/capabilities/generate-lambda-project/capability.yaml +20 -0
  66. package/runtime/agents/aws-lambda-builder/capabilities/generate-lambda-project/decision-rules.md +6 -0
  67. package/runtime/agents/aws-lambda-builder/capabilities/generate-lambda-project/runner.py +39 -0
  68. package/runtime/agents/aws-lambda-builder/capabilities/generate-lambda-project/workflow.md +7 -0
  69. package/runtime/agents/aws-lambda-builder/capabilities/package-lambda/capability.yaml +22 -0
  70. package/runtime/agents/aws-lambda-builder/capabilities/package-lambda/decision-rules.md +6 -0
  71. package/runtime/agents/aws-lambda-builder/capabilities/package-lambda/runner.py +41 -0
  72. package/runtime/agents/aws-lambda-builder/capabilities/package-lambda/workflow.md +6 -0
  73. package/runtime/agents/aws-lambda-builder/capabilities/plan-lambda/capability.yaml +18 -0
  74. package/runtime/agents/aws-lambda-builder/capabilities/plan-lambda/decision-rules.md +7 -0
  75. package/runtime/agents/aws-lambda-builder/capabilities/plan-lambda/runner.py +33 -0
  76. package/runtime/agents/aws-lambda-builder/capabilities/plan-lambda/workflow.md +6 -0
  77. package/runtime/agents/aws-lambda-builder/capabilities/review-lambda-security/capability.yaml +18 -0
  78. package/runtime/agents/aws-lambda-builder/capabilities/review-lambda-security/decision-rules.md +7 -0
  79. package/runtime/agents/aws-lambda-builder/capabilities/review-lambda-security/runner.py +33 -0
  80. package/runtime/agents/aws-lambda-builder/capabilities/review-lambda-security/workflow.md +5 -0
  81. package/runtime/agents/aws-lambda-builder/infra/integrations/aws-lambda/aws_lambda_repository.py +688 -0
  82. package/runtime/agents/aws-lambda-builder/knowledge/context.md +12 -0
  83. package/runtime/agents/aws-lambda-builder/knowledge/policies.yaml +23 -0
  84. package/runtime/agents/aws-lambda-builder/knowledge/system.md +10 -0
  85. package/runtime/agents/aws-lambda-builder/templates/lambda-deploy-plan.md +3 -0
  86. package/runtime/agents/aws-lambda-builder/templates/lambda-package.md +3 -0
  87. package/runtime/agents/aws-lambda-builder/templates/lambda-plan.md +3 -0
  88. package/runtime/agents/aws-lambda-builder/templates/lambda-readme.md +3 -0
  89. package/runtime/agents/aws-lambda-builder/templates/lambda-security-review.md +3 -0
  90. package/runtime/agents/aws-lambda-builder/tests/test_runners.py +355 -0
  91. package/runtime/agents/aws-operations-operator/agent.yaml +18 -6
  92. package/runtime/agents/aws-security-governance-auditor/agent.yaml +17 -5
  93. package/runtime/agents/azure-devops-orchestrator/agent.yaml +15 -2
  94. package/runtime/agents/azure-devops-orchestrator/capabilities/read-card/capability.yaml +29 -0
  95. package/runtime/agents/bpo-analyser/agent.yaml +12 -2
  96. package/runtime/agents/bpo-analyser/knowledge/policies.yaml +2 -2
  97. package/runtime/agents/data-scientist-analyst/agent.yaml +16 -4
  98. package/runtime/agents/data-scientist-analyst/capabilities/generate-data-report/capability.yaml +1 -1
  99. package/runtime/agents/data-scientist-analyst/capabilities/generate-reconciliation-report/capability.yaml +1 -1
  100. package/runtime/agents/data-scientist-analyst/capabilities/run-data-pipeline/capability.yaml +1 -1
  101. package/runtime/agents/data-scientist-analyst/infra/integrations/agent-bridge/methods/analyze-sql-source.yaml +1 -1
  102. package/runtime/agents/data-scientist-analyst/knowledge/policies.yaml +4 -4
  103. package/runtime/agents/data-scientist-analyst/knowledge/system.md +1 -1
  104. package/runtime/agents/data-scientist-analyst/tests/test_runners.py +1 -1
  105. package/runtime/agents/database-change-operator/agent.yaml +12 -1
  106. package/runtime/agents/docker-container-builder/AGENTS.md +27 -0
  107. package/runtime/agents/docker-container-builder/README.md +21 -0
  108. package/runtime/agents/docker-container-builder/agent.yaml +52 -0
  109. package/runtime/agents/docker-container-builder/capabilities/analyze-containerization-target/capability.yaml +18 -0
  110. package/runtime/agents/docker-container-builder/capabilities/analyze-containerization-target/decision-rules.md +6 -0
  111. package/runtime/agents/docker-container-builder/capabilities/analyze-containerization-target/runner.py +32 -0
  112. package/runtime/agents/docker-container-builder/capabilities/analyze-containerization-target/workflow.md +6 -0
  113. package/runtime/agents/docker-container-builder/capabilities/generate-compose/capability.yaml +18 -0
  114. package/runtime/agents/docker-container-builder/capabilities/generate-compose/decision-rules.md +7 -0
  115. package/runtime/agents/docker-container-builder/capabilities/generate-compose/runner.py +32 -0
  116. package/runtime/agents/docker-container-builder/capabilities/generate-compose/workflow.md +6 -0
  117. package/runtime/agents/docker-container-builder/capabilities/generate-container-project-files/capability.yaml +20 -0
  118. package/runtime/agents/docker-container-builder/capabilities/generate-container-project-files/decision-rules.md +7 -0
  119. package/runtime/agents/docker-container-builder/capabilities/generate-container-project-files/runner.py +38 -0
  120. package/runtime/agents/docker-container-builder/capabilities/generate-container-project-files/workflow.md +7 -0
  121. package/runtime/agents/docker-container-builder/capabilities/generate-dockerfile/capability.yaml +18 -0
  122. package/runtime/agents/docker-container-builder/capabilities/generate-dockerfile/decision-rules.md +6 -0
  123. package/runtime/agents/docker-container-builder/capabilities/generate-dockerfile/runner.py +32 -0
  124. package/runtime/agents/docker-container-builder/capabilities/generate-dockerfile/workflow.md +7 -0
  125. package/runtime/agents/docker-container-builder/capabilities/plan-image-build/capability.yaml +18 -0
  126. package/runtime/agents/docker-container-builder/capabilities/plan-image-build/decision-rules.md +6 -0
  127. package/runtime/agents/docker-container-builder/capabilities/plan-image-build/runner.py +32 -0
  128. package/runtime/agents/docker-container-builder/capabilities/plan-image-build/workflow.md +6 -0
  129. package/runtime/agents/docker-container-builder/capabilities/review-docker-security/capability.yaml +21 -0
  130. package/runtime/agents/docker-container-builder/capabilities/review-docker-security/decision-rules.md +6 -0
  131. package/runtime/agents/docker-container-builder/capabilities/review-docker-security/runner.py +43 -0
  132. package/runtime/agents/docker-container-builder/capabilities/review-docker-security/workflow.md +5 -0
  133. package/runtime/agents/docker-container-builder/infra/integrations/docker-container/docker_container_repository.py +837 -0
  134. package/runtime/agents/docker-container-builder/knowledge/context.md +21 -0
  135. package/runtime/agents/docker-container-builder/knowledge/policies.yaml +13 -0
  136. package/runtime/agents/docker-container-builder/knowledge/system.md +21 -0
  137. package/runtime/agents/docker-container-builder/templates/container-plan.md +4 -0
  138. package/runtime/agents/docker-container-builder/templates/container-review.md +4 -0
  139. package/runtime/agents/docker-container-builder/templates/docker-compose.md +5 -0
  140. package/runtime/agents/docker-container-builder/templates/docker-readme.md +3 -0
  141. package/runtime/agents/docker-container-builder/templates/dockerfile.md +5 -0
  142. package/runtime/agents/docker-container-builder/tests/test_runners.py +255 -0
  143. package/runtime/agents/drawio-diagram-builder/agent.yaml +11 -2
  144. package/runtime/agents/drawio-diagram-builder/capabilities/execute-diagram-delivery/capability.yaml +1 -1
  145. package/runtime/agents/drawio-diagram-builder/capabilities/read-azure-card-context/capability.yaml +1 -1
  146. package/runtime/agents/elasticsearch-log-analyzer/agent.yaml +14 -2
  147. package/runtime/agents/elasticsearch-log-analyzer/capabilities/analyze-service-errors/capability.yaml +14 -0
  148. package/runtime/agents/excel-workbook-builder/agent.yaml +10 -0
  149. package/runtime/agents/excel-workbook-builder/capabilities/create-template/capability.yaml +1 -1
  150. package/runtime/agents/excel-workbook-builder/capabilities/create-template/workflow.md +1 -1
  151. package/runtime/agents/excel-workbook-builder/capabilities/create-template-version/capability.yaml +1 -1
  152. package/runtime/agents/excel-workbook-builder/capabilities/generate-template-input-file/capability.yaml +1 -2
  153. package/runtime/agents/excel-workbook-builder/capabilities/refine-template/capability.yaml +1 -1
  154. package/runtime/agents/excel-workbook-builder/capabilities/register-template/capability.yaml +1 -2
  155. package/runtime/agents/excel-workbook-builder/capabilities/register-template/workflow.md +1 -1
  156. package/runtime/agents/execution-loop-builder/AGENTS.md +24 -0
  157. package/runtime/agents/execution-loop-builder/README.md +19 -0
  158. package/runtime/agents/execution-loop-builder/agent.yaml +49 -0
  159. package/runtime/agents/execution-loop-builder/capabilities/generate-loop-project-files/capability.yaml +20 -0
  160. package/runtime/agents/execution-loop-builder/capabilities/generate-loop-project-files/decision-rules.md +6 -0
  161. package/runtime/agents/execution-loop-builder/capabilities/generate-loop-project-files/runner.py +38 -0
  162. package/runtime/agents/execution-loop-builder/capabilities/generate-loop-project-files/workflow.md +7 -0
  163. package/runtime/agents/execution-loop-builder/capabilities/generate-loop-runner/capability.yaml +18 -0
  164. package/runtime/agents/execution-loop-builder/capabilities/generate-loop-runner/decision-rules.md +5 -0
  165. package/runtime/agents/execution-loop-builder/capabilities/generate-loop-runner/runner.py +32 -0
  166. package/runtime/agents/execution-loop-builder/capabilities/generate-loop-runner/workflow.md +6 -0
  167. package/runtime/agents/execution-loop-builder/capabilities/plan-execution-loop/capability.yaml +18 -0
  168. package/runtime/agents/execution-loop-builder/capabilities/plan-execution-loop/decision-rules.md +6 -0
  169. package/runtime/agents/execution-loop-builder/capabilities/plan-execution-loop/runner.py +32 -0
  170. package/runtime/agents/execution-loop-builder/capabilities/plan-execution-loop/workflow.md +6 -0
  171. package/runtime/agents/execution-loop-builder/capabilities/register-loop-task/capability.yaml +19 -0
  172. package/runtime/agents/execution-loop-builder/capabilities/register-loop-task/decision-rules.md +6 -0
  173. package/runtime/agents/execution-loop-builder/capabilities/register-loop-task/runner.py +36 -0
  174. package/runtime/agents/execution-loop-builder/capabilities/register-loop-task/workflow.md +6 -0
  175. package/runtime/agents/execution-loop-builder/capabilities/review-loop-safety/capability.yaml +19 -0
  176. package/runtime/agents/execution-loop-builder/capabilities/review-loop-safety/decision-rules.md +6 -0
  177. package/runtime/agents/execution-loop-builder/capabilities/review-loop-safety/runner.py +39 -0
  178. package/runtime/agents/execution-loop-builder/capabilities/review-loop-safety/workflow.md +5 -0
  179. package/runtime/agents/execution-loop-builder/infra/integrations/execution-loop/execution_loop_repository.py +608 -0
  180. package/runtime/agents/execution-loop-builder/knowledge/context.md +26 -0
  181. package/runtime/agents/execution-loop-builder/knowledge/policies.yaml +13 -0
  182. package/runtime/agents/execution-loop-builder/knowledge/system.md +19 -0
  183. package/runtime/agents/execution-loop-builder/templates/loop-plan.md +3 -0
  184. package/runtime/agents/execution-loop-builder/templates/loop-readme.md +3 -0
  185. package/runtime/agents/execution-loop-builder/templates/loop-review.md +3 -0
  186. package/runtime/agents/execution-loop-builder/templates/loop-runner.py +2 -0
  187. package/runtime/agents/execution-loop-builder/tests/test_runners.py +274 -0
  188. package/runtime/agents/execution-reviewer/agent.yaml +6 -4
  189. package/runtime/agents/execution-reviewer/capabilities/review-agent-result/capability.yaml +1 -2
  190. package/runtime/agents/execution-reviewer/capabilities/review-final-output/capability.yaml +1 -2
  191. package/runtime/agents/execution-reviewer/capabilities/review-plan/capability.yaml +1 -2
  192. package/runtime/agents/figma-ui-ux-product-designer/agent.yaml +17 -5
  193. package/runtime/agents/figma-ui-ux-product-designer/capabilities/analyze-product-context/capability.yaml +1 -1
  194. package/runtime/agents/figma-ui-ux-product-designer/capabilities/conduct-design-interview/capability.yaml +1 -1
  195. package/runtime/agents/figma-ui-ux-product-designer/capabilities/conduct-design-review-session/capability.yaml +1 -1
  196. package/runtime/agents/figma-ui-ux-product-designer/capabilities/generate-dev-handoff/capability.yaml +1 -1
  197. package/runtime/agents/figma-ui-ux-product-designer/capabilities/generate-user-journey-diagram/capability.yaml +1 -1
  198. package/runtime/agents/figma-ui-ux-product-designer/capabilities/ingest-design-source/capability.yaml +1 -1
  199. package/runtime/agents/figma-ui-ux-product-designer/capabilities/triage-design-feedback/capability.yaml +1 -1
  200. package/runtime/agents/generic-agent-builder/AGENTS.md +20 -0
  201. package/runtime/agents/generic-agent-builder/README.md +40 -0
  202. package/runtime/agents/generic-agent-builder/agent.yaml +43 -0
  203. package/runtime/agents/generic-agent-builder/capabilities/generate-agent-instructions/capability.yaml +18 -0
  204. package/runtime/agents/generic-agent-builder/capabilities/generate-agent-instructions/decision-rules.md +5 -0
  205. package/runtime/agents/generic-agent-builder/capabilities/generate-agent-instructions/runner.py +33 -0
  206. package/runtime/agents/generic-agent-builder/capabilities/generate-agent-instructions/workflow.md +6 -0
  207. package/runtime/agents/generic-agent-builder/capabilities/generate-project-agent-files/capability.yaml +20 -0
  208. package/runtime/agents/generic-agent-builder/capabilities/generate-project-agent-files/decision-rules.md +6 -0
  209. package/runtime/agents/generic-agent-builder/capabilities/generate-project-agent-files/runner.py +39 -0
  210. package/runtime/agents/generic-agent-builder/capabilities/generate-project-agent-files/workflow.md +7 -0
  211. package/runtime/agents/generic-agent-builder/capabilities/generate-skill/capability.yaml +18 -0
  212. package/runtime/agents/generic-agent-builder/capabilities/generate-skill/decision-rules.md +5 -0
  213. package/runtime/agents/generic-agent-builder/capabilities/generate-skill/runner.py +33 -0
  214. package/runtime/agents/generic-agent-builder/capabilities/generate-skill/workflow.md +5 -0
  215. package/runtime/agents/generic-agent-builder/capabilities/plan-generic-agent/capability.yaml +18 -0
  216. package/runtime/agents/generic-agent-builder/capabilities/plan-generic-agent/decision-rules.md +6 -0
  217. package/runtime/agents/generic-agent-builder/capabilities/plan-generic-agent/runner.py +33 -0
  218. package/runtime/agents/generic-agent-builder/capabilities/plan-generic-agent/workflow.md +6 -0
  219. package/runtime/agents/generic-agent-builder/capabilities/review-generic-agent/capability.yaml +20 -0
  220. package/runtime/agents/generic-agent-builder/capabilities/review-generic-agent/decision-rules.md +6 -0
  221. package/runtime/agents/generic-agent-builder/capabilities/review-generic-agent/runner.py +40 -0
  222. package/runtime/agents/generic-agent-builder/capabilities/review-generic-agent/workflow.md +7 -0
  223. package/runtime/agents/generic-agent-builder/infra/integrations/generic-agent/generic_agent_repository.py +445 -0
  224. package/runtime/agents/generic-agent-builder/knowledge/context.md +11 -0
  225. package/runtime/agents/generic-agent-builder/knowledge/policies.yaml +12 -0
  226. package/runtime/agents/generic-agent-builder/knowledge/system.md +17 -0
  227. package/runtime/agents/generic-agent-builder/templates/generic-agent-instructions.md +17 -0
  228. package/runtime/agents/generic-agent-builder/templates/generic-review-report.md +13 -0
  229. package/runtime/agents/generic-agent-builder/templates/generic-skill.md +14 -0
  230. package/runtime/agents/generic-agent-builder/tests/test_runners.py +220 -0
  231. package/runtime/agents/github-pr-reviewer/agent.yaml +17 -5
  232. package/runtime/agents/github-pr-reviewer/capabilities/create-review-automation/capability.yaml +1 -1
  233. package/runtime/agents/github-pr-reviewer/capabilities/inspect-pr/capability.yaml +1 -1
  234. package/runtime/agents/github-pr-reviewer/capabilities/list-review-requests/capability.yaml +1 -1
  235. package/runtime/agents/github-pr-reviewer/capabilities/review-pr-diff/capability.yaml +1 -1
  236. package/runtime/agents/knowledge-generator/agent.yaml +13 -3
  237. package/runtime/agents/knowledge-generator/capabilities/generate-knowledge/capability.yaml +1 -1
  238. package/runtime/agents/local-llm-operator/agent.yaml +6 -4
  239. package/runtime/agents/local-llm-operator/capabilities/delegate-operational-task/capability.yaml +1 -2
  240. package/runtime/agents/local-llm-operator/capabilities/inspect-local-models/capability.yaml +1 -2
  241. package/runtime/agents/local-llm-operator/capabilities/select-local-worker/capability.yaml +1 -2
  242. package/runtime/agents/n1-support-agent/agent.yaml +40 -1
  243. package/runtime/agents/n2-support-agent/agent.yaml +41 -2
  244. package/runtime/agents/n2-support-agent/knowledge/policies.yaml +2 -2
  245. package/runtime/agents/notification-operator/AGENTS.md +11 -0
  246. package/runtime/agents/notification-operator/README.md +15 -0
  247. package/runtime/agents/notification-operator/agent.yaml +43 -0
  248. package/runtime/agents/notification-operator/capabilities/configure-notification-channel/capability.yaml +19 -0
  249. package/runtime/agents/notification-operator/capabilities/configure-notification-channel/decision-rules.md +6 -0
  250. package/runtime/agents/notification-operator/capabilities/configure-notification-channel/runner.py +33 -0
  251. package/runtime/agents/notification-operator/capabilities/configure-notification-channel/workflow.md +6 -0
  252. package/runtime/agents/notification-operator/capabilities/format-task-completion-notification/capability.yaml +25 -0
  253. package/runtime/agents/notification-operator/capabilities/format-task-completion-notification/decision-rules.md +7 -0
  254. package/runtime/agents/notification-operator/capabilities/format-task-completion-notification/runner.py +49 -0
  255. package/runtime/agents/notification-operator/capabilities/format-task-completion-notification/workflow.md +6 -0
  256. package/runtime/agents/notification-operator/capabilities/send-task-completion-notification/capability.yaml +27 -0
  257. package/runtime/agents/notification-operator/capabilities/send-task-completion-notification/decision-rules.md +6 -0
  258. package/runtime/agents/notification-operator/capabilities/send-task-completion-notification/runner.py +68 -0
  259. package/runtime/agents/notification-operator/capabilities/send-task-completion-notification/workflow.md +7 -0
  260. package/runtime/agents/notification-operator/infra/README.md +6 -0
  261. package/runtime/agents/notification-operator/knowledge/context.md +10 -0
  262. package/runtime/agents/notification-operator/knowledge/policies.yaml +9 -0
  263. package/runtime/agents/notification-operator/knowledge/system.md +7 -0
  264. package/runtime/agents/notification-operator/templates/README.md +6 -0
  265. package/runtime/agents/notification-operator/tests/test_runners.py +108 -0
  266. package/runtime/agents/playwright-automation-builder/AGENTS.md +23 -0
  267. package/runtime/agents/playwright-automation-builder/README.md +43 -0
  268. package/runtime/agents/playwright-automation-builder/agent.yaml +48 -0
  269. package/runtime/agents/playwright-automation-builder/capabilities/generate-playwright-project-files/capability.yaml +20 -0
  270. package/runtime/agents/playwright-automation-builder/capabilities/generate-playwright-project-files/decision-rules.md +6 -0
  271. package/runtime/agents/playwright-automation-builder/capabilities/generate-playwright-project-files/runner.py +38 -0
  272. package/runtime/agents/playwright-automation-builder/capabilities/generate-playwright-project-files/workflow.md +6 -0
  273. package/runtime/agents/playwright-automation-builder/capabilities/generate-playwright-script/capability.yaml +18 -0
  274. package/runtime/agents/playwright-automation-builder/capabilities/generate-playwright-script/decision-rules.md +6 -0
  275. package/runtime/agents/playwright-automation-builder/capabilities/generate-playwright-script/runner.py +32 -0
  276. package/runtime/agents/playwright-automation-builder/capabilities/generate-playwright-script/workflow.md +6 -0
  277. package/runtime/agents/playwright-automation-builder/capabilities/plan-playwright-automation/capability.yaml +18 -0
  278. package/runtime/agents/playwright-automation-builder/capabilities/plan-playwright-automation/decision-rules.md +6 -0
  279. package/runtime/agents/playwright-automation-builder/capabilities/plan-playwright-automation/runner.py +32 -0
  280. package/runtime/agents/playwright-automation-builder/capabilities/plan-playwright-automation/workflow.md +6 -0
  281. package/runtime/agents/playwright-automation-builder/capabilities/review-playwright-artifacts/capability.yaml +19 -0
  282. package/runtime/agents/playwright-automation-builder/capabilities/review-playwright-artifacts/decision-rules.md +6 -0
  283. package/runtime/agents/playwright-automation-builder/capabilities/review-playwright-artifacts/runner.py +33 -0
  284. package/runtime/agents/playwright-automation-builder/capabilities/review-playwright-artifacts/workflow.md +6 -0
  285. package/runtime/agents/playwright-automation-builder/capabilities/run-playwright-check/capability.yaml +22 -0
  286. package/runtime/agents/playwright-automation-builder/capabilities/run-playwright-check/decision-rules.md +6 -0
  287. package/runtime/agents/playwright-automation-builder/capabilities/run-playwright-check/runner.py +40 -0
  288. package/runtime/agents/playwright-automation-builder/capabilities/run-playwright-check/workflow.md +6 -0
  289. package/runtime/agents/playwright-automation-builder/capabilities/wrap-playwright-as-capability/capability.yaml +22 -0
  290. package/runtime/agents/playwright-automation-builder/capabilities/wrap-playwright-as-capability/decision-rules.md +6 -0
  291. package/runtime/agents/playwright-automation-builder/capabilities/wrap-playwright-as-capability/runner.py +42 -0
  292. package/runtime/agents/playwright-automation-builder/capabilities/wrap-playwright-as-capability/workflow.md +6 -0
  293. package/runtime/agents/playwright-automation-builder/infra/integrations/playwright-automation/playwright_automation_repository.py +865 -0
  294. package/runtime/agents/playwright-automation-builder/knowledge/context.md +19 -0
  295. package/runtime/agents/playwright-automation-builder/knowledge/policies.yaml +25 -0
  296. package/runtime/agents/playwright-automation-builder/knowledge/system.md +19 -0
  297. package/runtime/agents/playwright-automation-builder/templates/capability-wrapper.md +4 -0
  298. package/runtime/agents/playwright-automation-builder/templates/playwright-automation.py +12 -0
  299. package/runtime/agents/playwright-automation-builder/templates/playwright-readme.md +13 -0
  300. package/runtime/agents/playwright-automation-builder/templates/playwright-review-report.md +9 -0
  301. package/runtime/agents/playwright-automation-builder/templates/playwright-test.py +2 -0
  302. package/runtime/agents/playwright-automation-builder/tests/test_runners.py +261 -0
  303. package/runtime/agents/postgres-data-analyzer/agent.yaml +13 -2
  304. package/runtime/agents/presentation-deck-builder/agent.yaml +14 -3
  305. package/runtime/agents/presentation-deck-builder/capabilities/create-template/capability.yaml +1 -1
  306. package/runtime/agents/presentation-deck-builder/capabilities/create-template-version/capability.yaml +1 -1
  307. package/runtime/agents/presentation-deck-builder/capabilities/generate-template-input-file/capability.yaml +1 -1
  308. package/runtime/agents/presentation-deck-builder/capabilities/refine-template/capability.yaml +1 -1
  309. package/runtime/agents/presentation-deck-builder/capabilities/register-template/capability.yaml +1 -1
  310. package/runtime/agents/presentation-deck-builder/knowledge/prompts/create-template.md +1 -1
  311. package/runtime/agents/presentation-deck-builder/knowledge/prompts/generate-template-input-file.md +1 -1
  312. package/runtime/agents/provider-configurator/agent.yaml +6 -4
  313. package/runtime/agents/provider-configurator/capabilities/collect-provider-credentials/capability.yaml +1 -2
  314. package/runtime/agents/provider-configurator/capabilities/configure-provider-source/capability.yaml +1 -2
  315. package/runtime/agents/provider-configurator/capabilities/validate-provider-readiness/capability.yaml +1 -2
  316. package/runtime/agents/pyautogui-automation-builder/AGENTS.md +32 -0
  317. package/runtime/agents/pyautogui-automation-builder/README.md +44 -0
  318. package/runtime/agents/pyautogui-automation-builder/agent.yaml +45 -0
  319. package/runtime/agents/pyautogui-automation-builder/capabilities/generate-pyautogui-project-files/capability.yaml +20 -0
  320. package/runtime/agents/pyautogui-automation-builder/capabilities/generate-pyautogui-project-files/decision-rules.md +6 -0
  321. package/runtime/agents/pyautogui-automation-builder/capabilities/generate-pyautogui-project-files/runner.py +39 -0
  322. package/runtime/agents/pyautogui-automation-builder/capabilities/generate-pyautogui-project-files/workflow.md +7 -0
  323. package/runtime/agents/pyautogui-automation-builder/capabilities/generate-pyautogui-script/capability.yaml +18 -0
  324. package/runtime/agents/pyautogui-automation-builder/capabilities/generate-pyautogui-script/decision-rules.md +7 -0
  325. package/runtime/agents/pyautogui-automation-builder/capabilities/generate-pyautogui-script/runner.py +33 -0
  326. package/runtime/agents/pyautogui-automation-builder/capabilities/generate-pyautogui-script/workflow.md +7 -0
  327. package/runtime/agents/pyautogui-automation-builder/capabilities/plan-desktop-automation/capability.yaml +18 -0
  328. package/runtime/agents/pyautogui-automation-builder/capabilities/plan-desktop-automation/decision-rules.md +8 -0
  329. package/runtime/agents/pyautogui-automation-builder/capabilities/plan-desktop-automation/runner.py +33 -0
  330. package/runtime/agents/pyautogui-automation-builder/capabilities/plan-desktop-automation/workflow.md +9 -0
  331. package/runtime/agents/pyautogui-automation-builder/capabilities/review-pyautogui-script/capability.yaml +20 -0
  332. package/runtime/agents/pyautogui-automation-builder/capabilities/review-pyautogui-script/decision-rules.md +8 -0
  333. package/runtime/agents/pyautogui-automation-builder/capabilities/review-pyautogui-script/runner.py +43 -0
  334. package/runtime/agents/pyautogui-automation-builder/capabilities/review-pyautogui-script/workflow.md +7 -0
  335. package/runtime/agents/pyautogui-automation-builder/capabilities/wrap-pyautogui-as-capability/capability.yaml +22 -0
  336. package/runtime/agents/pyautogui-automation-builder/capabilities/wrap-pyautogui-as-capability/decision-rules.md +6 -0
  337. package/runtime/agents/pyautogui-automation-builder/capabilities/wrap-pyautogui-as-capability/runner.py +43 -0
  338. package/runtime/agents/pyautogui-automation-builder/capabilities/wrap-pyautogui-as-capability/workflow.md +7 -0
  339. package/runtime/agents/pyautogui-automation-builder/infra/integrations/pyautogui-automation/pyautogui_automation_repository.py +856 -0
  340. package/runtime/agents/pyautogui-automation-builder/knowledge/context.md +17 -0
  341. package/runtime/agents/pyautogui-automation-builder/knowledge/policies.yaml +24 -0
  342. package/runtime/agents/pyautogui-automation-builder/knowledge/system.md +13 -0
  343. package/runtime/agents/pyautogui-automation-builder/templates/capability-wrapper.md +3 -0
  344. package/runtime/agents/pyautogui-automation-builder/templates/pyautogui-automation.py +12 -0
  345. package/runtime/agents/pyautogui-automation-builder/templates/pyautogui-readme.md +3 -0
  346. package/runtime/agents/pyautogui-automation-builder/templates/pyautogui-review-report.md +3 -0
  347. package/runtime/agents/pyautogui-automation-builder/templates/pyautogui-test.py +2 -0
  348. package/runtime/agents/pyautogui-automation-builder/tests/test_runners.py +376 -0
  349. package/runtime/agents/python-automation-builder/AGENTS.md +25 -0
  350. package/runtime/agents/python-automation-builder/README.md +43 -0
  351. package/runtime/agents/python-automation-builder/agent.yaml +45 -0
  352. package/runtime/agents/python-automation-builder/capabilities/generate-automation-project-files/capability.yaml +20 -0
  353. package/runtime/agents/python-automation-builder/capabilities/generate-automation-project-files/decision-rules.md +6 -0
  354. package/runtime/agents/python-automation-builder/capabilities/generate-automation-project-files/runner.py +39 -0
  355. package/runtime/agents/python-automation-builder/capabilities/generate-automation-project-files/workflow.md +7 -0
  356. package/runtime/agents/python-automation-builder/capabilities/generate-python-automation/capability.yaml +18 -0
  357. package/runtime/agents/python-automation-builder/capabilities/generate-python-automation/decision-rules.md +5 -0
  358. package/runtime/agents/python-automation-builder/capabilities/generate-python-automation/runner.py +33 -0
  359. package/runtime/agents/python-automation-builder/capabilities/generate-python-automation/workflow.md +5 -0
  360. package/runtime/agents/python-automation-builder/capabilities/plan-python-automation/capability.yaml +18 -0
  361. package/runtime/agents/python-automation-builder/capabilities/plan-python-automation/decision-rules.md +6 -0
  362. package/runtime/agents/python-automation-builder/capabilities/plan-python-automation/runner.py +33 -0
  363. package/runtime/agents/python-automation-builder/capabilities/plan-python-automation/workflow.md +6 -0
  364. package/runtime/agents/python-automation-builder/capabilities/review-python-automation/capability.yaml +20 -0
  365. package/runtime/agents/python-automation-builder/capabilities/review-python-automation/decision-rules.md +6 -0
  366. package/runtime/agents/python-automation-builder/capabilities/review-python-automation/runner.py +43 -0
  367. package/runtime/agents/python-automation-builder/capabilities/review-python-automation/workflow.md +5 -0
  368. package/runtime/agents/python-automation-builder/capabilities/wrap-automation-as-capability/capability.yaml +22 -0
  369. package/runtime/agents/python-automation-builder/capabilities/wrap-automation-as-capability/decision-rules.md +6 -0
  370. package/runtime/agents/python-automation-builder/capabilities/wrap-automation-as-capability/runner.py +43 -0
  371. package/runtime/agents/python-automation-builder/capabilities/wrap-automation-as-capability/workflow.md +6 -0
  372. package/runtime/agents/python-automation-builder/infra/integrations/python-automation/python_automation_repository.py +717 -0
  373. package/runtime/agents/python-automation-builder/knowledge/context.md +15 -0
  374. package/runtime/agents/python-automation-builder/knowledge/policies.yaml +12 -0
  375. package/runtime/agents/python-automation-builder/knowledge/system.md +19 -0
  376. package/runtime/agents/python-automation-builder/templates/automation-readme.md +13 -0
  377. package/runtime/agents/python-automation-builder/templates/automation-review-report.md +13 -0
  378. package/runtime/agents/python-automation-builder/templates/automation-test.py +9 -0
  379. package/runtime/agents/python-automation-builder/templates/automation.py +19 -0
  380. package/runtime/agents/python-automation-builder/templates/capability-wrapper.md +4 -0
  381. package/runtime/agents/python-automation-builder/tests/test_runners.py +292 -0
  382. package/runtime/agents/selenium-automation-builder/AGENTS.md +27 -0
  383. package/runtime/agents/selenium-automation-builder/README.md +40 -0
  384. package/runtime/agents/selenium-automation-builder/agent.yaml +45 -0
  385. package/runtime/agents/selenium-automation-builder/capabilities/generate-selenium-project-files/capability.yaml +20 -0
  386. package/runtime/agents/selenium-automation-builder/capabilities/generate-selenium-project-files/decision-rules.md +6 -0
  387. package/runtime/agents/selenium-automation-builder/capabilities/generate-selenium-project-files/runner.py +39 -0
  388. package/runtime/agents/selenium-automation-builder/capabilities/generate-selenium-project-files/workflow.md +7 -0
  389. package/runtime/agents/selenium-automation-builder/capabilities/generate-selenium-script/capability.yaml +18 -0
  390. package/runtime/agents/selenium-automation-builder/capabilities/generate-selenium-script/decision-rules.md +6 -0
  391. package/runtime/agents/selenium-automation-builder/capabilities/generate-selenium-script/runner.py +33 -0
  392. package/runtime/agents/selenium-automation-builder/capabilities/generate-selenium-script/workflow.md +6 -0
  393. package/runtime/agents/selenium-automation-builder/capabilities/plan-selenium-automation/capability.yaml +18 -0
  394. package/runtime/agents/selenium-automation-builder/capabilities/plan-selenium-automation/decision-rules.md +6 -0
  395. package/runtime/agents/selenium-automation-builder/capabilities/plan-selenium-automation/runner.py +33 -0
  396. package/runtime/agents/selenium-automation-builder/capabilities/plan-selenium-automation/workflow.md +6 -0
  397. package/runtime/agents/selenium-automation-builder/capabilities/review-selenium-script/capability.yaml +20 -0
  398. package/runtime/agents/selenium-automation-builder/capabilities/review-selenium-script/decision-rules.md +6 -0
  399. package/runtime/agents/selenium-automation-builder/capabilities/review-selenium-script/runner.py +40 -0
  400. package/runtime/agents/selenium-automation-builder/capabilities/review-selenium-script/workflow.md +6 -0
  401. package/runtime/agents/selenium-automation-builder/capabilities/wrap-selenium-as-capability/capability.yaml +22 -0
  402. package/runtime/agents/selenium-automation-builder/capabilities/wrap-selenium-as-capability/decision-rules.md +6 -0
  403. package/runtime/agents/selenium-automation-builder/capabilities/wrap-selenium-as-capability/runner.py +43 -0
  404. package/runtime/agents/selenium-automation-builder/capabilities/wrap-selenium-as-capability/workflow.md +6 -0
  405. package/runtime/agents/selenium-automation-builder/infra/integrations/selenium-automation/selenium_automation_repository.py +793 -0
  406. package/runtime/agents/selenium-automation-builder/knowledge/context.md +15 -0
  407. package/runtime/agents/selenium-automation-builder/knowledge/policies.yaml +17 -0
  408. package/runtime/agents/selenium-automation-builder/knowledge/system.md +18 -0
  409. package/runtime/agents/selenium-automation-builder/templates/capability-wrapper.md +4 -0
  410. package/runtime/agents/selenium-automation-builder/templates/selenium-automation.py +20 -0
  411. package/runtime/agents/selenium-automation-builder/templates/selenium-readme.md +13 -0
  412. package/runtime/agents/selenium-automation-builder/templates/selenium-review-report.md +13 -0
  413. package/runtime/agents/selenium-automation-builder/templates/selenium-test.py +9 -0
  414. package/runtime/agents/selenium-automation-builder/tests/test_runners.py +282 -0
  415. package/runtime/agents/software-specification-analyst/agent.yaml +17 -4
  416. package/runtime/agents/software-specification-analyst/capabilities/analyze-multiple-projects/capability.yaml +1 -1
  417. package/runtime/agents/software-specification-analyst/capabilities/analyze-project-context/capability.yaml +1 -1
  418. package/runtime/agents/software-specification-analyst/capabilities/conduct-requirements-interview/capability.yaml +1 -1
  419. package/runtime/agents/software-specification-analyst/capabilities/create-complete-spec/capability.yaml +1 -1
  420. package/runtime/agents/software-specification-analyst/capabilities/create-final-spec-from-analysis/capability.yaml +1 -1
  421. package/runtime/agents/software-specification-analyst/capabilities/create-functional-spec/capability.yaml +11 -0
  422. package/runtime/agents/software-specification-analyst/capabilities/create-technical-spec/capability.yaml +12 -0
  423. package/runtime/agents/software-specification-analyst/capabilities/refine-analysis-with-feedback/capability.yaml +1 -1
  424. package/runtime/agents/software-specification-analyst/capabilities/write-user-stories/capability.yaml +12 -0
  425. package/runtime/agents/sqlserver-change-operator/agent.yaml +12 -1
  426. package/runtime/agents/sqlserver-data-analyzer/agent.yaml +13 -2
  427. package/runtime/agents/supabase-project-analyst/AGENTS.md +29 -0
  428. package/runtime/agents/supabase-project-analyst/README.md +23 -0
  429. package/runtime/agents/supabase-project-analyst/agent.yaml +53 -0
  430. package/runtime/agents/supabase-project-analyst/capabilities/audit-auth-security/capability.yaml +18 -0
  431. package/runtime/agents/supabase-project-analyst/capabilities/audit-auth-security/decision-rules.md +5 -0
  432. package/runtime/agents/supabase-project-analyst/capabilities/audit-auth-security/runner.py +32 -0
  433. package/runtime/agents/supabase-project-analyst/capabilities/audit-auth-security/workflow.md +6 -0
  434. package/runtime/agents/supabase-project-analyst/capabilities/audit-rls-policies/capability.yaml +18 -0
  435. package/runtime/agents/supabase-project-analyst/capabilities/audit-rls-policies/decision-rules.md +6 -0
  436. package/runtime/agents/supabase-project-analyst/capabilities/audit-rls-policies/runner.py +32 -0
  437. package/runtime/agents/supabase-project-analyst/capabilities/audit-rls-policies/workflow.md +7 -0
  438. package/runtime/agents/supabase-project-analyst/capabilities/audit-storage-policies/capability.yaml +18 -0
  439. package/runtime/agents/supabase-project-analyst/capabilities/audit-storage-policies/decision-rules.md +5 -0
  440. package/runtime/agents/supabase-project-analyst/capabilities/audit-storage-policies/runner.py +32 -0
  441. package/runtime/agents/supabase-project-analyst/capabilities/audit-storage-policies/workflow.md +6 -0
  442. package/runtime/agents/supabase-project-analyst/capabilities/generate-supabase-report/capability.yaml +18 -0
  443. package/runtime/agents/supabase-project-analyst/capabilities/generate-supabase-report/decision-rules.md +6 -0
  444. package/runtime/agents/supabase-project-analyst/capabilities/generate-supabase-report/runner.py +32 -0
  445. package/runtime/agents/supabase-project-analyst/capabilities/generate-supabase-report/workflow.md +6 -0
  446. package/runtime/agents/supabase-project-analyst/capabilities/inspect-supabase-project/capability.yaml +19 -0
  447. package/runtime/agents/supabase-project-analyst/capabilities/inspect-supabase-project/decision-rules.md +6 -0
  448. package/runtime/agents/supabase-project-analyst/capabilities/inspect-supabase-project/runner.py +36 -0
  449. package/runtime/agents/supabase-project-analyst/capabilities/inspect-supabase-project/workflow.md +7 -0
  450. package/runtime/agents/supabase-project-analyst/capabilities/plan-supabase-fix/capability.yaml +18 -0
  451. package/runtime/agents/supabase-project-analyst/capabilities/plan-supabase-fix/decision-rules.md +6 -0
  452. package/runtime/agents/supabase-project-analyst/capabilities/plan-supabase-fix/runner.py +32 -0
  453. package/runtime/agents/supabase-project-analyst/capabilities/plan-supabase-fix/workflow.md +6 -0
  454. package/runtime/agents/supabase-project-analyst/capabilities/review-migrations/capability.yaml +18 -0
  455. package/runtime/agents/supabase-project-analyst/capabilities/review-migrations/decision-rules.md +6 -0
  456. package/runtime/agents/supabase-project-analyst/capabilities/review-migrations/runner.py +32 -0
  457. package/runtime/agents/supabase-project-analyst/capabilities/review-migrations/workflow.md +5 -0
  458. package/runtime/agents/supabase-project-analyst/infra/integrations/supabase-project/supabase_project_repository.py +589 -0
  459. package/runtime/agents/supabase-project-analyst/knowledge/context.md +11 -0
  460. package/runtime/agents/supabase-project-analyst/knowledge/policies.yaml +24 -0
  461. package/runtime/agents/supabase-project-analyst/knowledge/system.md +10 -0
  462. package/runtime/agents/supabase-project-analyst/templates/supabase-audit.md +3 -0
  463. package/runtime/agents/supabase-project-analyst/templates/supabase-fix-plan.md +3 -0
  464. package/runtime/agents/supabase-project-analyst/templates/supabase-inspection.md +3 -0
  465. package/runtime/agents/supabase-project-analyst/templates/supabase-report.md +3 -0
  466. package/runtime/agents/supabase-project-analyst/tests/test_runners.py +239 -0
  467. package/runtime/agents/task-orchestrator/agent.yaml +25 -3
  468. package/runtime/agents/task-orchestrator/capabilities/plan-task/capability.yaml +1 -2
  469. package/runtime/agents/task-orchestrator/capabilities/select-specialists/capability.yaml +1 -2
  470. package/runtime/agents/technical-integration-analyst/agent.yaml +15 -2
  471. package/runtime/agents/topdesk-orchestrator/agent.yaml +10 -2
  472. package/runtime/cli/aikit/__init__.py +1 -1
  473. package/runtime/cli/aikit/acceptance.py +166 -0
  474. package/runtime/cli/aikit/agent_executor.py +26 -3
  475. package/runtime/cli/aikit/agent_registry.py +244 -5
  476. package/runtime/cli/aikit/architecture.py +84 -0
  477. package/runtime/cli/aikit/audit.py +172 -3
  478. package/runtime/cli/aikit/autonomy.py +237 -0
  479. package/runtime/cli/aikit/capability_runtime.py +522 -0
  480. package/runtime/cli/aikit/catalog.py +246 -0
  481. package/runtime/cli/aikit/cli_dispatch.py +1078 -0
  482. package/runtime/cli/aikit/cli_parser.py +409 -0
  483. package/runtime/cli/aikit/collaboration.py +359 -0
  484. package/runtime/cli/aikit/configuration_orchestrator.py +52 -26
  485. package/runtime/cli/aikit/contribution.py +105 -0
  486. package/runtime/cli/aikit/core/__init__.py +1 -0
  487. package/runtime/cli/aikit/core/capability_contract.py +112 -0
  488. package/runtime/cli/aikit/core/requests.py +69 -0
  489. package/runtime/cli/aikit/core/runtime.py +64 -0
  490. package/runtime/cli/aikit/diagnostics.py +8 -2
  491. package/runtime/cli/aikit/doctor_runtime.py +79 -0
  492. package/runtime/cli/aikit/errors.py +7 -0
  493. package/runtime/cli/aikit/eval.py +158 -0
  494. package/runtime/cli/aikit/execution_reviewer.py +21 -0
  495. package/runtime/cli/aikit/extensions.py +140 -0
  496. package/runtime/cli/aikit/fallback.py +1 -0
  497. package/runtime/cli/aikit/github_pr.py +23 -0
  498. package/runtime/cli/aikit/guardrails.py +25 -10
  499. package/runtime/cli/aikit/human_output.py +1026 -0
  500. package/runtime/cli/aikit/impact_map.py +294 -0
  501. package/runtime/cli/aikit/interactive_wizard.py +79 -0
  502. package/runtime/cli/aikit/local_llm_operator.py +35 -1
  503. package/runtime/cli/aikit/main.py +9 -2834
  504. package/runtime/cli/aikit/mcp_manifest.py +229 -0
  505. package/runtime/cli/aikit/mcp_server.py +132 -0
  506. package/runtime/cli/aikit/mcp_tools.py +262 -0
  507. package/runtime/cli/aikit/mini_brain.py +227 -0
  508. package/runtime/cli/aikit/model_router.py +182 -18
  509. package/runtime/cli/aikit/module_controller.py +335 -0
  510. package/runtime/cli/aikit/natural_prompt_runtime.py +538 -0
  511. package/runtime/cli/aikit/notifications.py +716 -2
  512. package/runtime/cli/aikit/ollama.py +1 -0
  513. package/runtime/cli/aikit/orchestrator.py +809 -119
  514. package/runtime/cli/aikit/output.py +63 -2
  515. package/runtime/cli/aikit/permissions.py +14 -4
  516. package/runtime/cli/aikit/prompt_injection.py +57 -0
  517. package/runtime/cli/aikit/review_gate.py +38 -6
  518. package/runtime/cli/aikit/roadmap.py +195 -0
  519. package/runtime/cli/aikit/roadmap_cli.py +70 -0
  520. package/runtime/cli/aikit/router.py +41 -12
  521. package/runtime/cli/aikit/router_explain.py +152 -0
  522. package/runtime/cli/aikit/runtime_paths.py +11 -0
  523. package/runtime/cli/aikit/secrets.py +113 -0
  524. package/runtime/cli/aikit/sessions.py +88 -2
  525. package/runtime/cli/aikit/setup_wizard_payload.py +32 -0
  526. package/runtime/cli/aikit/sources.py +298 -50
  527. package/runtime/cli/aikit/tasks.py +449 -21
  528. package/runtime/cli/aikit/wizard_state.py +15 -1
  529. package/runtime/cli/aikit/workflows.py +115 -0
  530. package/runtime/cli/aikit/write_policy.py +108 -0
  531. package/runtime/plugins/claude-code-ai-devkit/README.md +17 -0
  532. package/runtime/plugins/claude-code-ai-devkit/agents/README.md +29 -2
  533. package/runtime/plugins/claude-code-ai-devkit/agents/agent-devkit-db-analyst.md +44 -0
  534. package/runtime/plugins/claude-code-ai-devkit/agents/agent-devkit-execution-reviewer.md +38 -0
  535. package/runtime/plugins/claude-code-ai-devkit/agents/agent-devkit-pr-reviewer.md +42 -0
  536. package/runtime/plugins/claude-code-ai-devkit/agents/agent-devkit-repo-explorer.md +40 -0
  537. package/runtime/plugins/claude-code-ai-devkit/agents/agent-devkit-support-triage.md +43 -0
  538. package/runtime/plugins/claude-code-ai-devkit/plugin.json +1 -1
  539. package/runtime/plugins/claude-code-ai-devkit/skills/ai-devkit-router/SKILL.md +16 -0
  540. package/runtime/plugins/claude-skill-ai-devkit/ai-devkit/SKILL.md +1 -0
  541. package/runtime/plugins/claude-skill-ai-devkit/ai-devkit/references/subagents.md +21 -0
  542. package/runtime/plugins/claude-skill-ai-devkit/plugin.json +1 -1
  543. package/runtime/providers/azure-devops.yaml +9 -0
  544. package/runtime/providers/github.yaml +4 -0
  545. package/runtime/providers/local-notification.yaml +5 -2
  546. package/runtime/providers/local-scheduler.yaml +1 -1
  547. package/runtime/providers/supabase.yaml +46 -0
  548. package/runtime/scripts/release-catalog-snapshot.json +543 -0
  549. package/runtime/scripts/release-gate.py +141 -1
  550. package/runtime/scripts/validate-repo.py +312 -0
  551. package/runtime/vendor/skills/napkin/napkin.md +15 -9
@@ -0,0 +1,688 @@
1
+ """Repository for deterministic AWS Lambda project generation."""
2
+
3
+ from __future__ import annotations
4
+
5
+ import json
6
+ import re
7
+ import zipfile
8
+ from pathlib import Path
9
+ from typing import Any
10
+
11
+ import yaml
12
+
13
+
14
+ REQUIRED_SPEC_FIELDS = (
15
+ "lambda_name",
16
+ "purpose",
17
+ "runtime_family",
18
+ "runtime",
19
+ "handler",
20
+ "trigger",
21
+ "input_schema",
22
+ "output_schema",
23
+ "environment_variables",
24
+ "iam_permissions",
25
+ "observability",
26
+ "timeout_seconds",
27
+ "memory_mb",
28
+ "deploy_strategy",
29
+ )
30
+ RUNTIME_FAMILIES = {"python", "nodejs"}
31
+ PYTHON_RUNTIMES = {"python3.11", "python3.12", "python3.13"}
32
+ NODE_RUNTIMES = {"nodejs20.x", "nodejs22.x"}
33
+ TRIGGERS = {"api-gateway", "eventbridge-schedule", "sqs", "sns", "s3-event", "manual-test-event"}
34
+ DEPLOY_STRATEGIES = {"sam", "serverless", "manual"}
35
+ ASYNC_TRIGGERS = {"eventbridge-schedule", "sqs", "sns", "s3-event"}
36
+ SECRET_NAME_PATTERN = re.compile(r"(SECRET|TOKEN|PASSWORD|PASS|API_KEY|PRIVATE_KEY)", re.IGNORECASE)
37
+ SECRET_ASSIGNMENT_PATTERN = re.compile(
38
+ r"\b(?:SECRET|TOKEN|PASSWORD|PASS|API_KEY|API_TOKEN|PRIVATE_KEY)\b\s*[:=]",
39
+ re.IGNORECASE,
40
+ )
41
+ KMS_OR_DYNAMIC_REFERENCE = re.compile(r"^(env:|ssm:|secretsmanager:|resolve:|\$\{|<.+>)")
42
+ KEBAB_CASE = re.compile(r"^[a-z0-9]+(?:-[a-z0-9]+)*$")
43
+ SLUG_PATTERN = re.compile(r"[^a-z0-9]+")
44
+ EXCLUDED_PACKAGE_PARTS = {".git", "__pycache__", ".pytest_cache", "node_modules", ".venv", "dist"}
45
+ EXCLUDED_PACKAGE_NAMES = {".env", ".DS_Store"}
46
+
47
+
48
+ class AwsLambdaBuilderError(RuntimeError):
49
+ """Raised when the builder cannot read or process an input spec."""
50
+
51
+
52
+ class AwsLambdaRepository:
53
+ def __init__(self, root: Path | None = None) -> None:
54
+ self.root = root or Path(__file__).resolve().parents[5]
55
+
56
+ def plan_lambda(self, *, spec_path: Path) -> dict[str, Any]:
57
+ spec = self.load_spec(spec_path)
58
+ spec_result = self.validate_spec(spec)
59
+ if spec_result["status"] != "ok":
60
+ return spec_result
61
+
62
+ normalized = self.normalize_spec(spec)
63
+ security = self.security_findings(normalized)
64
+ blocking = [finding for finding in security if finding["severity"] == "error"]
65
+ if blocking:
66
+ return {
67
+ "kind": "lambda-plan",
68
+ "status": "blocked",
69
+ "reason": "security_guardrail_failed",
70
+ "findings": blocking,
71
+ "write_policy": "read_only",
72
+ }
73
+
74
+ files = self.build_lambda_files(normalized)
75
+ return {
76
+ "kind": "lambda-plan",
77
+ "status": "ok",
78
+ "lambda": self.lambda_summary(normalized),
79
+ "runtime": normalized["runtime"],
80
+ "trigger": normalized["trigger"],
81
+ "write_policy": "read_only",
82
+ "planned_artifacts": self.public_file_plan(files),
83
+ "security_findings": security,
84
+ "questions": self.open_questions(normalized),
85
+ }
86
+
87
+ def generate_lambda_project(
88
+ self,
89
+ *,
90
+ spec_path: Path,
91
+ execute: bool = False,
92
+ allow_overwrite: bool = False,
93
+ ) -> dict[str, Any]:
94
+ plan = self.plan_lambda(spec_path=spec_path)
95
+ if plan["status"] != "ok":
96
+ return plan
97
+
98
+ spec = self.normalize_spec(self.load_spec(spec_path))
99
+ target_project = spec.get("target_project")
100
+ if not target_project:
101
+ return {
102
+ "kind": "lambda-project-files",
103
+ "status": "needs-input",
104
+ "missing_fields": ["target_project"],
105
+ "questions": ["Qual e o caminho do projeto destino?"],
106
+ }
107
+
108
+ target_root = Path(str(target_project)).expanduser().resolve()
109
+ files = self.build_lambda_files(spec, base_dir=spec["lambda_slug"])
110
+ return self.write_or_plan_files(
111
+ kind="lambda-project-files",
112
+ files=files,
113
+ target_root=target_root,
114
+ execute=execute,
115
+ allow_overwrite=allow_overwrite,
116
+ extra={"lambda": self.lambda_summary(spec), "runtime_family": spec["runtime_family"]},
117
+ )
118
+
119
+ def review_lambda_security(self, *, spec_path: Path) -> dict[str, Any]:
120
+ spec = self.load_spec(spec_path)
121
+ spec_result = self.validate_spec(spec)
122
+ if spec_result["status"] != "ok":
123
+ return spec_result
124
+ normalized = self.normalize_spec(spec)
125
+ findings = self.security_findings(normalized)
126
+ valid = not any(finding["severity"] == "error" for finding in findings)
127
+ return {
128
+ "kind": "lambda-security-review",
129
+ "status": "ok" if valid else "failed",
130
+ "valid": valid,
131
+ "findings": findings,
132
+ "write_policy": "read_only",
133
+ }
134
+
135
+ def package_lambda(
136
+ self,
137
+ *,
138
+ project_path: Path,
139
+ output_dir: Path | None = None,
140
+ execute: bool = False,
141
+ allow_overwrite: bool = False,
142
+ ) -> dict[str, Any]:
143
+ project_root = project_path.expanduser().resolve()
144
+ if not project_root.exists() or not project_root.is_dir():
145
+ return {
146
+ "kind": "lambda-package",
147
+ "status": "blocked",
148
+ "reason": "project_path_missing",
149
+ "project_path": str(project_root),
150
+ }
151
+
152
+ target_output_dir = (output_dir.expanduser().resolve() if output_dir else project_root / "dist")
153
+ if not self.is_inside(project_root, target_output_dir):
154
+ return {
155
+ "kind": "lambda-package",
156
+ "status": "blocked",
157
+ "reason": "output_dir_outside_project",
158
+ "project_path": str(project_root),
159
+ "output_dir": str(target_output_dir),
160
+ }
161
+
162
+ archive = target_output_dir / f"{project_root.name}.zip"
163
+ files = self.package_file_plan(project_root)
164
+ if not execute:
165
+ return {
166
+ "kind": "lambda-package",
167
+ "status": "planned",
168
+ "dry_run": True,
169
+ "project_path": str(project_root),
170
+ "archive_path": str(archive),
171
+ "file_count": len(files),
172
+ "files": [str(path.relative_to(project_root)) for path in files],
173
+ "write_policy": "local_write",
174
+ "next_steps": ["Rerun with --execute after reviewing package contents."],
175
+ }
176
+
177
+ if archive.exists() and not allow_overwrite:
178
+ return {
179
+ "kind": "lambda-package",
180
+ "status": "blocked",
181
+ "reason": "target_exists",
182
+ "archive_path": str(archive),
183
+ "next_steps": ["Rerun with --allow-overwrite only after reviewing existing archive."],
184
+ }
185
+
186
+ target_output_dir.mkdir(parents=True, exist_ok=True)
187
+ with zipfile.ZipFile(archive, "w", compression=zipfile.ZIP_DEFLATED) as package:
188
+ for path in files:
189
+ package.write(path, path.relative_to(project_root))
190
+
191
+ return {
192
+ "kind": "lambda-package",
193
+ "status": "written",
194
+ "dry_run": False,
195
+ "project_path": str(project_root),
196
+ "archive_path": str(archive),
197
+ "file_count": len(files),
198
+ "bytes": archive.stat().st_size,
199
+ "write_policy": "local_write",
200
+ }
201
+
202
+ def deploy_lambda_plan(self, *, spec_path: Path) -> dict[str, Any]:
203
+ plan = self.plan_lambda(spec_path=spec_path)
204
+ if plan["status"] != "ok":
205
+ return plan
206
+
207
+ spec = self.normalize_spec(self.load_spec(spec_path))
208
+ commands = self.deploy_commands(spec)
209
+ return {
210
+ "kind": "lambda-deploy-plan",
211
+ "status": "ok",
212
+ "deploy_real": False,
213
+ "lambda": self.lambda_summary(spec),
214
+ "deploy_strategy": spec["deploy_strategy"],
215
+ "write_policy": "dry_run",
216
+ "commands_to_review": commands,
217
+ "pre_requisites": [
218
+ "AWS credentials configured outside this agent.",
219
+ "SAM/Serverless installed when that deploy strategy is selected.",
220
+ "IAM reviewed and approved.",
221
+ "Environment variables resolved through env/SSM/Secrets Manager references.",
222
+ ],
223
+ "rollback": [
224
+ "Keep previous Lambda version or alias target before deployment.",
225
+ "Use CloudFormation/SAM rollback or reset alias to previous version.",
226
+ "Check CloudWatch logs and Lambda metrics after deployment.",
227
+ ],
228
+ "blocked_actions": ["aws cloudformation deploy", "sam deploy", "serverless deploy", "cdk deploy"],
229
+ }
230
+
231
+ def load_spec(self, path: Path) -> dict[str, Any]:
232
+ if not path.exists():
233
+ raise AwsLambdaBuilderError(f"spec not found: {path}")
234
+ text = path.read_text(encoding="utf-8")
235
+ if path.suffix.lower() == ".json":
236
+ payload = json.loads(text)
237
+ else:
238
+ payload = yaml.safe_load(text) or {}
239
+ if not isinstance(payload, dict):
240
+ raise AwsLambdaBuilderError("spec must be a mapping")
241
+ return payload
242
+
243
+ def validate_spec(self, spec: dict[str, Any]) -> dict[str, Any]:
244
+ missing = [field for field in REQUIRED_SPEC_FIELDS if field not in spec or spec.get(field) in (None, "")]
245
+ if missing:
246
+ return {
247
+ "kind": "lambda-plan",
248
+ "status": "needs-input",
249
+ "missing_fields": missing,
250
+ "questions": [self.question_for_missing_field(field) for field in missing],
251
+ }
252
+ for field in ("environment_variables", "iam_permissions"):
253
+ if not isinstance(spec.get(field), list):
254
+ return {
255
+ "kind": "lambda-plan",
256
+ "status": "blocked",
257
+ "reason": "invalid_list_field",
258
+ "field": field,
259
+ "risks": [f"{field} must be a list."],
260
+ }
261
+ for field in ("input_schema", "output_schema", "observability"):
262
+ if not isinstance(spec.get(field), dict):
263
+ return {
264
+ "kind": "lambda-plan",
265
+ "status": "blocked",
266
+ "reason": "invalid_mapping_field",
267
+ "field": field,
268
+ "risks": [f"{field} must be a mapping."],
269
+ }
270
+ runtime_family = str(spec.get("runtime_family") or "").strip().lower()
271
+ if runtime_family not in RUNTIME_FAMILIES:
272
+ return {
273
+ "kind": "lambda-plan",
274
+ "status": "blocked",
275
+ "reason": "unsupported_runtime_family",
276
+ "supported_values": sorted(RUNTIME_FAMILIES),
277
+ }
278
+ runtime = str(spec.get("runtime") or "").strip()
279
+ if runtime_family == "python" and runtime not in PYTHON_RUNTIMES:
280
+ return {"kind": "lambda-plan", "status": "blocked", "reason": "unsupported_runtime", "supported_values": sorted(PYTHON_RUNTIMES)}
281
+ if runtime_family == "nodejs" and runtime not in NODE_RUNTIMES:
282
+ return {"kind": "lambda-plan", "status": "blocked", "reason": "unsupported_runtime", "supported_values": sorted(NODE_RUNTIMES)}
283
+ trigger = str(spec.get("trigger") or "").strip()
284
+ if trigger not in TRIGGERS:
285
+ return {"kind": "lambda-plan", "status": "blocked", "reason": "unsupported_trigger", "supported_values": sorted(TRIGGERS)}
286
+ deploy_strategy = str(spec.get("deploy_strategy") or "").strip()
287
+ if deploy_strategy not in DEPLOY_STRATEGIES:
288
+ return {
289
+ "kind": "lambda-plan",
290
+ "status": "blocked",
291
+ "reason": "unsupported_deploy_strategy",
292
+ "supported_values": sorted(DEPLOY_STRATEGIES),
293
+ }
294
+ timeout_seconds = self.as_int(spec.get("timeout_seconds"), "timeout_seconds")
295
+ memory_mb = self.as_int(spec.get("memory_mb"), "memory_mb")
296
+ if not 1 <= timeout_seconds <= 900:
297
+ return {"kind": "lambda-plan", "status": "blocked", "reason": "invalid_timeout_seconds"}
298
+ if not 128 <= memory_mb <= 10240:
299
+ return {"kind": "lambda-plan", "status": "blocked", "reason": "invalid_memory_mb"}
300
+ return {"status": "ok"}
301
+
302
+ def normalize_spec(self, spec: dict[str, Any]) -> dict[str, Any]:
303
+ normalized = dict(spec)
304
+ normalized["lambda_name"] = " ".join(str(spec["lambda_name"]).split())
305
+ normalized["lambda_slug"] = self.slugify(normalized["lambda_name"])
306
+ normalized["purpose"] = " ".join(str(spec["purpose"]).split())
307
+ normalized["runtime_family"] = str(spec["runtime_family"]).strip().lower()
308
+ normalized["runtime"] = str(spec["runtime"]).strip()
309
+ normalized["handler"] = str(spec["handler"]).strip()
310
+ normalized["trigger"] = str(spec["trigger"]).strip()
311
+ normalized["input_schema"] = dict(spec["input_schema"])
312
+ normalized["output_schema"] = dict(spec["output_schema"])
313
+ normalized["environment_variables"] = [self.normalize_env_var(item) for item in spec["environment_variables"]]
314
+ normalized["iam_permissions"] = [self.normalize_iam_permission(item) for item in spec["iam_permissions"]]
315
+ normalized["observability"] = dict(spec["observability"])
316
+ normalized["timeout_seconds"] = self.as_int(spec["timeout_seconds"], "timeout_seconds")
317
+ normalized["memory_mb"] = self.as_int(spec["memory_mb"], "memory_mb")
318
+ normalized["deploy_strategy"] = str(spec["deploy_strategy"]).strip()
319
+ if spec.get("target_project"):
320
+ normalized["target_project"] = str(spec["target_project"]).strip()
321
+ return normalized
322
+
323
+ def security_findings(self, spec: dict[str, Any]) -> list[dict[str, Any]]:
324
+ findings: list[dict[str, Any]] = []
325
+ for key, value in self.iter_key_values(spec):
326
+ if isinstance(value, str) and SECRET_ASSIGNMENT_PATTERN.search(value):
327
+ findings.append({"severity": "error", "code": "hardcoded_secret_marker", "field": key})
328
+
329
+ for env_var in spec["environment_variables"]:
330
+ name = env_var["name"]
331
+ value = env_var["value"]
332
+ if SECRET_NAME_PATTERN.search(name) and value and not KMS_OR_DYNAMIC_REFERENCE.search(value):
333
+ findings.append({"severity": "error", "code": "hardcoded_secret_env_value", "env": name})
334
+
335
+ for permission in spec["iam_permissions"]:
336
+ action = permission["action"]
337
+ resource = permission["resource"]
338
+ justification = permission["justification"]
339
+ if (action == "*" or action.endswith(":*")) and not justification:
340
+ findings.append({"severity": "error", "code": "iam_action_wildcard_without_justification", "action": action})
341
+ if resource == "*":
342
+ findings.append({"severity": "warning", "code": "iam_resource_wildcard", "action": action})
343
+
344
+ if spec["trigger"] in ASYNC_TRIGGERS and not spec["observability"].get("dlq_or_destination"):
345
+ findings.append({"severity": "warning", "code": "missing_dlq_or_destination", "trigger": spec["trigger"]})
346
+ if not spec["observability"].get("structured_logging"):
347
+ findings.append({"severity": "warning", "code": "structured_logging_not_declared"})
348
+ return findings
349
+
350
+ def build_lambda_files(self, spec: dict[str, Any], *, base_dir: str = "") -> list[tuple[str, str]]:
351
+ prefix = f"{base_dir}/" if base_dir else ""
352
+ if spec["runtime_family"] == "python":
353
+ runtime_files = [
354
+ (f"{prefix}src/handler.py", self.render_python_handler(spec)),
355
+ (f"{prefix}tests/test_handler.py", self.render_python_test(spec)),
356
+ (f"{prefix}requirements.txt", "# Add runtime dependencies here.\n"),
357
+ ]
358
+ else:
359
+ runtime_files = [
360
+ (f"{prefix}src/handler.js", self.render_node_handler(spec)),
361
+ (f"{prefix}tests/handler.test.js", self.render_node_test(spec)),
362
+ (f"{prefix}package.json", self.render_package_json(spec)),
363
+ ]
364
+ return [
365
+ *runtime_files,
366
+ (f"{prefix}events/{spec['trigger']}.json", self.render_event_fixture(spec)),
367
+ (f"{prefix}template.yaml", self.render_sam_template(spec)),
368
+ (f"{prefix}README.md", self.render_readme(spec)),
369
+ ]
370
+
371
+ def write_or_plan_files(
372
+ self,
373
+ *,
374
+ kind: str,
375
+ files: list[tuple[str, str]],
376
+ target_root: Path,
377
+ execute: bool,
378
+ allow_overwrite: bool,
379
+ extra: dict[str, Any],
380
+ ) -> dict[str, Any]:
381
+ if not target_root.exists() or not target_root.is_dir():
382
+ return {"kind": kind, "status": "blocked", "reason": "target_project_missing", "target_project": str(target_root)}
383
+
384
+ checked_files = []
385
+ for relative_path, content in files:
386
+ target = (target_root / relative_path).resolve()
387
+ if Path(relative_path).is_absolute() or not self.is_inside(target_root, target):
388
+ return {"kind": kind, "status": "blocked", "reason": "path_outside_target_project", "path": relative_path}
389
+ checked_files.append((relative_path, target, content))
390
+
391
+ if not execute:
392
+ return {
393
+ "kind": kind,
394
+ "status": "planned",
395
+ "dry_run": True,
396
+ "target_project": str(target_root),
397
+ "planned_files": [
398
+ {"path": relative_path, "absolute_path": str(target), "bytes": len(content.encode("utf-8"))}
399
+ for relative_path, target, content in checked_files
400
+ ],
401
+ **extra,
402
+ "next_steps": ["Rerun with --execute after reviewing the planned files."],
403
+ }
404
+
405
+ existing = [target for _relative_path, target, _content in checked_files if target.exists()]
406
+ if existing and not allow_overwrite:
407
+ return {
408
+ "kind": kind,
409
+ "status": "blocked",
410
+ "reason": "target_exists",
411
+ "existing_files": [str(path) for path in existing],
412
+ **extra,
413
+ }
414
+
415
+ written_files = []
416
+ for _relative_path, target, content in checked_files:
417
+ target.parent.mkdir(parents=True, exist_ok=True)
418
+ target.write_text(content, encoding="utf-8")
419
+ written_files.append({"path": str(target), "bytes": len(content.encode("utf-8"))})
420
+ return {"kind": kind, "status": "written", "dry_run": False, "written_files": written_files, **extra}
421
+
422
+ def render_python_handler(self, spec: dict[str, Any]) -> str:
423
+ return "\n".join(
424
+ [
425
+ '"""AWS Lambda handler generated by aws-lambda-builder."""',
426
+ "",
427
+ "from __future__ import annotations",
428
+ "",
429
+ "import json",
430
+ "import logging",
431
+ "import os",
432
+ "from typing import Any",
433
+ "",
434
+ "logger = logging.getLogger()",
435
+ "logger.setLevel(logging.INFO)",
436
+ "",
437
+ "",
438
+ "def lambda_handler(event: dict[str, Any], context: Any) -> dict[str, Any]:",
439
+ " request_id = getattr(context, \"aws_request_id\", \"local\")",
440
+ " logger.info(json.dumps({\"message\": \"lambda_started\", \"request_id\": request_id}))",
441
+ " response = {",
442
+ f" \"lambda\": {spec['lambda_slug']!r},",
443
+ " \"request_id\": request_id,",
444
+ " \"received_keys\": sorted(event.keys()) if isinstance(event, dict) else [],",
445
+ " \"configured_env\": sorted(key for key in os.environ if key.startswith(\"APP_\")),",
446
+ " }",
447
+ " return {\"statusCode\": 200, \"body\": json.dumps(response)}",
448
+ "",
449
+ ]
450
+ )
451
+
452
+ def render_python_test(self, spec: dict[str, Any]) -> str:
453
+ return "\n".join(
454
+ [
455
+ "import json",
456
+ "import sys",
457
+ "from pathlib import Path",
458
+ "",
459
+ "sys.path.insert(0, str(Path(__file__).resolve().parents[1] / \"src\"))",
460
+ "from handler import lambda_handler",
461
+ "",
462
+ "",
463
+ "class Context:",
464
+ " aws_request_id = \"test-request\"",
465
+ "",
466
+ "",
467
+ "def test_lambda_handler_returns_success():",
468
+ f" event = json.loads((Path(__file__).resolve().parents[1] / \"events\" / {spec['trigger']!r}).read_text())",
469
+ " result = lambda_handler(event, Context())",
470
+ " assert result[\"statusCode\"] == 200",
471
+ " body = json.loads(result[\"body\"])",
472
+ f" assert body[\"lambda\"] == {spec['lambda_slug']!r}",
473
+ "",
474
+ ]
475
+ )
476
+
477
+ def render_node_handler(self, spec: dict[str, Any]) -> str:
478
+ return "\n".join(
479
+ [
480
+ "\"use strict\";",
481
+ "",
482
+ "exports.handler = async function handler(event, context) {",
483
+ " const requestId = context && context.awsRequestId ? context.awsRequestId : \"local\";",
484
+ " console.log(JSON.stringify({ message: \"lambda_started\", request_id: requestId }));",
485
+ " const body = {",
486
+ f" lambda: {json.dumps(spec['lambda_slug'])},",
487
+ " request_id: requestId,",
488
+ " received_keys: event && typeof event === \"object\" ? Object.keys(event).sort() : [],",
489
+ " configured_env: Object.keys(process.env).filter((key) => key.startsWith(\"APP_\")).sort()",
490
+ " };",
491
+ " return { statusCode: 200, body: JSON.stringify(body) };",
492
+ "};",
493
+ "",
494
+ ]
495
+ )
496
+
497
+ def render_node_test(self, spec: dict[str, Any]) -> str:
498
+ return "\n".join(
499
+ [
500
+ "\"use strict\";",
501
+ "",
502
+ "const assert = require(\"node:assert\");",
503
+ "const fs = require(\"node:fs\");",
504
+ "const path = require(\"node:path\");",
505
+ "const { handler } = require(\"../src/handler\");",
506
+ "",
507
+ "(async () => {",
508
+ f" const event = JSON.parse(fs.readFileSync(path.join(__dirname, \"..\", \"events\", {json.dumps(spec['trigger'])})));",
509
+ " const result = await handler(event, { awsRequestId: \"test-request\" });",
510
+ " assert.equal(result.statusCode, 200);",
511
+ " const body = JSON.parse(result.body);",
512
+ f" assert.equal(body.lambda, {json.dumps(spec['lambda_slug'])});",
513
+ "})();",
514
+ "",
515
+ ]
516
+ )
517
+
518
+ def render_package_json(self, spec: dict[str, Any]) -> str:
519
+ return json.dumps(
520
+ {
521
+ "name": spec["lambda_slug"],
522
+ "version": "0.1.0",
523
+ "private": True,
524
+ "type": "commonjs",
525
+ "scripts": {"test": "node tests/handler.test.js"},
526
+ },
527
+ indent=2,
528
+ ) + "\n"
529
+
530
+ def render_event_fixture(self, spec: dict[str, Any]) -> str:
531
+ fixtures = {
532
+ "api-gateway": {"requestContext": {"requestId": "local-request"}, "body": "{\"message\":\"hello\"}", "httpMethod": "POST"},
533
+ "eventbridge-schedule": {"source": "aws.events", "detail-type": "Scheduled Event", "detail": {}},
534
+ "sqs": {"Records": [{"messageId": "local-message", "body": "{\"message\":\"hello\"}"}]},
535
+ "sns": {"Records": [{"Sns": {"Message": "{\"message\":\"hello\"}"}}]},
536
+ "s3-event": {"Records": [{"s3": {"bucket": {"name": "example-bucket"}, "object": {"key": "example.txt"}}}]},
537
+ "manual-test-event": {"message": "hello"},
538
+ }
539
+ return json.dumps(fixtures[spec["trigger"]], indent=2) + "\n"
540
+
541
+ def render_sam_template(self, spec: dict[str, Any]) -> str:
542
+ env_vars = {item["name"]: item["value"] for item in spec["environment_variables"]}
543
+ events = self.sam_event(spec)
544
+ template = {
545
+ "AWSTemplateFormatVersion": "2010-09-09",
546
+ "Transform": "AWS::Serverless-2016-10-31",
547
+ "Description": spec["purpose"],
548
+ "Resources": {
549
+ "LambdaFunction": {
550
+ "Type": "AWS::Serverless::Function",
551
+ "Properties": {
552
+ "FunctionName": spec["lambda_slug"],
553
+ "Runtime": spec["runtime"],
554
+ "Handler": spec["handler"],
555
+ "CodeUri": "src/",
556
+ "Timeout": spec["timeout_seconds"],
557
+ "MemorySize": spec["memory_mb"],
558
+ "Environment": {"Variables": env_vars},
559
+ "Policies": [{"Statement": [self.iam_statement(permission) for permission in spec["iam_permissions"]]}],
560
+ "Events": events,
561
+ },
562
+ }
563
+ },
564
+ }
565
+ return yaml.safe_dump(template, sort_keys=False, allow_unicode=False)
566
+
567
+ def render_readme(self, spec: dict[str, Any]) -> str:
568
+ return "\n".join(
569
+ [
570
+ f"# {spec['lambda_name']}",
571
+ "",
572
+ spec["purpose"],
573
+ "",
574
+ "## Local Test",
575
+ "",
576
+ "```bash",
577
+ "python -m pytest tests",
578
+ "npm test",
579
+ "```",
580
+ "",
581
+ "Run only the command that matches the generated runtime.",
582
+ "",
583
+ "## Deploy",
584
+ "",
585
+ "Deploy real is not performed by aws-lambda-builder. Use deploy-lambda-plan to review commands and checklist.",
586
+ "",
587
+ "## Security",
588
+ "",
589
+ "- Review IAM before deploy.",
590
+ "- Resolve secrets through environment references, SSM or Secrets Manager.",
591
+ "- Do not commit `.env` files.",
592
+ "",
593
+ ]
594
+ )
595
+
596
+ def sam_event(self, spec: dict[str, Any]) -> dict[str, Any]:
597
+ trigger = spec["trigger"]
598
+ if trigger == "api-gateway":
599
+ return {"ApiEvent": {"Type": "Api", "Properties": {"Path": "/", "Method": "post"}}}
600
+ if trigger == "eventbridge-schedule":
601
+ return {"ScheduleEvent": {"Type": "Schedule", "Properties": {"Schedule": "rate(5 minutes)"}}}
602
+ if trigger == "sqs":
603
+ return {"SQSEvent": {"Type": "SQS", "Properties": {"Queue": "<queue-arn>"}}}
604
+ if trigger == "sns":
605
+ return {"SNSEvent": {"Type": "SNS", "Properties": {"Topic": "<topic-arn>"}}}
606
+ if trigger == "s3-event":
607
+ return {"S3Event": {"Type": "S3", "Properties": {"Bucket": "<bucket-name>", "Events": "s3:ObjectCreated:*"}}}
608
+ return {"ManualTestEvent": {"Type": "Schedule", "Properties": {"Schedule": "rate(365 days)", "Enabled": False}}}
609
+
610
+ def iam_statement(self, permission: dict[str, str]) -> dict[str, str]:
611
+ return {"Effect": "Allow", "Action": permission["action"], "Resource": permission["resource"]}
612
+
613
+ def deploy_commands(self, spec: dict[str, Any]) -> list[str]:
614
+ if spec["deploy_strategy"] == "sam":
615
+ return ["sam build", "sam deploy --guided"]
616
+ if spec["deploy_strategy"] == "serverless":
617
+ return ["serverless package", "serverless deploy"]
618
+ return ["zip package locally", "review template.yaml", "deploy manually after separate approval"]
619
+
620
+ def package_file_plan(self, project_root: Path) -> list[Path]:
621
+ files: list[Path] = []
622
+ for path in sorted(project_root.rglob("*")):
623
+ if not path.is_file():
624
+ continue
625
+ relative = path.relative_to(project_root)
626
+ if any(part in EXCLUDED_PACKAGE_PARTS for part in relative.parts):
627
+ continue
628
+ if path.name in EXCLUDED_PACKAGE_NAMES or path.suffix == ".pyc":
629
+ continue
630
+ files.append(path)
631
+ return files
632
+
633
+ def lambda_summary(self, spec: dict[str, Any]) -> dict[str, Any]:
634
+ return {"name": spec["lambda_name"], "slug": spec["lambda_slug"], "purpose": spec["purpose"]}
635
+
636
+ def public_file_plan(self, files: list[tuple[str, str]]) -> list[dict[str, Any]]:
637
+ return [{"path": path, "bytes": len(content.encode("utf-8"))} for path, content in files]
638
+
639
+ def open_questions(self, spec: dict[str, Any]) -> list[str]:
640
+ questions: list[str] = []
641
+ if spec["trigger"] in ASYNC_TRIGGERS and not spec["observability"].get("dlq_or_destination"):
642
+ questions.append("Qual DLQ ou destination deve ser usada para falhas assíncronas?")
643
+ if any(permission["resource"] == "*" for permission in spec["iam_permissions"]):
644
+ questions.append("Quais ARNs concretos podem substituir resource `*` antes do deploy?")
645
+ return questions
646
+
647
+ def normalize_env_var(self, value: Any) -> dict[str, str]:
648
+ if not isinstance(value, dict):
649
+ return {"name": str(value), "value": ""}
650
+ return {"name": str(value.get("name") or "").strip(), "value": str(value.get("value") or "").strip()}
651
+
652
+ def normalize_iam_permission(self, value: Any) -> dict[str, str]:
653
+ if not isinstance(value, dict):
654
+ return {"action": str(value), "resource": "*", "justification": ""}
655
+ return {
656
+ "action": str(value.get("action") or "").strip(),
657
+ "resource": str(value.get("resource") or "").strip(),
658
+ "justification": str(value.get("justification") or "").strip(),
659
+ }
660
+
661
+ def question_for_missing_field(self, field: str) -> str:
662
+ return f"Informe `{field}` para planejar a Lambda."
663
+
664
+ def as_int(self, value: Any, field: str) -> int:
665
+ try:
666
+ return int(value)
667
+ except (TypeError, ValueError) as exc:
668
+ raise AwsLambdaBuilderError(f"{field} must be an integer") from exc
669
+
670
+ def slugify(self, value: str) -> str:
671
+ slug = SLUG_PATTERN.sub("-", value.lower()).strip("-")
672
+ return slug or "lambda-function"
673
+
674
+ def iter_key_values(self, value: Any):
675
+ if isinstance(value, dict):
676
+ for key, child in value.items():
677
+ yield str(key), child
678
+ yield from self.iter_key_values(child)
679
+ elif isinstance(value, list):
680
+ for child in value:
681
+ yield from self.iter_key_values(child)
682
+
683
+ def is_inside(self, root: Path, target: Path) -> bool:
684
+ try:
685
+ target.relative_to(root.resolve())
686
+ return True
687
+ except ValueError:
688
+ return False