@shepai/cli 1.174.0 → 1.175.0-pr527.9ada632

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 (502) hide show
  1. package/apis/json-schema/ActionDispositionEntry.yaml +14 -0
  2. package/apis/json-schema/DependencyFinding.yaml +28 -0
  3. package/apis/json-schema/DependencyRiskType.yaml +11 -0
  4. package/apis/json-schema/DependencyRules.yaml +38 -0
  5. package/apis/json-schema/EffectivePolicySnapshot.yaml +24 -0
  6. package/apis/json-schema/ReleaseIntegrityCheck.yaml +22 -0
  7. package/apis/json-schema/ReleaseIntegrityCheckType.yaml +9 -0
  8. package/apis/json-schema/ReleaseIntegrityResult.yaml +16 -0
  9. package/apis/json-schema/ReleaseRules.yaml +21 -0
  10. package/apis/json-schema/Repository.yaml +6 -0
  11. package/apis/json-schema/SecurityActionCategory.yaml +10 -0
  12. package/apis/json-schema/SecurityActionDisposition.yaml +8 -0
  13. package/apis/json-schema/SecurityConfig.yaml +17 -0
  14. package/apis/json-schema/SecurityEvent.yaml +36 -0
  15. package/apis/json-schema/SecurityMode.yaml +8 -0
  16. package/apis/json-schema/SecurityPolicy.yaml +24 -0
  17. package/apis/json-schema/SecuritySeverity.yaml +9 -0
  18. package/apis/json-schema/Settings.yaml +3 -0
  19. package/dist/packages/core/src/application/ports/output/agents/agent-executor.interface.d.ts +15 -1
  20. package/dist/packages/core/src/application/ports/output/agents/agent-executor.interface.d.ts.map +1 -1
  21. package/dist/packages/core/src/application/ports/output/agents/feature-agent-process.interface.d.ts +3 -1
  22. package/dist/packages/core/src/application/ports/output/agents/feature-agent-process.interface.d.ts.map +1 -1
  23. package/dist/packages/core/src/application/ports/output/repositories/repository-repository.interface.d.ts +3 -1
  24. package/dist/packages/core/src/application/ports/output/repositories/repository-repository.interface.d.ts.map +1 -1
  25. package/dist/packages/core/src/application/ports/output/repositories/security-event.repository.interface.d.ts +76 -0
  26. package/dist/packages/core/src/application/ports/output/repositories/security-event.repository.interface.d.ts.map +1 -0
  27. package/dist/packages/core/src/application/ports/output/repositories/security-event.repository.interface.js +11 -0
  28. package/dist/packages/core/src/application/ports/output/services/git-pr-service.interface.d.ts +28 -0
  29. package/dist/packages/core/src/application/ports/output/services/git-pr-service.interface.d.ts.map +1 -1
  30. package/dist/packages/core/src/application/ports/output/services/git-pr-service.interface.js +2 -0
  31. package/dist/packages/core/src/application/ports/output/services/github-repository-service.interface.d.ts +85 -0
  32. package/dist/packages/core/src/application/ports/output/services/github-repository-service.interface.d.ts.map +1 -1
  33. package/dist/packages/core/src/application/ports/output/services/github-repository-service.interface.js +21 -0
  34. package/dist/packages/core/src/application/ports/output/services/security-policy-service.interface.d.ts +77 -0
  35. package/dist/packages/core/src/application/ports/output/services/security-policy-service.interface.d.ts.map +1 -0
  36. package/dist/packages/core/src/application/ports/output/services/security-policy-service.interface.js +13 -0
  37. package/dist/packages/core/src/application/ports/output/services/spec-initializer.interface.d.ts +11 -0
  38. package/dist/packages/core/src/application/ports/output/services/spec-initializer.interface.d.ts.map +1 -1
  39. package/dist/packages/core/src/application/use-cases/agents/approve-agent-run.use-case.d.ts.map +1 -1
  40. package/dist/packages/core/src/application/use-cases/agents/approve-agent-run.use-case.js +2 -0
  41. package/dist/packages/core/src/application/use-cases/agents/reject-agent-run.use-case.d.ts.map +1 -1
  42. package/dist/packages/core/src/application/use-cases/agents/reject-agent-run.use-case.js +2 -0
  43. package/dist/packages/core/src/application/use-cases/features/check-and-unblock-features.use-case.d.ts.map +1 -1
  44. package/dist/packages/core/src/application/use-cases/features/check-and-unblock-features.use-case.js +2 -0
  45. package/dist/packages/core/src/application/use-cases/features/create/create-feature-from-remote.use-case.d.ts +67 -0
  46. package/dist/packages/core/src/application/use-cases/features/create/create-feature-from-remote.use-case.d.ts.map +1 -0
  47. package/dist/packages/core/src/application/use-cases/features/create/create-feature-from-remote.use-case.js +128 -0
  48. package/dist/packages/core/src/application/use-cases/features/create/create-feature.use-case.d.ts.map +1 -1
  49. package/dist/packages/core/src/application/use-cases/features/create/create-feature.use-case.js +1 -0
  50. package/dist/packages/core/src/application/use-cases/features/resume-feature.use-case.d.ts.map +1 -1
  51. package/dist/packages/core/src/application/use-cases/features/resume-feature.use-case.js +2 -0
  52. package/dist/packages/core/src/application/use-cases/features/start-feature.use-case.d.ts.map +1 -1
  53. package/dist/packages/core/src/application/use-cases/features/start-feature.use-case.js +2 -0
  54. package/dist/packages/core/src/application/use-cases/repositories/import-github-repository.use-case.d.ts +16 -5
  55. package/dist/packages/core/src/application/use-cases/repositories/import-github-repository.use-case.d.ts.map +1 -1
  56. package/dist/packages/core/src/application/use-cases/repositories/import-github-repository.use-case.js +76 -14
  57. package/dist/packages/core/src/application/use-cases/repositories/init-remote-repository.use-case.d.ts +30 -0
  58. package/dist/packages/core/src/application/use-cases/repositories/init-remote-repository.use-case.d.ts.map +1 -0
  59. package/dist/packages/core/src/application/use-cases/repositories/init-remote-repository.use-case.js +51 -0
  60. package/dist/packages/core/src/application/use-cases/security/enforce-security.use-case.d.ts +71 -0
  61. package/dist/packages/core/src/application/use-cases/security/enforce-security.use-case.d.ts.map +1 -0
  62. package/dist/packages/core/src/application/use-cases/security/enforce-security.use-case.js +215 -0
  63. package/dist/packages/core/src/application/use-cases/security/evaluate-security-policy.use-case.d.ts +24 -0
  64. package/dist/packages/core/src/application/use-cases/security/evaluate-security-policy.use-case.d.ts.map +1 -0
  65. package/dist/packages/core/src/application/use-cases/security/evaluate-security-policy.use-case.js +56 -0
  66. package/dist/packages/core/src/application/use-cases/security/get-security-state.use-case.d.ts +36 -0
  67. package/dist/packages/core/src/application/use-cases/security/get-security-state.use-case.d.ts.map +1 -0
  68. package/dist/packages/core/src/application/use-cases/security/get-security-state.use-case.js +76 -0
  69. package/dist/packages/core/src/application/use-cases/security/record-security-event.use-case.d.ts +14 -0
  70. package/dist/packages/core/src/application/use-cases/security/record-security-event.use-case.d.ts.map +1 -0
  71. package/dist/packages/core/src/application/use-cases/security/record-security-event.use-case.js +46 -0
  72. package/dist/packages/core/src/domain/errors/security-violation.error.d.ts +15 -0
  73. package/dist/packages/core/src/domain/errors/security-violation.error.d.ts.map +1 -0
  74. package/dist/packages/core/src/domain/errors/security-violation.error.js +20 -0
  75. package/dist/packages/core/src/domain/factories/settings-defaults.factory.d.ts.map +1 -1
  76. package/dist/packages/core/src/domain/factories/settings-defaults.factory.js +5 -1
  77. package/dist/packages/core/src/domain/generated/output.d.ts +267 -0
  78. package/dist/packages/core/src/domain/generated/output.d.ts.map +1 -1
  79. package/dist/packages/core/src/domain/generated/output.js +43 -0
  80. package/dist/packages/core/src/infrastructure/di/container.d.ts.map +1 -1
  81. package/dist/packages/core/src/infrastructure/di/container.js +67 -0
  82. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/repository.mapper.d.ts +2 -0
  83. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/repository.mapper.d.ts.map +1 -1
  84. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/repository.mapper.js +4 -0
  85. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/security-event.mapper.d.ts +44 -0
  86. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/security-event.mapper.d.ts.map +1 -0
  87. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/security-event.mapper.js +55 -0
  88. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.d.ts +3 -0
  89. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.d.ts.map +1 -1
  90. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.js +14 -0
  91. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/053-add-security-settings-columns.d.ts +18 -0
  92. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/053-add-security-settings-columns.d.ts.map +1 -0
  93. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/053-add-security-settings-columns.js +31 -0
  94. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/054-create-security-events-table.d.ts +29 -0
  95. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/054-create-security-events-table.d.ts.map +1 -0
  96. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/054-create-security-events-table.js +53 -0
  97. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/055-add-repository-fork-fields.d.ts +12 -0
  98. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/055-add-repository-fork-fields.d.ts.map +1 -0
  99. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/055-add-repository-fork-fields.js +26 -0
  100. package/dist/packages/core/src/infrastructure/repositories/sqlite-repository.repository.d.ts +2 -1
  101. package/dist/packages/core/src/infrastructure/repositories/sqlite-repository.repository.d.ts.map +1 -1
  102. package/dist/packages/core/src/infrastructure/repositories/sqlite-repository.repository.js +14 -0
  103. package/dist/packages/core/src/infrastructure/repositories/sqlite-security-event.repository.d.ts +24 -0
  104. package/dist/packages/core/src/infrastructure/repositories/sqlite-security-event.repository.d.ts.map +1 -0
  105. package/dist/packages/core/src/infrastructure/repositories/sqlite-security-event.repository.js +96 -0
  106. package/dist/packages/core/src/infrastructure/repositories/sqlite-settings.repository.d.ts.map +1 -1
  107. package/dist/packages/core/src/infrastructure/repositories/sqlite-settings.repository.js +12 -3
  108. package/dist/packages/core/src/infrastructure/services/agents/common/executors/claude-code-executor.service.d.ts +2 -0
  109. package/dist/packages/core/src/infrastructure/services/agents/common/executors/claude-code-executor.service.d.ts.map +1 -1
  110. package/dist/packages/core/src/infrastructure/services/agents/common/executors/claude-code-executor.service.js +12 -0
  111. package/dist/packages/core/src/infrastructure/services/agents/common/executors/security-constraint-validator.d.ts +22 -0
  112. package/dist/packages/core/src/infrastructure/services/agents/common/executors/security-constraint-validator.d.ts.map +1 -0
  113. package/dist/packages/core/src/infrastructure/services/agents/common/executors/security-constraint-validator.js +30 -0
  114. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/fast-feature-agent-graph.d.ts +10 -0
  115. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/fast-feature-agent-graph.d.ts.map +1 -1
  116. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-graph.d.ts +34 -0
  117. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-graph.d.ts.map +1 -1
  118. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-process.service.d.ts +3 -1
  119. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-process.service.d.ts.map +1 -1
  120. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-process.service.js +7 -1
  121. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-worker.d.ts +3 -1
  122. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-worker.d.ts.map +1 -1
  123. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-worker.js +32 -1
  124. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/node-helpers.d.ts.map +1 -1
  125. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/node-helpers.js +19 -0
  126. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/security-pre-check.d.ts +45 -0
  127. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/security-pre-check.d.ts.map +1 -0
  128. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/security-pre-check.js +70 -0
  129. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/state.d.ts +4 -1
  130. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/state.d.ts.map +1 -1
  131. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/state.js +10 -0
  132. package/dist/packages/core/src/infrastructure/services/external/github-repository.service.d.ts +13 -1
  133. package/dist/packages/core/src/infrastructure/services/external/github-repository.service.d.ts.map +1 -1
  134. package/dist/packages/core/src/infrastructure/services/external/github-repository.service.js +155 -1
  135. package/dist/packages/core/src/infrastructure/services/git/git-pr.service.d.ts +15 -0
  136. package/dist/packages/core/src/infrastructure/services/git/git-pr.service.d.ts.map +1 -1
  137. package/dist/packages/core/src/infrastructure/services/git/git-pr.service.js +62 -0
  138. package/dist/packages/core/src/infrastructure/services/security/dependency-risk-evaluator.d.ts +53 -0
  139. package/dist/packages/core/src/infrastructure/services/security/dependency-risk-evaluator.d.ts.map +1 -0
  140. package/dist/packages/core/src/infrastructure/services/security/dependency-risk-evaluator.js +241 -0
  141. package/dist/packages/core/src/infrastructure/services/security/release-integrity-evaluator.d.ts +44 -0
  142. package/dist/packages/core/src/infrastructure/services/security/release-integrity-evaluator.d.ts.map +1 -0
  143. package/dist/packages/core/src/infrastructure/services/security/release-integrity-evaluator.js +194 -0
  144. package/dist/packages/core/src/infrastructure/services/security/security-policy-file-reader.d.ts +28 -0
  145. package/dist/packages/core/src/infrastructure/services/security/security-policy-file-reader.d.ts.map +1 -0
  146. package/dist/packages/core/src/infrastructure/services/security/security-policy-file-reader.js +50 -0
  147. package/dist/packages/core/src/infrastructure/services/security/security-policy-validator.d.ts +26 -0
  148. package/dist/packages/core/src/infrastructure/services/security/security-policy-validator.d.ts.map +1 -0
  149. package/dist/packages/core/src/infrastructure/services/security/security-policy-validator.js +147 -0
  150. package/dist/packages/core/src/infrastructure/services/security/security-policy.service.d.ts +44 -0
  151. package/dist/packages/core/src/infrastructure/services/security/security-policy.service.d.ts.map +1 -0
  152. package/dist/packages/core/src/infrastructure/services/security/security-policy.service.js +174 -0
  153. package/dist/packages/core/src/infrastructure/services/spec/spec-initializer.service.d.ts +1 -0
  154. package/dist/packages/core/src/infrastructure/services/spec/spec-initializer.service.d.ts.map +1 -1
  155. package/dist/packages/core/src/infrastructure/services/spec/spec-initializer.service.js +61 -0
  156. package/dist/src/presentation/cli/commands/feat/new.command.d.ts.map +1 -1
  157. package/dist/src/presentation/cli/commands/feat/new.command.js +32 -6
  158. package/dist/src/presentation/cli/commands/repo/index.d.ts.map +1 -1
  159. package/dist/src/presentation/cli/commands/repo/index.js +3 -1
  160. package/dist/src/presentation/cli/commands/repo/init-remote.command.d.ts +15 -0
  161. package/dist/src/presentation/cli/commands/repo/init-remote.command.d.ts.map +1 -0
  162. package/dist/src/presentation/cli/commands/repo/init-remote.command.js +44 -0
  163. package/dist/src/presentation/cli/commands/security.command.d.ts +16 -0
  164. package/dist/src/presentation/cli/commands/security.command.d.ts.map +1 -0
  165. package/dist/src/presentation/cli/commands/security.command.js +118 -0
  166. package/dist/src/presentation/cli/index.js +2 -0
  167. package/dist/src/presentation/web/app/(dashboard)/get-graph-data.d.ts.map +1 -1
  168. package/dist/src/presentation/web/app/(dashboard)/get-graph-data.js +2 -1
  169. package/dist/src/presentation/web/app/actions/create-feature-from-remote.d.ts +31 -0
  170. package/dist/src/presentation/web/app/actions/create-feature-from-remote.d.ts.map +1 -0
  171. package/dist/src/presentation/web/app/actions/create-feature-from-remote.js +69 -0
  172. package/dist/src/presentation/web/app/actions/import-github-repository.d.ts +1 -0
  173. package/dist/src/presentation/web/app/actions/import-github-repository.d.ts.map +1 -1
  174. package/dist/src/presentation/web/app/actions/import-github-repository.js +1 -1
  175. package/dist/src/presentation/web/app/actions/security.d.ts +28 -0
  176. package/dist/src/presentation/web/app/actions/security.d.ts.map +1 -0
  177. package/dist/src/presentation/web/app/actions/security.js +59 -0
  178. package/dist/src/presentation/web/app/build-graph-nodes.d.ts +3 -1
  179. package/dist/src/presentation/web/app/build-graph-nodes.d.ts.map +1 -1
  180. package/dist/src/presentation/web/app/build-graph-nodes.js +2 -0
  181. package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.d.ts +2 -0
  182. package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.d.ts.map +1 -1
  183. package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.js +1 -1
  184. package/dist/src/presentation/web/components/common/feature-create-drawer/repository-combobox.stories.d.ts +2 -0
  185. package/dist/src/presentation/web/components/common/feature-create-drawer/repository-combobox.stories.d.ts.map +1 -1
  186. package/dist/src/presentation/web/components/common/feature-create-drawer/repository-combobox.stories.js +22 -0
  187. package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.d.ts +3 -1
  188. package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.d.ts.map +1 -1
  189. package/dist/src/presentation/web/components/common/feature-node/feature-node.d.ts.map +1 -1
  190. package/dist/src/presentation/web/components/common/feature-node/feature-node.js +2 -1
  191. package/dist/src/presentation/web/components/common/repository-node/repository-drawer.d.ts +3 -1
  192. package/dist/src/presentation/web/components/common/repository-node/repository-drawer.d.ts.map +1 -1
  193. package/dist/src/presentation/web/components/common/repository-node/repository-drawer.js +3 -2
  194. package/dist/src/presentation/web/components/common/repository-node/security-panel.d.ts +6 -0
  195. package/dist/src/presentation/web/components/common/repository-node/security-panel.d.ts.map +1 -0
  196. package/dist/src/presentation/web/components/common/repository-node/security-panel.js +29 -0
  197. package/dist/src/presentation/web/components/common/repository-node/security-panel.stories.d.ts +10 -0
  198. package/dist/src/presentation/web/components/common/repository-node/security-panel.stories.d.ts.map +1 -0
  199. package/dist/src/presentation/web/components/common/repository-node/security-panel.stories.js +53 -0
  200. package/dist/src/presentation/web/components/common/security-badge.d.ts +7 -0
  201. package/dist/src/presentation/web/components/common/security-badge.d.ts.map +1 -0
  202. package/dist/src/presentation/web/components/common/security-badge.js +30 -0
  203. package/dist/src/presentation/web/components/common/security-badge.stories.d.ts +12 -0
  204. package/dist/src/presentation/web/components/common/security-badge.stories.d.ts.map +1 -0
  205. package/dist/src/presentation/web/components/common/security-badge.stories.js +20 -0
  206. package/dist/src/presentation/web/components/features/settings/settings-page-client.d.ts.map +1 -1
  207. package/dist/src/presentation/web/components/features/settings/settings-page-client.js +16 -3
  208. package/dist/src/presentation/web/components/features/settings/supply-chain-security-settings-section.d.ts +6 -0
  209. package/dist/src/presentation/web/components/features/settings/supply-chain-security-settings-section.d.ts.map +1 -0
  210. package/dist/src/presentation/web/components/features/settings/supply-chain-security-settings-section.js +60 -0
  211. package/dist/src/presentation/web/components/features/settings/supply-chain-security-settings-section.stories.d.ts +14 -0
  212. package/dist/src/presentation/web/components/features/settings/supply-chain-security-settings-section.stories.d.ts.map +1 -0
  213. package/dist/src/presentation/web/components/features/settings/supply-chain-security-settings-section.stories.js +116 -0
  214. package/dist/src/presentation/web/lib/feature-flags.js +1 -1
  215. package/dist/translations/ar/cli.json +32 -0
  216. package/dist/translations/ar/web.json +43 -1
  217. package/dist/translations/de/cli.json +32 -0
  218. package/dist/translations/de/web.json +43 -1
  219. package/dist/translations/en/cli.json +32 -0
  220. package/dist/translations/en/web.json +43 -1
  221. package/dist/translations/es/cli.json +32 -0
  222. package/dist/translations/es/web.json +43 -1
  223. package/dist/translations/fr/cli.json +32 -0
  224. package/dist/translations/fr/web.json +43 -1
  225. package/dist/translations/he/cli.json +32 -0
  226. package/dist/translations/he/web.json +43 -1
  227. package/dist/translations/pt/cli.json +32 -0
  228. package/dist/translations/pt/web.json +43 -1
  229. package/dist/translations/ru/cli.json +32 -0
  230. package/dist/translations/ru/web.json +43 -1
  231. package/dist/tsconfig.build.tsbuildinfo +1 -1
  232. package/package.json +1 -1
  233. package/web/.next/BUILD_ID +1 -1
  234. package/web/.next/build-manifest.json +2 -2
  235. package/web/.next/fallback-build-manifest.json +2 -2
  236. package/web/.next/prerender-manifest.json +3 -3
  237. package/web/.next/required-server-files.js +3 -3
  238. package/web/.next/required-server-files.json +3 -3
  239. package/web/.next/server/app/(dashboard)/@drawer/adopt/page/server-reference-manifest.json +29 -29
  240. package/web/.next/server/app/(dashboard)/@drawer/adopt/page.js +2 -1
  241. package/web/.next/server/app/(dashboard)/@drawer/adopt/page.js.nft.json +1 -1
  242. package/web/.next/server/app/(dashboard)/@drawer/adopt/page_client-reference-manifest.js +1 -1
  243. package/web/.next/server/app/(dashboard)/@drawer/chat/page/server-reference-manifest.json +27 -27
  244. package/web/.next/server/app/(dashboard)/@drawer/chat/page.js +2 -1
  245. package/web/.next/server/app/(dashboard)/@drawer/chat/page.js.nft.json +1 -1
  246. package/web/.next/server/app/(dashboard)/@drawer/chat/page_client-reference-manifest.js +1 -1
  247. package/web/.next/server/app/(dashboard)/@drawer/create/page/server-reference-manifest.json +30 -30
  248. package/web/.next/server/app/(dashboard)/@drawer/create/page.js +2 -1
  249. package/web/.next/server/app/(dashboard)/@drawer/create/page.js.nft.json +1 -1
  250. package/web/.next/server/app/(dashboard)/@drawer/create/page_client-reference-manifest.js +1 -1
  251. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page/server-reference-manifest.json +38 -38
  252. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page.js +2 -1
  253. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page.js.nft.json +1 -1
  254. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page_client-reference-manifest.js +1 -1
  255. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page/server-reference-manifest.json +38 -38
  256. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page.js +2 -1
  257. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page.js.nft.json +1 -1
  258. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page_client-reference-manifest.js +1 -1
  259. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page/server-reference-manifest.json +28 -28
  260. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page.js +2 -1
  261. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page.js.nft.json +1 -1
  262. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page_client-reference-manifest.js +1 -1
  263. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page/server-reference-manifest.json +28 -28
  264. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page.js +2 -1
  265. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page.js.nft.json +1 -1
  266. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page_client-reference-manifest.js +1 -1
  267. package/web/.next/server/app/(dashboard)/chat/page/server-reference-manifest.json +27 -27
  268. package/web/.next/server/app/(dashboard)/chat/page.js +2 -1
  269. package/web/.next/server/app/(dashboard)/chat/page.js.nft.json +1 -1
  270. package/web/.next/server/app/(dashboard)/chat/page_client-reference-manifest.js +1 -1
  271. package/web/.next/server/app/(dashboard)/create/page/server-reference-manifest.json +30 -30
  272. package/web/.next/server/app/(dashboard)/create/page.js +2 -1
  273. package/web/.next/server/app/(dashboard)/create/page.js.nft.json +1 -1
  274. package/web/.next/server/app/(dashboard)/create/page_client-reference-manifest.js +1 -1
  275. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page/server-reference-manifest.json +38 -38
  276. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page.js +2 -1
  277. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page.js.nft.json +1 -1
  278. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page_client-reference-manifest.js +1 -1
  279. package/web/.next/server/app/(dashboard)/feature/[featureId]/page/server-reference-manifest.json +38 -38
  280. package/web/.next/server/app/(dashboard)/feature/[featureId]/page.js +2 -1
  281. package/web/.next/server/app/(dashboard)/feature/[featureId]/page.js.nft.json +1 -1
  282. package/web/.next/server/app/(dashboard)/feature/[featureId]/page_client-reference-manifest.js +1 -1
  283. package/web/.next/server/app/(dashboard)/page/server-reference-manifest.json +27 -27
  284. package/web/.next/server/app/(dashboard)/page.js +2 -1
  285. package/web/.next/server/app/(dashboard)/page.js.nft.json +1 -1
  286. package/web/.next/server/app/(dashboard)/page_client-reference-manifest.js +1 -1
  287. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page/server-reference-manifest.json +28 -28
  288. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page.js +2 -1
  289. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page.js.nft.json +1 -1
  290. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page_client-reference-manifest.js +1 -1
  291. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page/server-reference-manifest.json +28 -28
  292. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page.js +2 -1
  293. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page.js.nft.json +1 -1
  294. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page_client-reference-manifest.js +1 -1
  295. package/web/.next/server/app/_global-error.html +2 -2
  296. package/web/.next/server/app/_global-error.rsc +1 -1
  297. package/web/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  298. package/web/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  299. package/web/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  300. package/web/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  301. package/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  302. package/web/.next/server/app/_not-found/page/server-reference-manifest.json +6 -6
  303. package/web/.next/server/app/_not-found/page.js.nft.json +1 -1
  304. package/web/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  305. package/web/.next/server/app/api/attachments/preview/route.js.nft.json +1 -1
  306. package/web/.next/server/app/api/evidence/route.js.nft.json +1 -1
  307. package/web/.next/server/app/api/graph-data/route.js.nft.json +1 -1
  308. package/web/.next/server/app/api/interactive/chat/[featureId]/messages/route.js.nft.json +1 -1
  309. package/web/.next/server/app/api/sessions/route.js.nft.json +1 -1
  310. package/web/.next/server/app/api/sessions-batch/route.js.nft.json +1 -1
  311. package/web/.next/server/app/features/page/server-reference-manifest.json +6 -6
  312. package/web/.next/server/app/features/page.js.nft.json +1 -1
  313. package/web/.next/server/app/features/page_client-reference-manifest.js +1 -1
  314. package/web/.next/server/app/settings/page/server-reference-manifest.json +33 -18
  315. package/web/.next/server/app/settings/page.js +1 -1
  316. package/web/.next/server/app/settings/page.js.nft.json +1 -1
  317. package/web/.next/server/app/settings/page_client-reference-manifest.js +1 -1
  318. package/web/.next/server/app/skills/page/server-reference-manifest.json +13 -13
  319. package/web/.next/server/app/skills/page.js +2 -1
  320. package/web/.next/server/app/skills/page.js.nft.json +1 -1
  321. package/web/.next/server/app/skills/page_client-reference-manifest.js +1 -1
  322. package/web/.next/server/app/tools/page/server-reference-manifest.json +11 -11
  323. package/web/.next/server/app/tools/page.js +2 -1
  324. package/web/.next/server/app/tools/page.js.nft.json +1 -1
  325. package/web/.next/server/app/tools/page_client-reference-manifest.js +1 -1
  326. package/web/.next/server/app/version/page/server-reference-manifest.json +6 -6
  327. package/web/.next/server/app/version/page.js.nft.json +1 -1
  328. package/web/.next/server/app/version/page_client-reference-manifest.js +1 -1
  329. package/web/.next/server/chunks/403f9_next_dist_esm_build_templates_app-route_370c43b1.js +1 -1
  330. package/web/.next/server/chunks/403f9_next_dist_esm_build_templates_app-route_370c43b1.js.map +1 -1
  331. package/web/.next/server/chunks/[root-of-the-server]__a402b567._.js +1 -1
  332. package/web/.next/server/chunks/[root-of-the-server]__c78383b1._.js +1 -1
  333. package/web/.next/server/chunks/[root-of-the-server]__c78383b1._.js.map +1 -1
  334. package/web/.next/server/chunks/[root-of-the-server]__cd67a84c._.js +1 -1
  335. package/web/.next/server/chunks/[root-of-the-server]__cd67a84c._.js.map +1 -1
  336. package/web/.next/server/chunks/ssr/744ca_web__next-internal_server_app_(dashboard)_@drawer_adopt_page_actions_ad0071c9.js +3 -0
  337. package/web/.next/server/chunks/ssr/744ca_web__next-internal_server_app_(dashboard)_@drawer_adopt_page_actions_ad0071c9.js.map +1 -0
  338. package/web/.next/server/chunks/ssr/744ca_web__next-internal_server_app_(dashboard)_@drawer_chat_page_actions_90d98b2b.js +3 -0
  339. package/web/.next/server/chunks/ssr/744ca_web__next-internal_server_app_(dashboard)_@drawer_chat_page_actions_90d98b2b.js.map +1 -0
  340. package/web/.next/server/chunks/ssr/744ca_web__next-internal_server_app_(dashboard)_chat_page_actions_d3828105.js +3 -0
  341. package/web/.next/server/chunks/ssr/744ca_web__next-internal_server_app_(dashboard)_chat_page_actions_d3828105.js.map +1 -0
  342. package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_create-drawer-client_tsx_5e26fc0a._.js +1 -1
  343. package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_create-drawer-client_tsx_5e26fc0a._.js.map +1 -1
  344. package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_feature-drawer-client_tsx_e9755fc8._.js +2 -2
  345. package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_feature-drawer-client_tsx_e9755fc8._.js.map +1 -1
  346. package/web/.next/server/chunks/ssr/[root-of-the-server]__1f389e5d._.js +1 -1
  347. package/web/.next/server/chunks/ssr/[root-of-the-server]__1f389e5d._.js.map +1 -1
  348. package/web/.next/server/chunks/ssr/[root-of-the-server]__357d99f9._.js +1 -1
  349. package/web/.next/server/chunks/ssr/[root-of-the-server]__51ec77a8._.js +3 -0
  350. package/web/.next/server/chunks/ssr/[root-of-the-server]__51ec77a8._.js.map +1 -0
  351. package/web/.next/server/chunks/ssr/[root-of-the-server]__540c615f._.js +4 -0
  352. package/web/.next/server/chunks/ssr/[root-of-the-server]__540c615f._.js.map +1 -0
  353. package/web/.next/server/chunks/ssr/[root-of-the-server]__66047a1b._.js +3 -0
  354. package/web/.next/server/chunks/ssr/[root-of-the-server]__66047a1b._.js.map +1 -0
  355. package/web/.next/server/chunks/ssr/[root-of-the-server]__6c7d3936._.js +1 -1
  356. package/web/.next/server/chunks/ssr/[root-of-the-server]__6c7d3936._.js.map +1 -1
  357. package/web/.next/server/chunks/ssr/[root-of-the-server]__a2d6c0ac._.js +4 -0
  358. package/web/.next/server/chunks/ssr/[root-of-the-server]__a2d6c0ac._.js.map +1 -0
  359. package/web/.next/server/chunks/ssr/[root-of-the-server]__a932cd3a._.js +3 -0
  360. package/web/.next/server/chunks/ssr/[root-of-the-server]__a932cd3a._.js.map +1 -0
  361. package/web/.next/server/chunks/ssr/[root-of-the-server]__aa72e794._.js +3 -0
  362. package/web/.next/server/chunks/ssr/[root-of-the-server]__aa72e794._.js.map +1 -0
  363. package/web/.next/server/chunks/ssr/[root-of-the-server]__b7b96453._.js +1 -1
  364. package/web/.next/server/chunks/ssr/[root-of-the-server]__b7b96453._.js.map +1 -1
  365. package/web/.next/server/chunks/ssr/_05c23ad9._.js +1 -1
  366. package/web/.next/server/chunks/ssr/_05c23ad9._.js.map +1 -1
  367. package/web/.next/server/chunks/ssr/_08eaf4b1._.js +3 -0
  368. package/web/.next/server/chunks/ssr/_08eaf4b1._.js.map +1 -0
  369. package/web/.next/server/chunks/ssr/_16eb4fec._.js +1 -1
  370. package/web/.next/server/chunks/ssr/_16eb4fec._.js.map +1 -1
  371. package/web/.next/server/chunks/ssr/_295fffde._.js +1 -1
  372. package/web/.next/server/chunks/ssr/_295fffde._.js.map +1 -1
  373. package/web/.next/server/chunks/ssr/_3686b70d._.js +3 -0
  374. package/web/.next/server/chunks/ssr/_3686b70d._.js.map +1 -0
  375. package/web/.next/server/chunks/ssr/{_3a71f39b._.js → _45286124._.js} +2 -2
  376. package/web/.next/server/chunks/ssr/{_3a71f39b._.js.map → _45286124._.js.map} +1 -1
  377. package/web/.next/server/chunks/ssr/_45496654._.js +1 -1
  378. package/web/.next/server/chunks/ssr/_45496654._.js.map +1 -1
  379. package/web/.next/server/chunks/ssr/_4cbb7f95._.js +1 -1
  380. package/web/.next/server/chunks/ssr/_4cbb7f95._.js.map +1 -1
  381. package/web/.next/server/chunks/ssr/_56b9d60f._.js +1 -1
  382. package/web/.next/server/chunks/ssr/_56b9d60f._.js.map +1 -1
  383. package/web/.next/server/chunks/ssr/_6abfa39e._.js +1 -1
  384. package/web/.next/server/chunks/ssr/_6abfa39e._.js.map +1 -1
  385. package/web/.next/server/chunks/ssr/_783debcb._.js +9 -0
  386. package/web/.next/server/chunks/ssr/_783debcb._.js.map +1 -0
  387. package/web/.next/server/chunks/ssr/{_7953be4d._.js → _d943aad7._.js} +2 -2
  388. package/web/.next/server/chunks/ssr/_d943aad7._.js.map +1 -0
  389. package/web/.next/server/chunks/ssr/_f8c55130._.js +4 -0
  390. package/web/.next/server/chunks/ssr/_f8c55130._.js.map +1 -0
  391. package/web/.next/server/chunks/ssr/_ff04802c._.js +3 -0
  392. package/web/.next/server/chunks/ssr/_ff04802c._.js.map +1 -0
  393. package/web/.next/server/chunks/ssr/b1a17_presentation_web_components_features_settings_settings-page-client_tsx_6ed9d5f8._.js +1 -1
  394. package/web/.next/server/chunks/ssr/b1a17_presentation_web_components_features_settings_settings-page-client_tsx_6ed9d5f8._.js.map +1 -1
  395. package/web/.next/server/chunks/ssr/f3a1f_components_common_control-center-drawer_repository-drawer-client_tsx_39a00c03._.js +1 -1
  396. package/web/.next/server/chunks/ssr/f3a1f_components_common_control-center-drawer_repository-drawer-client_tsx_39a00c03._.js.map +1 -1
  397. package/web/.next/server/chunks/ssr/src_presentation_web_17d39233._.js +3 -0
  398. package/web/.next/server/chunks/ssr/src_presentation_web_17d39233._.js.map +1 -0
  399. package/web/.next/server/chunks/ssr/src_presentation_web_54b02639._.js +5 -0
  400. package/web/.next/server/chunks/ssr/src_presentation_web_54b02639._.js.map +1 -0
  401. package/web/.next/server/chunks/ssr/src_presentation_web_7b7b9e3b._.js +5 -0
  402. package/web/.next/server/chunks/ssr/src_presentation_web_7b7b9e3b._.js.map +1 -0
  403. package/web/.next/server/chunks/ssr/src_presentation_web_807cba76._.js +3 -0
  404. package/web/.next/server/chunks/ssr/src_presentation_web_807cba76._.js.map +1 -0
  405. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_(dashboard)_page_actions_90b5e66e.js +3 -0
  406. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_(dashboard)_page_actions_90b5e66e.js.map +1 -0
  407. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_skills_page_actions_4ce30db7.js +3 -0
  408. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_skills_page_actions_4ce30db7.js.map +1 -0
  409. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_tools_page_actions_e4032193.js +3 -0
  410. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_tools_page_actions_e4032193.js.map +1 -0
  411. package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_open-ide_ts_baaca5d5._.js +1 -1
  412. package/web/.next/server/chunks/ssr/src_presentation_web_ca99d62d._.js +1 -1
  413. package/web/.next/server/chunks/ssr/src_presentation_web_ca99d62d._.js.map +1 -1
  414. package/web/.next/server/chunks/ssr/src_presentation_web_components_895e5bfa._.js +1 -1
  415. package/web/.next/server/chunks/ssr/src_presentation_web_components_895e5bfa._.js.map +1 -1
  416. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_control-center_7ac3562e._.js +1 -1
  417. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_control-center_7ac3562e._.js.map +1 -1
  418. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_skills_8a174cac._.js +1 -1
  419. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_skills_8a174cac._.js.map +1 -1
  420. package/web/.next/server/chunks/ssr/src_presentation_web_db9fa0c2._.js +1 -1
  421. package/web/.next/server/chunks/ssr/src_presentation_web_db9fa0c2._.js.map +1 -1
  422. package/web/.next/server/chunks/ssr/src_presentation_web_e1cd1869._.js +3 -0
  423. package/web/.next/server/chunks/ssr/src_presentation_web_e1cd1869._.js.map +1 -0
  424. package/web/.next/server/chunks/ssr/src_presentation_web_e3a30e30._.js +3 -0
  425. package/web/.next/server/chunks/ssr/src_presentation_web_e3a30e30._.js.map +1 -0
  426. package/web/.next/server/chunks/ssr/translations_23dd5e7e._.js +1 -1
  427. package/web/.next/server/chunks/ssr/translations_23dd5e7e._.js.map +1 -1
  428. package/web/.next/server/pages/500.html +2 -2
  429. package/web/.next/server/server-reference-manifest.js +1 -1
  430. package/web/.next/server/server-reference-manifest.json +74 -59
  431. package/web/.next/static/chunks/{ad47bc6ddec7508e.js → 128f165077681f87.js} +2 -2
  432. package/web/.next/static/chunks/20ec94c610d07a10.css +1 -0
  433. package/web/.next/static/chunks/2ceebcc839ee0d4b.js +1 -0
  434. package/web/.next/static/chunks/{6bc240cd4ae43267.js → 34e82d5f47b938e3.js} +1 -1
  435. package/web/.next/static/chunks/38c5a2cc4ce5d4d2.js +1 -0
  436. package/web/.next/static/chunks/3aba9d2242420cb5.js +1 -0
  437. package/web/.next/static/chunks/4981e52ed9b5dea3.js +1 -0
  438. package/web/.next/static/chunks/{a060ad1bb509687f.js → 4a909223df60de49.js} +1 -1
  439. package/web/.next/static/chunks/5858b85217fd0ead.js +1 -0
  440. package/web/.next/static/chunks/{a2a03ecb10000974.js → 68a0d1e04c636c09.js} +1 -1
  441. package/web/.next/static/chunks/{393b27ab5de6c454.js → 85473115de724a77.js} +1 -1
  442. package/web/.next/static/chunks/{d9c9db1823b4dffd.js → 8a5c7d80045a8f49.js} +2 -2
  443. package/web/.next/static/chunks/{5a2e1c8699897c26.js → 90c687976b254681.js} +3 -3
  444. package/web/.next/static/chunks/aab749e78b4c10bc.js +1 -0
  445. package/web/.next/static/chunks/{534194b584a151ed.js → ac18577f94d63177.js} +1 -1
  446. package/web/.next/static/chunks/ae81796726a9bba3.js +1 -0
  447. package/web/.next/static/chunks/{6dc0a23d333274ae.js → af9ee4accaa11f83.js} +2 -2
  448. package/web/.next/static/chunks/{c164b157638b2a8b.js → b082a6bb7e17b701.js} +1 -1
  449. package/web/.next/static/chunks/{b49ab0b290e9342d.js → b46545caae3b4930.js} +1 -1
  450. package/web/.next/server/chunks/ssr/[root-of-the-server]__1cd4327c._.js +0 -4
  451. package/web/.next/server/chunks/ssr/[root-of-the-server]__1cd4327c._.js.map +0 -1
  452. package/web/.next/server/chunks/ssr/[root-of-the-server]__4fb81977._.js +0 -4
  453. package/web/.next/server/chunks/ssr/[root-of-the-server]__4fb81977._.js.map +0 -1
  454. package/web/.next/server/chunks/ssr/[root-of-the-server]__7dcd0917._.js +0 -4
  455. package/web/.next/server/chunks/ssr/[root-of-the-server]__7dcd0917._.js.map +0 -1
  456. package/web/.next/server/chunks/ssr/[root-of-the-server]__92ffd5ee._.js +0 -4
  457. package/web/.next/server/chunks/ssr/[root-of-the-server]__92ffd5ee._.js.map +0 -1
  458. package/web/.next/server/chunks/ssr/[root-of-the-server]__b020c17d._.js +0 -4
  459. package/web/.next/server/chunks/ssr/[root-of-the-server]__b020c17d._.js.map +0 -1
  460. package/web/.next/server/chunks/ssr/[root-of-the-server]__ba7f5873._.js +0 -4
  461. package/web/.next/server/chunks/ssr/[root-of-the-server]__ba7f5873._.js.map +0 -1
  462. package/web/.next/server/chunks/ssr/[root-of-the-server]__c5e09f6f._.js +0 -4
  463. package/web/.next/server/chunks/ssr/[root-of-the-server]__c5e09f6f._.js.map +0 -1
  464. package/web/.next/server/chunks/ssr/_02e01240._.js +0 -4
  465. package/web/.next/server/chunks/ssr/_02e01240._.js.map +0 -1
  466. package/web/.next/server/chunks/ssr/_18886033._.js +0 -4
  467. package/web/.next/server/chunks/ssr/_18886033._.js.map +0 -1
  468. package/web/.next/server/chunks/ssr/_22e00a14._.js +0 -4
  469. package/web/.next/server/chunks/ssr/_22e00a14._.js.map +0 -1
  470. package/web/.next/server/chunks/ssr/_43ba79e7._.js +0 -3
  471. package/web/.next/server/chunks/ssr/_43ba79e7._.js.map +0 -1
  472. package/web/.next/server/chunks/ssr/_7953be4d._.js.map +0 -1
  473. package/web/.next/server/chunks/ssr/_7cb0396e._.js +0 -3
  474. package/web/.next/server/chunks/ssr/_7cb0396e._.js.map +0 -1
  475. package/web/.next/server/chunks/ssr/_a5a5901d._.js +0 -4
  476. package/web/.next/server/chunks/ssr/_a5a5901d._.js.map +0 -1
  477. package/web/.next/server/chunks/ssr/_ad09f271._.js +0 -4
  478. package/web/.next/server/chunks/ssr/_ad09f271._.js.map +0 -1
  479. package/web/.next/server/chunks/ssr/_c3f595c6._.js +0 -4
  480. package/web/.next/server/chunks/ssr/_c3f595c6._.js.map +0 -1
  481. package/web/.next/server/chunks/ssr/_e680c57c._.js +0 -9
  482. package/web/.next/server/chunks/ssr/_e680c57c._.js.map +0 -1
  483. package/web/.next/server/chunks/ssr/_ea9e1556._.js +0 -4
  484. package/web/.next/server/chunks/ssr/_ea9e1556._.js.map +0 -1
  485. package/web/.next/server/chunks/ssr/_f1ba9be6._.js +0 -6
  486. package/web/.next/server/chunks/ssr/_f1ba9be6._.js.map +0 -1
  487. package/web/.next/server/chunks/ssr/_f33cd07e._.js +0 -6
  488. package/web/.next/server/chunks/ssr/_f33cd07e._.js.map +0 -1
  489. package/web/.next/server/chunks/ssr/_f8b45233._.js +0 -4
  490. package/web/.next/server/chunks/ssr/_f8b45233._.js.map +0 -1
  491. package/web/.next/server/chunks/ssr/_fd595af2._.js +0 -3
  492. package/web/.next/server/chunks/ssr/_fd595af2._.js.map +0 -1
  493. package/web/.next/static/chunks/0baf5a2e56d191cf.js +0 -1
  494. package/web/.next/static/chunks/32c46154c31c58fc.js +0 -1
  495. package/web/.next/static/chunks/84b480808bd74fa9.css +0 -1
  496. package/web/.next/static/chunks/8b0a9cb5109fe899.js +0 -1
  497. package/web/.next/static/chunks/b65e555419a0c664.js +0 -1
  498. package/web/.next/static/chunks/e30aa6d2cf824fa1.js +0 -1
  499. package/web/.next/static/chunks/f5abbc495d496f5b.js +0 -1
  500. /package/web/.next/static/{nLYXtW5TIrvQiMl1yyD4O → PEEwFezIwaFMSsCXbx5zQ}/_buildManifest.js +0 -0
  501. /package/web/.next/static/{nLYXtW5TIrvQiMl1yyD4O → PEEwFezIwaFMSsCXbx5zQ}/_clientMiddlewareManifest.json +0 -0
  502. /package/web/.next/static/{nLYXtW5TIrvQiMl1yyD4O → PEEwFezIwaFMSsCXbx5zQ}/_ssgManifest.js +0 -0
@@ -35,6 +35,12 @@ export declare class GitHubRepoListError extends Error {
35
35
  export declare class GitHubPermissionError extends Error {
36
36
  constructor(message: string, cause?: Error);
37
37
  }
38
+ /**
39
+ * Thrown when a fork operation fails.
40
+ */
41
+ export declare class GitHubForkError extends Error {
42
+ constructor(message: string, cause?: Error);
43
+ }
38
44
  /**
39
45
  * A GitHub repository as returned by `gh repo list --json`.
40
46
  */
@@ -88,6 +94,48 @@ export interface ParsedGitHubUrl {
88
94
  /** Combined owner/repo (e.g. "octocat/my-project") */
89
95
  nameWithOwner: string;
90
96
  }
97
+ /**
98
+ * Options for forking a repository.
99
+ */
100
+ export interface ForkOptions {
101
+ onProgress?: (message: string) => void;
102
+ }
103
+ /**
104
+ * Result of checking push access on a repository.
105
+ */
106
+ export interface PushAccessResult {
107
+ hasPushAccess: boolean;
108
+ viewerLogin: string;
109
+ }
110
+ /**
111
+ * Result of forking a repository.
112
+ */
113
+ export interface ForkResult {
114
+ nameWithOwner: string;
115
+ alreadyExisted: boolean;
116
+ }
117
+ /**
118
+ * Category of a governance audit finding.
119
+ */
120
+ export declare enum GovernanceFindingCategory {
121
+ BranchProtection = "BranchProtection",
122
+ Codeowners = "Codeowners",
123
+ WorkflowPermissions = "WorkflowPermissions"
124
+ }
125
+ /**
126
+ * A single finding from a GitHub governance audit.
127
+ * Findings are advisory-only — Shep reports gaps but does not mutate remote settings.
128
+ */
129
+ export interface GovernanceFinding {
130
+ /** Category of the governance check */
131
+ category: GovernanceFindingCategory;
132
+ /** Severity of the finding */
133
+ severity: 'Low' | 'Medium' | 'High' | 'Critical' | 'Unknown';
134
+ /** Human-readable description of the finding */
135
+ message: string;
136
+ /** Actionable remediation guidance */
137
+ remediation: string;
138
+ }
91
139
  /**
92
140
  * Output port for GitHub repository operations.
93
141
  *
@@ -151,5 +199,42 @@ export interface IGitHubRepositoryService {
151
199
  * @throws {GitHubPermissionError} if the permission check fails (e.g. gh not installed, not authenticated)
152
200
  */
153
201
  getViewerPermission(repoPath: string): Promise<string>;
202
+ /**
203
+ * Get the authenticated GitHub user's login.
204
+ * @returns The login username
205
+ * @throws {GitHubAuthError} if not authenticated
206
+ */
207
+ getAuthenticatedUser(): Promise<string>;
208
+ /**
209
+ * Check if the authenticated user has push access to a repository.
210
+ * @param nameWithOwner - Full owner/repo identifier
211
+ * @returns Push access result with viewer login
212
+ * @throws {GitHubPermissionError} on failure
213
+ */
214
+ checkPushAccess(nameWithOwner: string): Promise<PushAccessResult>;
215
+ /**
216
+ * Fork a repository to the authenticated user's account.
217
+ * @param nameWithOwner - Full owner/repo identifier to fork
218
+ * @param options - Optional progress callback
219
+ * @returns Fork result with the fork's nameWithOwner
220
+ * @throws {GitHubForkError} on failure
221
+ */
222
+ forkRepository(nameWithOwner: string, options?: ForkOptions): Promise<ForkResult>;
223
+ /**
224
+ * Audit repository governance settings via the gh CLI.
225
+ *
226
+ * Checks branch protection rules, CODEOWNERS presence, and workflow
227
+ * permissions. Returns findings with severity and remediation suggestions.
228
+ * This is audit-only — no remote settings are mutated.
229
+ *
230
+ * Handles auth/permission errors gracefully by returning an Unknown-severity
231
+ * finding instead of throwing.
232
+ *
233
+ * @param owner - Repository owner (e.g. "octocat")
234
+ * @param repo - Repository name (e.g. "my-project")
235
+ * @param defaultBranch - Branch to check protection for (default: "main")
236
+ * @returns Array of governance findings (empty if all checks pass)
237
+ */
238
+ auditRepositoryGovernance(owner: string, repo: string, defaultBranch?: string): Promise<GovernanceFinding[]>;
154
239
  }
155
240
  //# sourceMappingURL=github-repository-service.interface.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"github-repository-service.interface.d.ts","sourceRoot":"","sources":["../../../../../../../../packages/core/src/application/ports/output/services/github-repository-service.interface.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAMH;;GAEG;AACH,qBAAa,eAAgB,SAAQ,KAAK;gBAC5B,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK;CAM3C;AAED;;GAEG;AACH,qBAAa,gBAAiB,SAAQ,KAAK;gBAC7B,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK;CAM3C;AAED;;GAEG;AACH,qBAAa,mBAAoB,SAAQ,KAAK;gBAChC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK;CAM3C;AAED;;GAEG;AACH,qBAAa,mBAAoB,SAAQ,KAAK;gBAChC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK;CAM3C;AAED;;GAEG;AACH,qBAAa,qBAAsB,SAAQ,KAAK;gBAClC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK;CAM3C;AAMD;;GAEG;AACH,MAAM,WAAW,UAAU;IACzB,0CAA0C;IAC1C,IAAI,EAAE,MAAM,CAAC;IACb,6DAA6D;IAC7D,aAAa,EAAE,MAAM,CAAC;IACtB,mDAAmD;IACnD,WAAW,EAAE,MAAM,CAAC;IACpB,wCAAwC;IACxC,SAAS,EAAE,OAAO,CAAC;IACnB,iDAAiD;IACjD,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED;;GAEG;AACH,MAAM,WAAW,2BAA2B;IAC1C,sDAAsD;IACtD,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,qCAAqC;IACrC,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,+FAA+F;IAC/F,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED;;GAEG;AACH,MAAM,WAAW,kBAAkB;IACjC,gDAAgD;IAChD,KAAK,EAAE,MAAM,CAAC;IACd,qDAAqD;IACrD,WAAW,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,4EAA4E;IAC5E,UAAU,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;CACrC;AAED;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,wCAAwC;IACxC,KAAK,EAAE,MAAM,CAAC;IACd,0CAA0C;IAC1C,IAAI,EAAE,MAAM,CAAC;IACb,sDAAsD;IACtD,aAAa,EAAE,MAAM,CAAC;CACvB;AAMD;;;;GAIG;AACH,MAAM,WAAW,wBAAwB;IACvC;;;;OAIG;IACH,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAE3B;;;;;;;OAOG;IACH,eAAe,CACb,aAAa,EAAE,MAAM,EACrB,WAAW,EAAE,MAAM,EACnB,OAAO,CAAC,EAAE,YAAY,GACrB,OAAO,CAAC,IAAI,CAAC,CAAC;IAEjB;;;;;;;;OAQG;IACH,oBAAoB,CAAC,OAAO,CAAC,EAAE,2BAA2B,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC,CAAC;IAEnF;;;;;OAKG;IACH,iBAAiB,IAAI,OAAO,CAAC,kBAAkB,EAAE,CAAC,CAAC;IAEnD;;;;;;;;;;;;OAYG;IACH,cAAc,CAAC,GAAG,EAAE,MAAM,GAAG,eAAe,CAAC;IAE7C;;;;;;;;;OASG;IACH,mBAAmB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;CACxD"}
1
+ {"version":3,"file":"github-repository-service.interface.d.ts","sourceRoot":"","sources":["../../../../../../../../packages/core/src/application/ports/output/services/github-repository-service.interface.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAMH;;GAEG;AACH,qBAAa,eAAgB,SAAQ,KAAK;gBAC5B,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK;CAM3C;AAED;;GAEG;AACH,qBAAa,gBAAiB,SAAQ,KAAK;gBAC7B,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK;CAM3C;AAED;;GAEG;AACH,qBAAa,mBAAoB,SAAQ,KAAK;gBAChC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK;CAM3C;AAED;;GAEG;AACH,qBAAa,mBAAoB,SAAQ,KAAK;gBAChC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK;CAM3C;AAED;;GAEG;AACH,qBAAa,qBAAsB,SAAQ,KAAK;gBAClC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK;CAM3C;AAED;;GAEG;AACH,qBAAa,eAAgB,SAAQ,KAAK;gBAC5B,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK;CAM3C;AAMD;;GAEG;AACH,MAAM,WAAW,UAAU;IACzB,0CAA0C;IAC1C,IAAI,EAAE,MAAM,CAAC;IACb,6DAA6D;IAC7D,aAAa,EAAE,MAAM,CAAC;IACtB,mDAAmD;IACnD,WAAW,EAAE,MAAM,CAAC;IACpB,wCAAwC;IACxC,SAAS,EAAE,OAAO,CAAC;IACnB,iDAAiD;IACjD,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED;;GAEG;AACH,MAAM,WAAW,2BAA2B;IAC1C,sDAAsD;IACtD,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,qCAAqC;IACrC,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,+FAA+F;IAC/F,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED;;GAEG;AACH,MAAM,WAAW,kBAAkB;IACjC,gDAAgD;IAChD,KAAK,EAAE,MAAM,CAAC;IACd,qDAAqD;IACrD,WAAW,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,4EAA4E;IAC5E,UAAU,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;CACrC;AAED;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,wCAAwC;IACxC,KAAK,EAAE,MAAM,CAAC;IACd,0CAA0C;IAC1C,IAAI,EAAE,MAAM,CAAC;IACb,sDAAsD;IACtD,aAAa,EAAE,MAAM,CAAC;CACvB;AAED;;GAEG;AACH,MAAM,WAAW,WAAW;IAC1B,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,CAAC;CACxC;AAED;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B,aAAa,EAAE,OAAO,CAAC;IACvB,WAAW,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,UAAU;IACzB,aAAa,EAAE,MAAM,CAAC;IACtB,cAAc,EAAE,OAAO,CAAC;CACzB;AAED;;GAEG;AACH,oBAAY,yBAAyB;IACnC,gBAAgB,qBAAqB;IACrC,UAAU,eAAe;IACzB,mBAAmB,wBAAwB;CAC5C;AAED;;;GAGG;AACH,MAAM,WAAW,iBAAiB;IAChC,uCAAuC;IACvC,QAAQ,EAAE,yBAAyB,CAAC;IACpC,8BAA8B;IAC9B,QAAQ,EAAE,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,UAAU,GAAG,SAAS,CAAC;IAC7D,gDAAgD;IAChD,OAAO,EAAE,MAAM,CAAC;IAChB,sCAAsC;IACtC,WAAW,EAAE,MAAM,CAAC;CACrB;AAMD;;;;GAIG;AACH,MAAM,WAAW,wBAAwB;IACvC;;;;OAIG;IACH,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAE3B;;;;;;;OAOG;IACH,eAAe,CACb,aAAa,EAAE,MAAM,EACrB,WAAW,EAAE,MAAM,EACnB,OAAO,CAAC,EAAE,YAAY,GACrB,OAAO,CAAC,IAAI,CAAC,CAAC;IAEjB;;;;;;;;OAQG;IACH,oBAAoB,CAAC,OAAO,CAAC,EAAE,2BAA2B,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC,CAAC;IAEnF;;;;;OAKG;IACH,iBAAiB,IAAI,OAAO,CAAC,kBAAkB,EAAE,CAAC,CAAC;IAEnD;;;;;;;;;;;;OAYG;IACH,cAAc,CAAC,GAAG,EAAE,MAAM,GAAG,eAAe,CAAC;IAE7C;;;;;;;;;OASG;IACH,mBAAmB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAEvD;;;;OAIG;IACH,oBAAoB,IAAI,OAAO,CAAC,MAAM,CAAC,CAAC;IAExC;;;;;OAKG;IACH,eAAe,CAAC,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC;IAElE;;;;;;OAMG;IACH,cAAc,CAAC,aAAa,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IAElF;;;;;;;;;;;;;;OAcG;IACH,yBAAyB,CACvB,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,MAAM,EACZ,aAAa,CAAC,EAAE,MAAM,GACrB,OAAO,CAAC,iBAAiB,EAAE,CAAC,CAAC;CACjC"}
@@ -68,3 +68,24 @@ export class GitHubPermissionError extends Error {
68
68
  this.cause = cause;
69
69
  }
70
70
  }
71
+ /**
72
+ * Thrown when a fork operation fails.
73
+ */
74
+ export class GitHubForkError extends Error {
75
+ constructor(message, cause) {
76
+ super(message);
77
+ this.name = 'GitHubForkError';
78
+ Object.setPrototypeOf(this, new.target.prototype);
79
+ if (cause)
80
+ this.cause = cause;
81
+ }
82
+ }
83
+ /**
84
+ * Category of a governance audit finding.
85
+ */
86
+ export var GovernanceFindingCategory;
87
+ (function (GovernanceFindingCategory) {
88
+ GovernanceFindingCategory["BranchProtection"] = "BranchProtection";
89
+ GovernanceFindingCategory["Codeowners"] = "Codeowners";
90
+ GovernanceFindingCategory["WorkflowPermissions"] = "WorkflowPermissions";
91
+ })(GovernanceFindingCategory || (GovernanceFindingCategory = {}));
@@ -0,0 +1,77 @@
1
+ /**
2
+ * Security Policy Service Interface
3
+ *
4
+ * Output port for the central security policy engine.
5
+ * Implementations handle policy file reading, validation, merging
6
+ * with persisted settings, and deterministic policy evaluation.
7
+ *
8
+ * Following Clean Architecture:
9
+ * - Application and use-case layers depend on this interface
10
+ * - Infrastructure layer provides the concrete implementation
11
+ * - All consumers (CLI, runtime, CI, UI) resolve the same instance via DI
12
+ */
13
+ import type { EffectivePolicySnapshot, SecurityActionCategory, SecurityActionDisposition } from '../../../../domain/generated/output.js';
14
+ /**
15
+ * Result of validating a security policy file.
16
+ */
17
+ export interface PolicyValidationResult {
18
+ /** Whether the policy file is valid */
19
+ valid: boolean;
20
+ /** Per-field validation error messages (empty when valid) */
21
+ errors: string[];
22
+ }
23
+ /**
24
+ * Service interface for security policy evaluation.
25
+ *
26
+ * Implementations must:
27
+ * - Read shep.security.yaml from the repository root
28
+ * - Merge repository policy with persisted settings defaults
29
+ * - Apply deterministic precedence (global defaults < repo policy)
30
+ * - Cache effective policy per repository path
31
+ * - Fail fast on invalid policy files with actionable errors
32
+ */
33
+ export interface ISecurityPolicyService {
34
+ /**
35
+ * Evaluate and compute the effective security policy for a repository.
36
+ *
37
+ * Reads the policy file, merges with persisted settings defaults,
38
+ * validates, and returns a deterministic snapshot. Re-evaluates
39
+ * on every call (no cache).
40
+ *
41
+ * @param repositoryPath - Absolute path to the repository root
42
+ * @returns Computed effective policy snapshot
43
+ * @throws Error if the policy file exists but is invalid
44
+ */
45
+ evaluatePolicy(repositoryPath: string): Promise<EffectivePolicySnapshot>;
46
+ /**
47
+ * Get the effective security policy for a repository.
48
+ *
49
+ * Returns a cached snapshot if available, otherwise computes
50
+ * and caches the result. Use evaluatePolicy() to force re-evaluation.
51
+ *
52
+ * @param repositoryPath - Absolute path to the repository root
53
+ * @returns Cached or freshly computed effective policy snapshot
54
+ * @throws Error if the policy file exists but is invalid
55
+ */
56
+ getEffectivePolicy(repositoryPath: string): Promise<EffectivePolicySnapshot>;
57
+ /**
58
+ * Validate a security policy file without computing effective policy.
59
+ *
60
+ * Parses and validates the file against the expected schema.
61
+ * Returns a structured result with per-field error messages.
62
+ *
63
+ * @param filePath - Absolute path to the policy file
64
+ * @returns Validation result with errors array
65
+ */
66
+ validatePolicyFile(filePath: string): Promise<PolicyValidationResult>;
67
+ /**
68
+ * Look up the enforcement disposition for a specific action category
69
+ * within a given effective policy snapshot.
70
+ *
71
+ * @param policy - The effective policy snapshot to query
72
+ * @param actionCategory - The action category to look up
73
+ * @returns The disposition (Allowed, Denied, or ApprovalRequired)
74
+ */
75
+ getActionDisposition(policy: EffectivePolicySnapshot, actionCategory: SecurityActionCategory): SecurityActionDisposition;
76
+ }
77
+ //# sourceMappingURL=security-policy-service.interface.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"security-policy-service.interface.d.ts","sourceRoot":"","sources":["../../../../../../../../packages/core/src/application/ports/output/services/security-policy-service.interface.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAEH,OAAO,KAAK,EACV,uBAAuB,EACvB,sBAAsB,EACtB,yBAAyB,EAC1B,MAAM,wCAAwC,CAAC;AAEhD;;GAEG;AACH,MAAM,WAAW,sBAAsB;IACrC,uCAAuC;IACvC,KAAK,EAAE,OAAO,CAAC;IACf,6DAA6D;IAC7D,MAAM,EAAE,MAAM,EAAE,CAAC;CAClB;AAED;;;;;;;;;GASG;AACH,MAAM,WAAW,sBAAsB;IACrC;;;;;;;;;;OAUG;IACH,cAAc,CAAC,cAAc,EAAE,MAAM,GAAG,OAAO,CAAC,uBAAuB,CAAC,CAAC;IAEzE;;;;;;;;;OASG;IACH,kBAAkB,CAAC,cAAc,EAAE,MAAM,GAAG,OAAO,CAAC,uBAAuB,CAAC,CAAC;IAE7E;;;;;;;;OAQG;IACH,kBAAkB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,sBAAsB,CAAC,CAAC;IAEtE;;;;;;;OAOG;IACH,oBAAoB,CAClB,MAAM,EAAE,uBAAuB,EAC/B,cAAc,EAAE,sBAAsB,GACrC,yBAAyB,CAAC;CAC9B"}
@@ -0,0 +1,13 @@
1
+ /**
2
+ * Security Policy Service Interface
3
+ *
4
+ * Output port for the central security policy engine.
5
+ * Implementations handle policy file reading, validation, merging
6
+ * with persisted settings, and deterministic policy evaluation.
7
+ *
8
+ * Following Clean Architecture:
9
+ * - Application and use-case layers depend on this interface
10
+ * - Infrastructure layer provides the concrete implementation
11
+ * - All consumers (CLI, runtime, CI, UI) resolve the same instance via DI
12
+ */
13
+ export {};
@@ -32,5 +32,16 @@ export interface ISpecInitializerService {
32
32
  * @returns The spec directory path and feature number used
33
33
  */
34
34
  initialize(basePath: string, slug: string, featureNumber: number, description: string, mode?: 'fast'): Promise<SpecInitializerResult>;
35
+ /**
36
+ * Scaffold a baseline shep.security.yaml file at the repository root.
37
+ *
38
+ * Creates the security policy file with Advisory mode, default action
39
+ * dispositions, and dependency/release rules. Includes YAML comments
40
+ * explaining each section.
41
+ *
42
+ * @param repositoryPath - Absolute path to the repository root
43
+ * @returns The absolute path to the created security policy file
44
+ */
45
+ scaffoldSecurityPolicy(repositoryPath: string): Promise<string>;
35
46
  }
36
47
  //# sourceMappingURL=spec-initializer.interface.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"spec-initializer.interface.d.ts","sourceRoot":"","sources":["../../../../../../../../packages/core/src/application/ports/output/services/spec-initializer.interface.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,MAAM,WAAW,qBAAqB;IACpC,kDAAkD;IAClD,OAAO,EAAE,MAAM,CAAC;IAChB,8CAA8C;IAC9C,aAAa,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,uBAAuB;IACtC;;;;;;;;;;;;;;;;;;OAkBG;IACH,UAAU,CACR,QAAQ,EAAE,MAAM,EAChB,IAAI,EAAE,MAAM,EACZ,aAAa,EAAE,MAAM,EACrB,WAAW,EAAE,MAAM,EACnB,IAAI,CAAC,EAAE,MAAM,GACZ,OAAO,CAAC,qBAAqB,CAAC,CAAC;CACnC"}
1
+ {"version":3,"file":"spec-initializer.interface.d.ts","sourceRoot":"","sources":["../../../../../../../../packages/core/src/application/ports/output/services/spec-initializer.interface.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,MAAM,WAAW,qBAAqB;IACpC,kDAAkD;IAClD,OAAO,EAAE,MAAM,CAAC;IAChB,8CAA8C;IAC9C,aAAa,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,uBAAuB;IACtC;;;;;;;;;;;;;;;;;;OAkBG;IACH,UAAU,CACR,QAAQ,EAAE,MAAM,EAChB,IAAI,EAAE,MAAM,EACZ,aAAa,EAAE,MAAM,EACrB,WAAW,EAAE,MAAM,EACnB,IAAI,CAAC,EAAE,MAAM,GACZ,OAAO,CAAC,qBAAqB,CAAC,CAAC;IAElC;;;;;;;;;OASG;IACH,sBAAsB,CAAC,cAAc,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;CACjE"}
@@ -1 +1 @@
1
- {"version":3,"file":"approve-agent-run.use-case.d.ts","sourceRoot":"","sources":["../../../../../../../packages/core/src/application/use-cases/agents/approve-agent-run.use-case.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAMH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,6DAA6D,CAAC;AACvG,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,8DAA8D,CAAC;AAChH,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,gEAAgE,CAAC;AAC7G,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iEAAiE,CAAC;AAE1G,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AAO9E,qBACa,sBAAsB;IAG/B,OAAO,CAAC,QAAQ,CAAC,kBAAkB;IAEnC,OAAO,CAAC,QAAQ,CAAC,cAAc;IAE/B,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IAElC,OAAO,CAAC,QAAQ,CAAC,qBAAqB;gBANrB,kBAAkB,EAAE,mBAAmB,EAEvC,cAAc,EAAE,2BAA2B,EAE3C,iBAAiB,EAAE,kBAAkB,EAErC,qBAAqB,EAAE,sBAAsB;IAG1D,OAAO,CACX,EAAE,EAAE,MAAM,EACV,OAAO,CAAC,EAAE,kBAAkB,GAC3B,OAAO,CAAC;QAAE,QAAQ,EAAE,OAAO,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC;CA0GlD"}
1
+ {"version":3,"file":"approve-agent-run.use-case.d.ts","sourceRoot":"","sources":["../../../../../../../packages/core/src/application/use-cases/agents/approve-agent-run.use-case.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAMH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,6DAA6D,CAAC;AACvG,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,8DAA8D,CAAC;AAChH,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,gEAAgE,CAAC;AAC7G,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iEAAiE,CAAC;AAE1G,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AAQ9E,qBACa,sBAAsB;IAG/B,OAAO,CAAC,QAAQ,CAAC,kBAAkB;IAEnC,OAAO,CAAC,QAAQ,CAAC,cAAc;IAE/B,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IAElC,OAAO,CAAC,QAAQ,CAAC,qBAAqB;gBANrB,kBAAkB,EAAE,mBAAmB,EAEvC,cAAc,EAAE,2BAA2B,EAE3C,iBAAiB,EAAE,kBAAkB,EAErC,qBAAqB,EAAE,sBAAsB;IAG1D,OAAO,CACX,EAAE,EAAE,MAAM,EACV,OAAO,CAAC,EAAE,kBAAkB,GAC3B,OAAO,CAAC;QAAE,QAAQ,EAAE,OAAO,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC;CA2GlD"}
@@ -25,6 +25,7 @@ import { join } from 'node:path';
25
25
  import { AgentRunStatus } from '../../../domain/generated/output.js';
26
26
  import { writeSpecFileAtomic, safeYamlDump, } from '../../../infrastructure/services/agents/feature-agent/nodes/node-helpers.js';
27
27
  import { computeWorktreePath } from '../../../infrastructure/services/ide-launchers/compute-worktree-path.js';
28
+ import { getSettings } from '../../../infrastructure/services/settings.service.js';
28
29
  let ApproveAgentRunUseCase = class ApproveAgentRunUseCase {
29
30
  agentRunRepository;
30
31
  processService;
@@ -120,6 +121,7 @@ let ApproveAgentRunUseCase = class ApproveAgentRunUseCase {
120
121
  agentType: run.agentType,
121
122
  ...(run.modelId ? { model: run.modelId } : {}),
122
123
  ...(feature?.fast ? { fast: true } : {}),
124
+ securityMode: getSettings().security?.mode,
123
125
  });
124
126
  return { approved: true, reason: 'Approved and resumed' };
125
127
  }
@@ -1 +1 @@
1
- {"version":3,"file":"reject-agent-run.use-case.d.ts","sourceRoot":"","sources":["../../../../../../../packages/core/src/application/use-cases/agents/reject-agent-run.use-case.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAMH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,6DAA6D,CAAC;AACvG,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,8DAA8D,CAAC;AAChH,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,gEAAgE,CAAC;AAC7G,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iEAAiE,CAAC;AAa1G,qBACa,qBAAqB;IAG9B,OAAO,CAAC,QAAQ,CAAC,kBAAkB;IAEnC,OAAO,CAAC,QAAQ,CAAC,cAAc;IAE/B,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IAElC,OAAO,CAAC,QAAQ,CAAC,qBAAqB;gBANrB,kBAAkB,EAAE,mBAAmB,EAEvC,cAAc,EAAE,2BAA2B,EAE3C,iBAAiB,EAAE,kBAAkB,EAErC,qBAAqB,EAAE,sBAAsB;IAG1D,OAAO,CACX,EAAE,EAAE,MAAM,EACV,QAAQ,EAAE,MAAM,EAChB,WAAW,CAAC,EAAE,MAAM,EAAE,GACrB,OAAO,CAAC;QACT,QAAQ,EAAE,OAAO,CAAC;QAClB,MAAM,EAAE,MAAM,CAAC;QACf,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,gBAAgB,CAAC,EAAE,OAAO,CAAC;KAC5B,CAAC;CAkIH"}
1
+ {"version":3,"file":"reject-agent-run.use-case.d.ts","sourceRoot":"","sources":["../../../../../../../packages/core/src/application/use-cases/agents/reject-agent-run.use-case.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAMH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,6DAA6D,CAAC;AACvG,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,8DAA8D,CAAC;AAChH,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,gEAAgE,CAAC;AAC7G,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iEAAiE,CAAC;AAc1G,qBACa,qBAAqB;IAG9B,OAAO,CAAC,QAAQ,CAAC,kBAAkB;IAEnC,OAAO,CAAC,QAAQ,CAAC,cAAc;IAE/B,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IAElC,OAAO,CAAC,QAAQ,CAAC,qBAAqB;gBANrB,kBAAkB,EAAE,mBAAmB,EAEvC,cAAc,EAAE,2BAA2B,EAE3C,iBAAiB,EAAE,kBAAkB,EAErC,qBAAqB,EAAE,sBAAsB;IAG1D,OAAO,CACX,EAAE,EAAE,MAAM,EACV,QAAQ,EAAE,MAAM,EAChB,WAAW,CAAC,EAAE,MAAM,EAAE,GACrB,OAAO,CAAC;QACT,QAAQ,EAAE,OAAO,CAAC;QAClB,MAAM,EAAE,MAAM,CAAC;QACf,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,gBAAgB,CAAC,EAAE,OAAO,CAAC;KAC5B,CAAC;CAmIH"}
@@ -25,6 +25,7 @@ import { AgentRunStatus } from '../../../domain/generated/output.js';
25
25
  import { writeSpecFileAtomic, safeYamlDump, } from '../../../infrastructure/services/agents/feature-agent/nodes/node-helpers.js';
26
26
  import { recordLifecycleEvent } from '../../../infrastructure/services/agents/feature-agent/phase-timing-context.js';
27
27
  import { computeWorktreePath } from '../../../infrastructure/services/ide-launchers/compute-worktree-path.js';
28
+ import { getSettings } from '../../../infrastructure/services/settings.service.js';
28
29
  let RejectAgentRunUseCase = class RejectAgentRunUseCase {
29
30
  agentRunRepository;
30
31
  processService;
@@ -136,6 +137,7 @@ let RejectAgentRunUseCase = class RejectAgentRunUseCase {
136
137
  agentType: run.agentType,
137
138
  ...(run.modelId ? { model: run.modelId } : {}),
138
139
  ...(feature.fast ? { fast: true } : {}),
140
+ securityMode: getSettings().security?.mode,
139
141
  });
140
142
  return {
141
143
  rejected: true,
@@ -1 +1 @@
1
- {"version":3,"file":"check-and-unblock-features.use-case.d.ts","sourceRoot":"","sources":["../../../../../../../packages/core/src/application/use-cases/features/check-and-unblock-features.use-case.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAIH,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iEAAiE,CAAC;AAC1G,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,8DAA8D,CAAC;AAGhH,qBACa,8BAA8B;IAET,OAAO,CAAC,QAAQ,CAAC,WAAW;IAE1D,OAAO,CAAC,QAAQ,CAAC,YAAY;gBAFkB,WAAW,EAAE,kBAAkB,EAE7D,YAAY,EAAE,2BAA2B;IAG5D;;;;OAIG;IACG,OAAO,CAAC,eAAe,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CA4CtD"}
1
+ {"version":3,"file":"check-and-unblock-features.use-case.d.ts","sourceRoot":"","sources":["../../../../../../../packages/core/src/application/use-cases/features/check-and-unblock-features.use-case.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAIH,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iEAAiE,CAAC;AAC1G,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,8DAA8D,CAAC;AAIhH,qBACa,8BAA8B;IAET,OAAO,CAAC,QAAQ,CAAC,WAAW;IAE1D,OAAO,CAAC,QAAQ,CAAC,YAAY;gBAFkB,WAAW,EAAE,kBAAkB,EAE7D,YAAY,EAAE,2BAA2B;IAG5D;;;;OAIG;IACG,OAAO,CAAC,eAAe,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CA6CtD"}
@@ -29,6 +29,7 @@ var __param = (this && this.__param) || function (paramIndex, decorator) {
29
29
  import { injectable, inject } from 'tsyringe';
30
30
  import { SdlcLifecycle } from '../../../domain/generated/output.js';
31
31
  import { POST_IMPLEMENTATION } from '../../../domain/lifecycle-gates.js';
32
+ import { getSettings } from '../../../infrastructure/services/settings.service.js';
32
33
  let CheckAndUnblockFeaturesUseCase = class CheckAndUnblockFeaturesUseCase {
33
34
  featureRepo;
34
35
  agentProcess;
@@ -70,6 +71,7 @@ let CheckAndUnblockFeaturesUseCase = class CheckAndUnblockFeaturesUseCase {
70
71
  enableEvidence: child.enableEvidence,
71
72
  commitEvidence: child.commitEvidence,
72
73
  ...(child.fast ? { fast: true } : {}),
74
+ securityMode: getSettings().security?.mode,
73
75
  });
74
76
  }
75
77
  }
@@ -0,0 +1,67 @@
1
+ /**
2
+ * Create Feature From Remote Use Case
3
+ *
4
+ * Composite use case that chains ImportGitHubRepositoryUseCase with
5
+ * CreateFeatureUseCase. Enables creating a feature on a remote GitHub
6
+ * repo in a single command — clone (or fork), register, then create feature.
7
+ *
8
+ * Provides two execution modes:
9
+ * - execute(): synchronous full flow for CLI
10
+ * - createRecord() + initializeAndSpawn(): two-phase for Web UI (fast response + background work)
11
+ */
12
+ import type { Feature } from '../../../../domain/generated/output.js';
13
+ import type { ApprovalGates, Attachment } from '../../../../domain/generated/output.js';
14
+ import type { CloneOptions, ForkOptions } from '../../../ports/output/services/github-repository-service.interface.js';
15
+ import { ImportGitHubRepositoryUseCase } from '../../repositories/import-github-repository.use-case.js';
16
+ import { CreateFeatureUseCase } from './create-feature.use-case.js';
17
+ import type { CreateFeatureResult, CreateRecordResult } from './types.js';
18
+ export interface CreateFeatureFromRemoteInput {
19
+ /** GitHub URL or owner/repo shorthand */
20
+ remoteUrl: string;
21
+ /** Override clone destination directory */
22
+ cloneDest?: string;
23
+ /** Default base directory for clones (from settings) */
24
+ defaultCloneDir?: string;
25
+ /** Options for the clone subprocess */
26
+ cloneOptions?: CloneOptions;
27
+ /** Options for fork operations */
28
+ forkOptions?: ForkOptions;
29
+ userInput: string;
30
+ approvalGates?: ApprovalGates;
31
+ push?: boolean;
32
+ openPr?: boolean;
33
+ parentId?: string;
34
+ name?: string;
35
+ description?: string;
36
+ fast?: boolean;
37
+ pending?: boolean;
38
+ agentType?: string;
39
+ model?: string;
40
+ attachments?: Attachment[];
41
+ sessionId?: string;
42
+ attachmentPaths?: string[];
43
+ }
44
+ export declare class CreateFeatureFromRemoteUseCase {
45
+ private readonly importUseCase;
46
+ private readonly createFeatureUseCase;
47
+ constructor(importUseCase: ImportGitHubRepositoryUseCase, createFeatureUseCase: CreateFeatureUseCase);
48
+ /**
49
+ * Full synchronous execution: import repo then create feature.
50
+ * Used by the CLI which shows a spinner and needs everything done before returning.
51
+ */
52
+ execute(input: CreateFeatureFromRemoteInput): Promise<CreateFeatureResult>;
53
+ /**
54
+ * Phase 1 (fast): import repo + create DB record. Returns immediately with real feature ID.
55
+ * Used by the Web UI for optimistic display.
56
+ */
57
+ createRecord(input: CreateFeatureFromRemoteInput): Promise<CreateRecordResult>;
58
+ /**
59
+ * Phase 2 (background): metadata generation, worktree, spec, agent spawn.
60
+ * Fire-and-forget from the Web UI.
61
+ */
62
+ initializeAndSpawn(feature: Feature, input: CreateFeatureFromRemoteInput, shouldSpawn: boolean): Promise<{
63
+ warning?: string;
64
+ updatedFeature: Feature;
65
+ }>;
66
+ }
67
+ //# sourceMappingURL=create-feature-from-remote.use-case.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create-feature-from-remote.use-case.d.ts","sourceRoot":"","sources":["../../../../../../../../packages/core/src/application/use-cases/features/create/create-feature-from-remote.use-case.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAGH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,wCAAwC,CAAC;AACtE,OAAO,KAAK,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,wCAAwC,CAAC;AACxF,OAAO,KAAK,EACV,YAAY,EACZ,WAAW,EACZ,MAAM,uEAAuE,CAAC;AAC/E,OAAO,EAAE,6BAA6B,EAAE,MAAM,yDAAyD,CAAC;AACxG,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AACpE,OAAO,KAAK,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAE1E,MAAM,WAAW,4BAA4B;IAC3C,yCAAyC;IACzC,SAAS,EAAE,MAAM,CAAC;IAClB,2CAA2C;IAC3C,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,wDAAwD;IACxD,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,uCAAuC;IACvC,YAAY,CAAC,EAAE,YAAY,CAAC;IAC5B,kCAAkC;IAClC,WAAW,CAAC,EAAE,WAAW,CAAC;IAG1B,SAAS,EAAE,MAAM,CAAC;IAClB,aAAa,CAAC,EAAE,aAAa,CAAC;IAC9B,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,UAAU,EAAE,CAAC;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;CAC5B;AAED,qBACa,8BAA8B;IAGvC,OAAO,CAAC,QAAQ,CAAC,aAAa;IAE9B,OAAO,CAAC,QAAQ,CAAC,oBAAoB;gBAFpB,aAAa,EAAE,6BAA6B,EAE5C,oBAAoB,EAAE,oBAAoB;IAG7D;;;OAGG;IACG,OAAO,CAAC,KAAK,EAAE,4BAA4B,GAAG,OAAO,CAAC,mBAAmB,CAAC;IA4BhF;;;OAGG;IACG,YAAY,CAAC,KAAK,EAAE,4BAA4B,GAAG,OAAO,CAAC,kBAAkB,CAAC;IA4BpF;;;OAGG;IACG,kBAAkB,CACtB,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,4BAA4B,EACnC,WAAW,EAAE,OAAO,GACnB,OAAO,CAAC;QAAE,OAAO,CAAC,EAAE,MAAM,CAAC;QAAC,cAAc,EAAE,OAAO,CAAA;KAAE,CAAC;CA0B1D"}
@@ -0,0 +1,128 @@
1
+ /**
2
+ * Create Feature From Remote Use Case
3
+ *
4
+ * Composite use case that chains ImportGitHubRepositoryUseCase with
5
+ * CreateFeatureUseCase. Enables creating a feature on a remote GitHub
6
+ * repo in a single command — clone (or fork), register, then create feature.
7
+ *
8
+ * Provides two execution modes:
9
+ * - execute(): synchronous full flow for CLI
10
+ * - createRecord() + initializeAndSpawn(): two-phase for Web UI (fast response + background work)
11
+ */
12
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
13
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
14
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
15
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
16
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
17
+ };
18
+ var __metadata = (this && this.__metadata) || function (k, v) {
19
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
20
+ };
21
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
22
+ return function (target, key) { decorator(target, key, paramIndex); }
23
+ };
24
+ import { injectable, inject } from 'tsyringe';
25
+ import { ImportGitHubRepositoryUseCase } from '../../repositories/import-github-repository.use-case.js';
26
+ import { CreateFeatureUseCase } from './create-feature.use-case.js';
27
+ let CreateFeatureFromRemoteUseCase = class CreateFeatureFromRemoteUseCase {
28
+ importUseCase;
29
+ createFeatureUseCase;
30
+ constructor(importUseCase, createFeatureUseCase) {
31
+ this.importUseCase = importUseCase;
32
+ this.createFeatureUseCase = createFeatureUseCase;
33
+ }
34
+ /**
35
+ * Full synchronous execution: import repo then create feature.
36
+ * Used by the CLI which shows a spinner and needs everything done before returning.
37
+ */
38
+ async execute(input) {
39
+ const repository = await this.importUseCase.execute({
40
+ url: input.remoteUrl,
41
+ dest: input.cloneDest,
42
+ defaultCloneDir: input.defaultCloneDir,
43
+ cloneOptions: input.cloneOptions,
44
+ forkOptions: input.forkOptions,
45
+ });
46
+ return this.createFeatureUseCase.execute({
47
+ userInput: input.userInput,
48
+ repositoryPath: repository.path,
49
+ approvalGates: input.approvalGates,
50
+ push: input.push,
51
+ openPr: input.openPr,
52
+ parentId: input.parentId,
53
+ name: input.name,
54
+ description: input.description,
55
+ fast: input.fast,
56
+ pending: input.pending,
57
+ agentType: input.agentType,
58
+ model: input.model,
59
+ attachments: input.attachments,
60
+ sessionId: input.sessionId,
61
+ attachmentPaths: input.attachmentPaths,
62
+ });
63
+ }
64
+ /**
65
+ * Phase 1 (fast): import repo + create DB record. Returns immediately with real feature ID.
66
+ * Used by the Web UI for optimistic display.
67
+ */
68
+ async createRecord(input) {
69
+ const repository = await this.importUseCase.execute({
70
+ url: input.remoteUrl,
71
+ dest: input.cloneDest,
72
+ defaultCloneDir: input.defaultCloneDir,
73
+ cloneOptions: input.cloneOptions,
74
+ forkOptions: input.forkOptions,
75
+ });
76
+ return this.createFeatureUseCase.createRecord({
77
+ userInput: input.userInput,
78
+ repositoryPath: repository.path,
79
+ approvalGates: input.approvalGates,
80
+ push: input.push,
81
+ openPr: input.openPr,
82
+ parentId: input.parentId,
83
+ name: input.name,
84
+ description: input.description,
85
+ fast: input.fast,
86
+ pending: input.pending,
87
+ agentType: input.agentType,
88
+ model: input.model,
89
+ attachments: input.attachments,
90
+ sessionId: input.sessionId,
91
+ attachmentPaths: input.attachmentPaths,
92
+ });
93
+ }
94
+ /**
95
+ * Phase 2 (background): metadata generation, worktree, spec, agent spawn.
96
+ * Fire-and-forget from the Web UI.
97
+ */
98
+ async initializeAndSpawn(feature, input, shouldSpawn) {
99
+ return this.createFeatureUseCase.initializeAndSpawn(feature, {
100
+ userInput: input.userInput,
101
+ // CreateFeatureUseCase.initializeAndSpawn reads the effective repo path
102
+ // from feature.repositoryPath, but the interface still requires this
103
+ // field. Pass the feature's repositoryPath for consistency.
104
+ repositoryPath: feature.repositoryPath,
105
+ approvalGates: input.approvalGates,
106
+ push: input.push,
107
+ openPr: input.openPr,
108
+ parentId: input.parentId,
109
+ name: input.name,
110
+ description: input.description,
111
+ fast: input.fast,
112
+ pending: input.pending,
113
+ agentType: input.agentType,
114
+ model: input.model,
115
+ attachments: input.attachments,
116
+ sessionId: input.sessionId,
117
+ attachmentPaths: input.attachmentPaths,
118
+ }, shouldSpawn);
119
+ }
120
+ };
121
+ CreateFeatureFromRemoteUseCase = __decorate([
122
+ injectable(),
123
+ __param(0, inject(ImportGitHubRepositoryUseCase)),
124
+ __param(1, inject(CreateFeatureUseCase)),
125
+ __metadata("design:paramtypes", [ImportGitHubRepositoryUseCase,
126
+ CreateFeatureUseCase])
127
+ ], CreateFeatureFromRemoteUseCase);
128
+ export { CreateFeatureFromRemoteUseCase };
@@ -1 +1 @@
1
- {"version":3,"file":"create-feature.use-case.d.ts","sourceRoot":"","sources":["../../../../../../../../packages/core/src/application/use-cases/features/create/create-feature.use-case.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;GAgBG;AAIH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,wCAAwC,CAAC;AAMtE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oEAAoE,CAAC;AAC7G,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,8DAA8D,CAAC;AACrG,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,iEAAiE,CAAC;AACnH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,gEAAgE,CAAC;AAC1G,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,8DAA8D,CAAC;AAC5G,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,uEAAuE,CAAC;AACnH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,4DAA4D,CAAC;AAChG,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2DAA2D,CAAC;AACjG,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,4DAA4D,CAAC;AAIxG,OAAO,EAAE,wBAAwB,EAAE,MAAM,mEAAmE,CAAC;AAC7G,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,KAAK,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAE9F,qBACa,oBAAoB;IAG7B,OAAO,CAAC,QAAQ,CAAC,WAAW;IAE5B,OAAO,CAAC,QAAQ,CAAC,eAAe;IAEhC,OAAO,CAAC,QAAQ,CAAC,YAAY;IAE7B,OAAO,CAAC,QAAQ,CAAC,aAAa;IAE9B,OAAO,CAAC,QAAQ,CAAC,eAAe;IAEhC,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IAElC,OAAO,CAAC,QAAQ,CAAC,YAAY;IAE7B,OAAO,CAAC,QAAQ,CAAC,cAAc;IAE/B,OAAO,CAAC,QAAQ,CAAC,YAAY;IAE7B,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IAElC,OAAO,CAAC,QAAQ,CAAC,cAAc;IAE/B,OAAO,CAAC,QAAQ,CAAC,aAAa;gBAtBb,WAAW,EAAE,kBAAkB,EAE/B,eAAe,EAAE,gBAAgB,EAEjC,YAAY,EAAE,2BAA2B,EAEzC,aAAa,EAAE,mBAAmB,EAElC,eAAe,EAAE,uBAAuB,EAExC,iBAAiB,EAAE,iBAAiB,EAEpC,YAAY,EAAE,YAAY,EAE1B,cAAc,EAAE,qBAAqB,EAErC,YAAY,EAAE,aAAa,EAE3B,iBAAiB,EAAE,wBAAwB,EAE3C,cAAc,EAAE,eAAe,EAE/B,aAAa,EAAE,qBAAqB;IAGvD;;;OAGG;IACG,OAAO,CAAC,KAAK,EAAE,kBAAkB,GAAG,OAAO,CAAC,mBAAmB,CAAC;IAMtE;;;;OAIG;IACG,YAAY,CAAC,KAAK,EAAE,kBAAkB,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAyI1E;;;OAGG;IACG,kBAAkB,CACtB,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,kBAAkB,EACzB,WAAW,EAAE,OAAO,GACnB,OAAO,CAAC;QAAE,OAAO,CAAC,EAAE,MAAM,CAAC;QAAC,cAAc,EAAE,OAAO,CAAA;KAAE,CAAC;CAsK1D"}
1
+ {"version":3,"file":"create-feature.use-case.d.ts","sourceRoot":"","sources":["../../../../../../../../packages/core/src/application/use-cases/features/create/create-feature.use-case.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;GAgBG;AAIH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,wCAAwC,CAAC;AAMtE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oEAAoE,CAAC;AAC7G,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,8DAA8D,CAAC;AACrG,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,iEAAiE,CAAC;AACnH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,gEAAgE,CAAC;AAC1G,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,8DAA8D,CAAC;AAC5G,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,uEAAuE,CAAC;AACnH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,4DAA4D,CAAC;AAChG,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2DAA2D,CAAC;AACjG,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,4DAA4D,CAAC;AAIxG,OAAO,EAAE,wBAAwB,EAAE,MAAM,mEAAmE,CAAC;AAC7G,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,KAAK,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAE9F,qBACa,oBAAoB;IAG7B,OAAO,CAAC,QAAQ,CAAC,WAAW;IAE5B,OAAO,CAAC,QAAQ,CAAC,eAAe;IAEhC,OAAO,CAAC,QAAQ,CAAC,YAAY;IAE7B,OAAO,CAAC,QAAQ,CAAC,aAAa;IAE9B,OAAO,CAAC,QAAQ,CAAC,eAAe;IAEhC,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IAElC,OAAO,CAAC,QAAQ,CAAC,YAAY;IAE7B,OAAO,CAAC,QAAQ,CAAC,cAAc;IAE/B,OAAO,CAAC,QAAQ,CAAC,YAAY;IAE7B,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IAElC,OAAO,CAAC,QAAQ,CAAC,cAAc;IAE/B,OAAO,CAAC,QAAQ,CAAC,aAAa;gBAtBb,WAAW,EAAE,kBAAkB,EAE/B,eAAe,EAAE,gBAAgB,EAEjC,YAAY,EAAE,2BAA2B,EAEzC,aAAa,EAAE,mBAAmB,EAElC,eAAe,EAAE,uBAAuB,EAExC,iBAAiB,EAAE,iBAAiB,EAEpC,YAAY,EAAE,YAAY,EAE1B,cAAc,EAAE,qBAAqB,EAErC,YAAY,EAAE,aAAa,EAE3B,iBAAiB,EAAE,wBAAwB,EAE3C,cAAc,EAAE,eAAe,EAE/B,aAAa,EAAE,qBAAqB;IAGvD;;;OAGG;IACG,OAAO,CAAC,KAAK,EAAE,kBAAkB,GAAG,OAAO,CAAC,mBAAmB,CAAC;IAMtE;;;;OAIG;IACG,YAAY,CAAC,KAAK,EAAE,kBAAkB,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAyI1E;;;OAGG;IACG,kBAAkB,CACtB,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,kBAAkB,EACzB,WAAW,EAAE,OAAO,GACnB,OAAO,CAAC;QAAE,OAAO,CAAC,EAAE,MAAM,CAAC;QAAC,cAAc,EAAE,OAAO,CAAA;KAAE,CAAC;CAuK1D"}
@@ -326,6 +326,7 @@ let CreateFeatureUseCase = class CreateFeatureUseCase {
326
326
  ...(input.fast ? { fast: true } : {}),
327
327
  ...(input.agentType ? { agentType: input.agentType } : {}),
328
328
  ...(input.model ? { model: input.model } : {}),
329
+ securityMode: settings.security?.mode,
329
330
  });
330
331
  }
331
332
  return { warning, updatedFeature };
@@ -1 +1 @@
1
- {"version":3,"file":"resume-feature.use-case.d.ts","sourceRoot":"","sources":["../../../../../../../packages/core/src/application/use-cases/features/resume-feature.use-case.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,qCAAqC,CAAC;AAE7E,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iEAAiE,CAAC;AAC1G,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,6DAA6D,CAAC;AACvG,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,8DAA8D,CAAC;AAChH,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,2DAA2D,CAAC;AAQlG,MAAM,WAAW,mBAAmB;IAClC,OAAO,EAAE,OAAO,CAAC;IACjB,MAAM,EAAE,QAAQ,CAAC;CAClB;AAED,qBACa,oBAAoB;IAG7B,OAAO,CAAC,QAAQ,CAAC,WAAW;IAE5B,OAAO,CAAC,QAAQ,CAAC,OAAO;IAExB,OAAO,CAAC,QAAQ,CAAC,cAAc;IAE/B,OAAO,CAAC,QAAQ,CAAC,eAAe;gBANf,WAAW,EAAE,kBAAkB,EAE/B,OAAO,EAAE,mBAAmB,EAE5B,cAAc,EAAE,2BAA2B,EAE3C,eAAe,EAAE,gBAAgB;IAG9C,OAAO,CACX,SAAS,EAAE,MAAM,EACjB,OAAO,CAAC,EAAE;QAAE,YAAY,CAAC,EAAE,MAAM,CAAA;KAAE,GAClC,OAAO,CAAC,mBAAmB,CAAC;CA4GhC"}
1
+ {"version":3,"file":"resume-feature.use-case.d.ts","sourceRoot":"","sources":["../../../../../../../packages/core/src/application/use-cases/features/resume-feature.use-case.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,qCAAqC,CAAC;AAE7E,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iEAAiE,CAAC;AAC1G,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,6DAA6D,CAAC;AACvG,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,8DAA8D,CAAC;AAChH,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,2DAA2D,CAAC;AASlG,MAAM,WAAW,mBAAmB;IAClC,OAAO,EAAE,OAAO,CAAC;IACjB,MAAM,EAAE,QAAQ,CAAC;CAClB;AAED,qBACa,oBAAoB;IAG7B,OAAO,CAAC,QAAQ,CAAC,WAAW;IAE5B,OAAO,CAAC,QAAQ,CAAC,OAAO;IAExB,OAAO,CAAC,QAAQ,CAAC,cAAc;IAE/B,OAAO,CAAC,QAAQ,CAAC,eAAe;gBANf,WAAW,EAAE,kBAAkB,EAE/B,OAAO,EAAE,mBAAmB,EAE5B,cAAc,EAAE,2BAA2B,EAE3C,eAAe,EAAE,gBAAgB;IAG9C,OAAO,CACX,SAAS,EAAE,MAAM,EACjB,OAAO,CAAC,EAAE;QAAE,YAAY,CAAC,EAAE,MAAM,CAAA;KAAE,GAClC,OAAO,CAAC,mBAAmB,CAAC;CA6GhC"}
@@ -19,6 +19,7 @@ var __param = (this && this.__param) || function (paramIndex, decorator) {
19
19
  import { injectable, inject } from 'tsyringe';
20
20
  import { randomUUID } from 'node:crypto';
21
21
  import { AgentRunStatus } from '../../../domain/generated/output.js';
22
+ import { getSettings } from '../../../infrastructure/services/settings.service.js';
22
23
  const RESUMABLE_STATUSES = new Set([
23
24
  AgentRunStatus.interrupted,
24
25
  AgentRunStatus.failed,
@@ -118,6 +119,7 @@ let ResumeFeatureUseCase = class ResumeFeatureUseCase {
118
119
  ...(feature.fast ? { fast: true } : {}),
119
120
  ...(lastRun.modelId ? { model: lastRun.modelId } : {}),
120
121
  resumeReason: lastRun.status,
122
+ securityMode: getSettings().security?.mode,
121
123
  });
122
124
  return { feature, newRun };
123
125
  }
@@ -1 +1 @@
1
- {"version":3,"file":"start-feature.use-case.d.ts","sourceRoot":"","sources":["../../../../../../../packages/core/src/application/use-cases/features/start-feature.use-case.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAGH,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,qCAAqC,CAAC;AAE7E,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iEAAiE,CAAC;AAC1G,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,6DAA6D,CAAC;AACvG,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,8DAA8D,CAAC;AAChH,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,2DAA2D,CAAC;AAGlG,MAAM,WAAW,kBAAkB;IACjC,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,EAAE,QAAQ,CAAC;CACpB;AAED,qBACa,mBAAmB;IAG5B,OAAO,CAAC,QAAQ,CAAC,WAAW;IAE5B,OAAO,CAAC,QAAQ,CAAC,OAAO;IAExB,OAAO,CAAC,QAAQ,CAAC,cAAc;IAE/B,OAAO,CAAC,QAAQ,CAAC,eAAe;gBANf,WAAW,EAAE,kBAAkB,EAE/B,OAAO,EAAE,mBAAmB,EAE5B,cAAc,EAAE,2BAA2B,EAE3C,eAAe,EAAE,gBAAgB;IAG9C,OAAO,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC;CAyG9D"}
1
+ {"version":3,"file":"start-feature.use-case.d.ts","sourceRoot":"","sources":["../../../../../../../packages/core/src/application/use-cases/features/start-feature.use-case.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAGH,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,qCAAqC,CAAC;AAE7E,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iEAAiE,CAAC;AAC1G,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,6DAA6D,CAAC;AACvG,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,8DAA8D,CAAC;AAChH,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,2DAA2D,CAAC;AAIlG,MAAM,WAAW,kBAAkB;IACjC,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,EAAE,QAAQ,CAAC;CACpB;AAED,qBACa,mBAAmB;IAG5B,OAAO,CAAC,QAAQ,CAAC,WAAW;IAE5B,OAAO,CAAC,QAAQ,CAAC,OAAO;IAExB,OAAO,CAAC,QAAQ,CAAC,cAAc;IAE/B,OAAO,CAAC,QAAQ,CAAC,eAAe;gBANf,WAAW,EAAE,kBAAkB,EAE/B,OAAO,EAAE,mBAAmB,EAE5B,cAAc,EAAE,2BAA2B,EAE3C,eAAe,EAAE,gBAAgB;IAG9C,OAAO,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC;CA0G9D"}
@@ -20,6 +20,7 @@ var __param = (this && this.__param) || function (paramIndex, decorator) {
20
20
  import { injectable, inject } from 'tsyringe';
21
21
  import { SdlcLifecycle } from '../../../domain/generated/output.js';
22
22
  import { POST_IMPLEMENTATION } from '../../../domain/lifecycle-gates.js';
23
+ import { getSettings } from '../../../infrastructure/services/settings.service.js';
23
24
  let StartFeatureUseCase = class StartFeatureUseCase {
24
25
  featureRepo;
25
26
  runRepo;
@@ -105,6 +106,7 @@ let StartFeatureUseCase = class StartFeatureUseCase {
105
106
  agentType: agentRun.agentType,
106
107
  ...(resolved.fast ? { fast: true } : {}),
107
108
  ...(agentRun.modelId ? { model: agentRun.modelId } : {}),
109
+ securityMode: getSettings().security?.mode,
108
110
  });
109
111
  }
110
112
  return { feature: updatedFeature, agentRun };