@friggframework/devtools 2.0.0-next.6 → 2.0.0-next.60

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 (357) hide show
  1. package/frigg-cli/README.md +1289 -0
  2. package/frigg-cli/__tests__/unit/commands/build.test.js +279 -0
  3. package/frigg-cli/__tests__/unit/commands/db-setup.test.js +649 -0
  4. package/frigg-cli/__tests__/unit/commands/deploy.test.js +320 -0
  5. package/frigg-cli/__tests__/unit/commands/doctor.test.js +309 -0
  6. package/frigg-cli/__tests__/unit/commands/install.test.js +400 -0
  7. package/frigg-cli/__tests__/unit/commands/ui.test.js +346 -0
  8. package/frigg-cli/__tests__/unit/dependencies.test.js +74 -0
  9. package/frigg-cli/__tests__/unit/utils/database-validator.test.js +397 -0
  10. package/frigg-cli/__tests__/unit/utils/error-messages.test.js +345 -0
  11. package/frigg-cli/__tests__/unit/version-detection.test.js +171 -0
  12. package/frigg-cli/__tests__/utils/mock-factory.js +270 -0
  13. package/frigg-cli/__tests__/utils/prisma-mock.js +194 -0
  14. package/frigg-cli/__tests__/utils/test-fixtures.js +463 -0
  15. package/frigg-cli/__tests__/utils/test-setup.js +287 -0
  16. package/frigg-cli/build-command/index.js +53 -14
  17. package/frigg-cli/db-setup-command/index.js +246 -0
  18. package/frigg-cli/deploy-command/SPEC-DEPLOY-DRY-RUN.md +981 -0
  19. package/frigg-cli/deploy-command/index.js +295 -17
  20. package/frigg-cli/doctor-command/index.js +335 -0
  21. package/frigg-cli/generate-command/__tests__/generate-command.test.js +301 -0
  22. package/frigg-cli/generate-command/azure-generator.js +43 -0
  23. package/frigg-cli/generate-command/gcp-generator.js +47 -0
  24. package/frigg-cli/generate-command/index.js +332 -0
  25. package/frigg-cli/generate-command/terraform-generator.js +555 -0
  26. package/frigg-cli/generate-iam-command.js +118 -0
  27. package/frigg-cli/index.js +142 -1
  28. package/frigg-cli/index.test.js +1 -4
  29. package/frigg-cli/init-command/backend-first-handler.js +756 -0
  30. package/frigg-cli/init-command/index.js +93 -0
  31. package/frigg-cli/init-command/template-handler.js +143 -0
  32. package/frigg-cli/install-command/index.js +1 -4
  33. package/frigg-cli/jest.config.js +124 -0
  34. package/frigg-cli/package.json +63 -0
  35. package/frigg-cli/repair-command/index.js +564 -0
  36. package/frigg-cli/start-command/index.js +125 -6
  37. package/frigg-cli/start-command/start-command.test.js +297 -0
  38. package/frigg-cli/test/init-command.test.js +180 -0
  39. package/frigg-cli/test/npm-registry.test.js +319 -0
  40. package/frigg-cli/ui-command/index.js +154 -0
  41. package/frigg-cli/utils/app-resolver.js +319 -0
  42. package/frigg-cli/utils/backend-path.js +16 -17
  43. package/frigg-cli/utils/database-validator.js +167 -0
  44. package/frigg-cli/utils/error-messages.js +329 -0
  45. package/frigg-cli/utils/npm-registry.js +167 -0
  46. package/frigg-cli/utils/process-manager.js +199 -0
  47. package/frigg-cli/utils/repo-detection.js +405 -0
  48. package/infrastructure/ARCHITECTURE.md +487 -0
  49. package/infrastructure/CLAUDE.md +481 -0
  50. package/infrastructure/HEALTH.md +468 -0
  51. package/infrastructure/README.md +522 -0
  52. package/infrastructure/__tests__/fixtures/mock-aws-resources.js +391 -0
  53. package/infrastructure/__tests__/helpers/test-utils.js +277 -0
  54. package/infrastructure/__tests__/postgres-config.test.js +914 -0
  55. package/infrastructure/__tests__/template-generation.test.js +687 -0
  56. package/infrastructure/create-frigg-infrastructure.js +129 -20
  57. package/infrastructure/docs/POSTGRES-CONFIGURATION.md +630 -0
  58. package/infrastructure/docs/PRE-DEPLOYMENT-HEALTH-CHECK-SPEC.md +1317 -0
  59. package/infrastructure/docs/WEBSOCKET-CONFIGURATION.md +105 -0
  60. package/infrastructure/docs/deployment-instructions.md +268 -0
  61. package/infrastructure/docs/generate-iam-command.md +278 -0
  62. package/infrastructure/docs/iam-policy-templates.md +193 -0
  63. package/infrastructure/domains/database/aurora-builder.js +809 -0
  64. package/infrastructure/domains/database/aurora-builder.test.js +950 -0
  65. package/infrastructure/domains/database/aurora-discovery.js +87 -0
  66. package/infrastructure/domains/database/aurora-discovery.test.js +188 -0
  67. package/infrastructure/domains/database/aurora-resolver.js +210 -0
  68. package/infrastructure/domains/database/aurora-resolver.test.js +347 -0
  69. package/infrastructure/domains/database/migration-builder.js +701 -0
  70. package/infrastructure/domains/database/migration-builder.test.js +321 -0
  71. package/infrastructure/domains/database/migration-resolver.js +163 -0
  72. package/infrastructure/domains/database/migration-resolver.test.js +337 -0
  73. package/infrastructure/domains/health/application/ports/IPropertyReconciler.js +164 -0
  74. package/infrastructure/domains/health/application/ports/IResourceDetector.js +129 -0
  75. package/infrastructure/domains/health/application/ports/IResourceImporter.js +142 -0
  76. package/infrastructure/domains/health/application/ports/IStackRepository.js +131 -0
  77. package/infrastructure/domains/health/application/ports/index.js +26 -0
  78. package/infrastructure/domains/health/application/use-cases/__tests__/execute-resource-import-use-case.test.js +679 -0
  79. package/infrastructure/domains/health/application/use-cases/__tests__/mismatch-analyzer-method-name.test.js +167 -0
  80. package/infrastructure/domains/health/application/use-cases/__tests__/repair-via-import-use-case.test.js +1130 -0
  81. package/infrastructure/domains/health/application/use-cases/execute-resource-import-use-case.js +221 -0
  82. package/infrastructure/domains/health/application/use-cases/reconcile-properties-use-case.js +152 -0
  83. package/infrastructure/domains/health/application/use-cases/reconcile-properties-use-case.test.js +343 -0
  84. package/infrastructure/domains/health/application/use-cases/repair-via-import-use-case.js +535 -0
  85. package/infrastructure/domains/health/application/use-cases/repair-via-import-use-case.test.js +376 -0
  86. package/infrastructure/domains/health/application/use-cases/run-health-check-use-case.js +213 -0
  87. package/infrastructure/domains/health/application/use-cases/run-health-check-use-case.test.js +441 -0
  88. package/infrastructure/domains/health/docs/ACME-DEV-DRIFT-ANALYSIS.md +267 -0
  89. package/infrastructure/domains/health/docs/BUILD-VS-DEPLOYED-TEMPLATE-ANALYSIS.md +324 -0
  90. package/infrastructure/domains/health/docs/ORPHAN-DETECTION-ANALYSIS.md +386 -0
  91. package/infrastructure/domains/health/docs/SPEC-CLEANUP-COMMAND.md +1419 -0
  92. package/infrastructure/domains/health/docs/TDD-IMPLEMENTATION-SUMMARY.md +391 -0
  93. package/infrastructure/domains/health/docs/TEMPLATE-COMPARISON-IMPLEMENTATION.md +551 -0
  94. package/infrastructure/domains/health/domain/entities/issue.js +299 -0
  95. package/infrastructure/domains/health/domain/entities/issue.test.js +528 -0
  96. package/infrastructure/domains/health/domain/entities/property-mismatch.js +108 -0
  97. package/infrastructure/domains/health/domain/entities/property-mismatch.test.js +275 -0
  98. package/infrastructure/domains/health/domain/entities/resource.js +159 -0
  99. package/infrastructure/domains/health/domain/entities/resource.test.js +432 -0
  100. package/infrastructure/domains/health/domain/entities/stack-health-report.js +306 -0
  101. package/infrastructure/domains/health/domain/entities/stack-health-report.test.js +601 -0
  102. package/infrastructure/domains/health/domain/services/__tests__/health-score-percentage-based.test.js +380 -0
  103. package/infrastructure/domains/health/domain/services/__tests__/import-progress-monitor.test.js +971 -0
  104. package/infrastructure/domains/health/domain/services/__tests__/import-template-generator.test.js +1150 -0
  105. package/infrastructure/domains/health/domain/services/__tests__/logical-id-mapper.test.js +672 -0
  106. package/infrastructure/domains/health/domain/services/__tests__/template-parser.test.js +496 -0
  107. package/infrastructure/domains/health/domain/services/__tests__/update-progress-monitor.test.js +419 -0
  108. package/infrastructure/domains/health/domain/services/health-score-calculator.js +248 -0
  109. package/infrastructure/domains/health/domain/services/health-score-calculator.test.js +504 -0
  110. package/infrastructure/domains/health/domain/services/import-progress-monitor.js +195 -0
  111. package/infrastructure/domains/health/domain/services/import-template-generator.js +435 -0
  112. package/infrastructure/domains/health/domain/services/logical-id-mapper.js +345 -0
  113. package/infrastructure/domains/health/domain/services/mismatch-analyzer.js +234 -0
  114. package/infrastructure/domains/health/domain/services/mismatch-analyzer.test.js +431 -0
  115. package/infrastructure/domains/health/domain/services/property-mutability-config.js +382 -0
  116. package/infrastructure/domains/health/domain/services/template-parser.js +245 -0
  117. package/infrastructure/domains/health/domain/services/update-progress-monitor.js +192 -0
  118. package/infrastructure/domains/health/domain/value-objects/health-score.js +138 -0
  119. package/infrastructure/domains/health/domain/value-objects/health-score.test.js +267 -0
  120. package/infrastructure/domains/health/domain/value-objects/property-mutability.js +161 -0
  121. package/infrastructure/domains/health/domain/value-objects/property-mutability.test.js +198 -0
  122. package/infrastructure/domains/health/domain/value-objects/resource-state.js +167 -0
  123. package/infrastructure/domains/health/domain/value-objects/resource-state.test.js +196 -0
  124. package/infrastructure/domains/health/domain/value-objects/stack-identifier.js +192 -0
  125. package/infrastructure/domains/health/domain/value-objects/stack-identifier.test.js +262 -0
  126. package/infrastructure/domains/health/infrastructure/adapters/__tests__/orphan-detection-cfn-tagged.test.js +312 -0
  127. package/infrastructure/domains/health/infrastructure/adapters/__tests__/orphan-detection-multi-stack.test.js +367 -0
  128. package/infrastructure/domains/health/infrastructure/adapters/__tests__/orphan-detection-relationship-analysis.test.js +432 -0
  129. package/infrastructure/domains/health/infrastructure/adapters/aws-property-reconciler.js +784 -0
  130. package/infrastructure/domains/health/infrastructure/adapters/aws-property-reconciler.test.js +1133 -0
  131. package/infrastructure/domains/health/infrastructure/adapters/aws-resource-detector.js +565 -0
  132. package/infrastructure/domains/health/infrastructure/adapters/aws-resource-detector.test.js +554 -0
  133. package/infrastructure/domains/health/infrastructure/adapters/aws-resource-importer.js +318 -0
  134. package/infrastructure/domains/health/infrastructure/adapters/aws-resource-importer.test.js +398 -0
  135. package/infrastructure/domains/health/infrastructure/adapters/aws-stack-repository.js +777 -0
  136. package/infrastructure/domains/health/infrastructure/adapters/aws-stack-repository.test.js +580 -0
  137. package/infrastructure/domains/integration/integration-builder.js +404 -0
  138. package/infrastructure/domains/integration/integration-builder.test.js +690 -0
  139. package/infrastructure/domains/integration/integration-resolver.js +170 -0
  140. package/infrastructure/domains/integration/integration-resolver.test.js +369 -0
  141. package/infrastructure/domains/integration/websocket-builder.js +69 -0
  142. package/infrastructure/domains/integration/websocket-builder.test.js +195 -0
  143. package/infrastructure/domains/networking/vpc-builder.js +2051 -0
  144. package/infrastructure/domains/networking/vpc-builder.test.js +1960 -0
  145. package/infrastructure/domains/networking/vpc-discovery.js +177 -0
  146. package/infrastructure/domains/networking/vpc-discovery.test.js +350 -0
  147. package/infrastructure/domains/networking/vpc-resolver.js +505 -0
  148. package/infrastructure/domains/networking/vpc-resolver.test.js +801 -0
  149. package/infrastructure/domains/parameters/ssm-builder.js +79 -0
  150. package/infrastructure/domains/parameters/ssm-builder.test.js +189 -0
  151. package/infrastructure/domains/parameters/ssm-discovery.js +84 -0
  152. package/infrastructure/domains/parameters/ssm-discovery.test.js +210 -0
  153. package/infrastructure/domains/security/iam-generator.js +816 -0
  154. package/infrastructure/domains/security/iam-generator.test.js +204 -0
  155. package/infrastructure/domains/security/kms-builder.js +415 -0
  156. package/infrastructure/domains/security/kms-builder.test.js +392 -0
  157. package/infrastructure/domains/security/kms-discovery.js +80 -0
  158. package/infrastructure/domains/security/kms-discovery.test.js +177 -0
  159. package/infrastructure/domains/security/kms-resolver.js +96 -0
  160. package/infrastructure/domains/security/kms-resolver.test.js +216 -0
  161. package/infrastructure/domains/security/templates/frigg-deployment-iam-stack.yaml +401 -0
  162. package/infrastructure/domains/security/templates/iam-policy-basic.json +218 -0
  163. package/infrastructure/domains/security/templates/iam-policy-full.json +288 -0
  164. package/infrastructure/domains/shared/base-builder.js +112 -0
  165. package/infrastructure/domains/shared/base-resolver.js +186 -0
  166. package/infrastructure/domains/shared/base-resolver.test.js +305 -0
  167. package/infrastructure/domains/shared/builder-orchestrator.js +212 -0
  168. package/infrastructure/domains/shared/builder-orchestrator.test.js +213 -0
  169. package/infrastructure/domains/shared/cloudformation-discovery-v2.js +334 -0
  170. package/infrastructure/domains/shared/cloudformation-discovery.js +672 -0
  171. package/infrastructure/domains/shared/cloudformation-discovery.test.js +985 -0
  172. package/infrastructure/domains/shared/environment-builder.js +119 -0
  173. package/infrastructure/domains/shared/environment-builder.test.js +247 -0
  174. package/infrastructure/domains/shared/providers/aws-provider-adapter.js +579 -0
  175. package/infrastructure/domains/shared/providers/aws-provider-adapter.test.js +416 -0
  176. package/infrastructure/domains/shared/providers/azure-provider-adapter.stub.js +93 -0
  177. package/infrastructure/domains/shared/providers/cloud-provider-adapter.js +136 -0
  178. package/infrastructure/domains/shared/providers/gcp-provider-adapter.stub.js +82 -0
  179. package/infrastructure/domains/shared/providers/provider-factory.js +108 -0
  180. package/infrastructure/domains/shared/providers/provider-factory.test.js +170 -0
  181. package/infrastructure/domains/shared/resource-discovery.enhanced.test.js +306 -0
  182. package/infrastructure/domains/shared/resource-discovery.js +233 -0
  183. package/infrastructure/domains/shared/resource-discovery.test.js +588 -0
  184. package/infrastructure/domains/shared/types/app-definition.js +205 -0
  185. package/infrastructure/domains/shared/types/discovery-result.js +106 -0
  186. package/infrastructure/domains/shared/types/discovery-result.test.js +258 -0
  187. package/infrastructure/domains/shared/types/index.js +46 -0
  188. package/infrastructure/domains/shared/types/resource-ownership.js +108 -0
  189. package/infrastructure/domains/shared/types/resource-ownership.test.js +101 -0
  190. package/infrastructure/domains/shared/utilities/base-definition-factory.js +394 -0
  191. package/infrastructure/domains/shared/utilities/base-definition-factory.js.bak +338 -0
  192. package/infrastructure/domains/shared/utilities/base-definition-factory.test.js +291 -0
  193. package/infrastructure/domains/shared/utilities/handler-path-resolver.js +134 -0
  194. package/infrastructure/domains/shared/utilities/handler-path-resolver.test.js +268 -0
  195. package/infrastructure/domains/shared/utilities/prisma-layer-manager.js +159 -0
  196. package/infrastructure/domains/shared/utilities/prisma-layer-manager.test.js +444 -0
  197. package/infrastructure/domains/shared/validation/env-validator.js +78 -0
  198. package/infrastructure/domains/shared/validation/env-validator.test.js +173 -0
  199. package/infrastructure/domains/shared/validation/plugin-validator.js +187 -0
  200. package/infrastructure/domains/shared/validation/plugin-validator.test.js +323 -0
  201. package/infrastructure/esbuild.config.js +53 -0
  202. package/infrastructure/infrastructure-composer.js +117 -0
  203. package/infrastructure/infrastructure-composer.test.js +1895 -0
  204. package/infrastructure/integration.test.js +383 -0
  205. package/infrastructure/scripts/build-prisma-layer.js +701 -0
  206. package/infrastructure/scripts/build-prisma-layer.test.js +170 -0
  207. package/infrastructure/scripts/build-time-discovery.js +238 -0
  208. package/infrastructure/scripts/build-time-discovery.test.js +379 -0
  209. package/infrastructure/scripts/run-discovery.js +110 -0
  210. package/infrastructure/scripts/verify-prisma-layer.js +72 -0
  211. package/layers/prisma/.build-complete +3 -0
  212. package/layers/prisma/nodejs/package.json +8 -0
  213. package/management-ui/.eslintrc.js +22 -0
  214. package/management-ui/README.md +203 -0
  215. package/management-ui/components.json +21 -0
  216. package/management-ui/docs/phase2-integration-guide.md +320 -0
  217. package/management-ui/index.html +13 -0
  218. package/management-ui/package.json +76 -0
  219. package/management-ui/packages/devtools/frigg-cli/ui-command/index.js +302 -0
  220. package/management-ui/postcss.config.js +6 -0
  221. package/management-ui/server/api/backend.js +256 -0
  222. package/management-ui/server/api/cli.js +315 -0
  223. package/management-ui/server/api/codegen.js +663 -0
  224. package/management-ui/server/api/connections.js +857 -0
  225. package/management-ui/server/api/discovery.js +185 -0
  226. package/management-ui/server/api/environment/index.js +1 -0
  227. package/management-ui/server/api/environment/router.js +378 -0
  228. package/management-ui/server/api/environment.js +328 -0
  229. package/management-ui/server/api/integrations.js +876 -0
  230. package/management-ui/server/api/logs.js +248 -0
  231. package/management-ui/server/api/monitoring.js +282 -0
  232. package/management-ui/server/api/open-ide.js +31 -0
  233. package/management-ui/server/api/project.js +1029 -0
  234. package/management-ui/server/api/users/sessions.js +371 -0
  235. package/management-ui/server/api/users/simulation.js +254 -0
  236. package/management-ui/server/api/users.js +362 -0
  237. package/management-ui/server/api-contract.md +275 -0
  238. package/management-ui/server/index.js +873 -0
  239. package/management-ui/server/middleware/errorHandler.js +93 -0
  240. package/management-ui/server/middleware/security.js +32 -0
  241. package/management-ui/server/processManager.js +296 -0
  242. package/management-ui/server/server.js +346 -0
  243. package/management-ui/server/services/aws-monitor.js +413 -0
  244. package/management-ui/server/services/npm-registry.js +347 -0
  245. package/management-ui/server/services/template-engine.js +538 -0
  246. package/management-ui/server/utils/cliIntegration.js +220 -0
  247. package/management-ui/server/utils/environment/auditLogger.js +471 -0
  248. package/management-ui/server/utils/environment/awsParameterStore.js +275 -0
  249. package/management-ui/server/utils/environment/encryption.js +278 -0
  250. package/management-ui/server/utils/environment/envFileManager.js +286 -0
  251. package/management-ui/server/utils/import-commonjs.js +28 -0
  252. package/management-ui/server/utils/response.js +83 -0
  253. package/management-ui/server/websocket/handler.js +325 -0
  254. package/management-ui/src/App.jsx +25 -0
  255. package/management-ui/src/assets/FriggLogo.svg +1 -0
  256. package/management-ui/src/components/AppRouter.jsx +65 -0
  257. package/management-ui/src/components/Button.jsx +70 -0
  258. package/management-ui/src/components/Card.jsx +97 -0
  259. package/management-ui/src/components/EnvironmentCompare.jsx +400 -0
  260. package/management-ui/src/components/EnvironmentEditor.jsx +372 -0
  261. package/management-ui/src/components/EnvironmentImportExport.jsx +469 -0
  262. package/management-ui/src/components/EnvironmentSchema.jsx +491 -0
  263. package/management-ui/src/components/EnvironmentSecurity.jsx +463 -0
  264. package/management-ui/src/components/ErrorBoundary.jsx +73 -0
  265. package/management-ui/src/components/IntegrationCard.jsx +481 -0
  266. package/management-ui/src/components/IntegrationCardEnhanced.jsx +770 -0
  267. package/management-ui/src/components/IntegrationExplorer.jsx +379 -0
  268. package/management-ui/src/components/IntegrationStatus.jsx +336 -0
  269. package/management-ui/src/components/Layout.jsx +716 -0
  270. package/management-ui/src/components/LoadingSpinner.jsx +113 -0
  271. package/management-ui/src/components/RepositoryPicker.jsx +248 -0
  272. package/management-ui/src/components/SessionMonitor.jsx +350 -0
  273. package/management-ui/src/components/StatusBadge.jsx +208 -0
  274. package/management-ui/src/components/UserContextSwitcher.jsx +212 -0
  275. package/management-ui/src/components/UserSimulation.jsx +327 -0
  276. package/management-ui/src/components/Welcome.jsx +434 -0
  277. package/management-ui/src/components/codegen/APIEndpointGenerator.jsx +637 -0
  278. package/management-ui/src/components/codegen/APIModuleSelector.jsx +227 -0
  279. package/management-ui/src/components/codegen/CodeGenerationWizard.jsx +247 -0
  280. package/management-ui/src/components/codegen/CodePreviewEditor.jsx +316 -0
  281. package/management-ui/src/components/codegen/DynamicModuleForm.jsx +271 -0
  282. package/management-ui/src/components/codegen/FormBuilder.jsx +737 -0
  283. package/management-ui/src/components/codegen/IntegrationGenerator.jsx +855 -0
  284. package/management-ui/src/components/codegen/ProjectScaffoldWizard.jsx +797 -0
  285. package/management-ui/src/components/codegen/SchemaBuilder.jsx +303 -0
  286. package/management-ui/src/components/codegen/TemplateSelector.jsx +586 -0
  287. package/management-ui/src/components/codegen/index.js +10 -0
  288. package/management-ui/src/components/connections/ConnectionConfigForm.jsx +362 -0
  289. package/management-ui/src/components/connections/ConnectionHealthMonitor.jsx +182 -0
  290. package/management-ui/src/components/connections/ConnectionTester.jsx +200 -0
  291. package/management-ui/src/components/connections/EntityRelationshipMapper.jsx +292 -0
  292. package/management-ui/src/components/connections/OAuthFlow.jsx +204 -0
  293. package/management-ui/src/components/connections/index.js +5 -0
  294. package/management-ui/src/components/index.js +21 -0
  295. package/management-ui/src/components/monitoring/APIGatewayMetrics.jsx +222 -0
  296. package/management-ui/src/components/monitoring/LambdaMetrics.jsx +169 -0
  297. package/management-ui/src/components/monitoring/MetricsChart.jsx +197 -0
  298. package/management-ui/src/components/monitoring/MonitoringDashboard.jsx +393 -0
  299. package/management-ui/src/components/monitoring/SQSMetrics.jsx +246 -0
  300. package/management-ui/src/components/monitoring/index.js +6 -0
  301. package/management-ui/src/components/monitoring/monitoring.css +218 -0
  302. package/management-ui/src/components/theme-provider.jsx +52 -0
  303. package/management-ui/src/components/theme-toggle.jsx +39 -0
  304. package/management-ui/src/components/ui/badge.tsx +36 -0
  305. package/management-ui/src/components/ui/button.test.jsx +56 -0
  306. package/management-ui/src/components/ui/button.tsx +57 -0
  307. package/management-ui/src/components/ui/card.tsx +76 -0
  308. package/management-ui/src/components/ui/dropdown-menu.tsx +199 -0
  309. package/management-ui/src/components/ui/select.tsx +157 -0
  310. package/management-ui/src/components/ui/skeleton.jsx +15 -0
  311. package/management-ui/src/hooks/useFrigg.jsx +387 -0
  312. package/management-ui/src/hooks/useSocket.jsx +58 -0
  313. package/management-ui/src/index.css +193 -0
  314. package/management-ui/src/lib/utils.ts +6 -0
  315. package/management-ui/src/main.jsx +10 -0
  316. package/management-ui/src/pages/CodeGeneration.jsx +14 -0
  317. package/management-ui/src/pages/Connections.jsx +252 -0
  318. package/management-ui/src/pages/ConnectionsEnhanced.jsx +633 -0
  319. package/management-ui/src/pages/Dashboard.jsx +311 -0
  320. package/management-ui/src/pages/Environment.jsx +314 -0
  321. package/management-ui/src/pages/IntegrationConfigure.jsx +669 -0
  322. package/management-ui/src/pages/IntegrationDiscovery.jsx +567 -0
  323. package/management-ui/src/pages/IntegrationTest.jsx +742 -0
  324. package/management-ui/src/pages/Integrations.jsx +253 -0
  325. package/management-ui/src/pages/Monitoring.jsx +17 -0
  326. package/management-ui/src/pages/Simulation.jsx +155 -0
  327. package/management-ui/src/pages/Users.jsx +492 -0
  328. package/management-ui/src/services/api.js +41 -0
  329. package/management-ui/src/services/apiModuleService.js +193 -0
  330. package/management-ui/src/services/websocket-handlers.js +120 -0
  331. package/management-ui/src/test/api/project.test.js +273 -0
  332. package/management-ui/src/test/components/Welcome.test.jsx +378 -0
  333. package/management-ui/src/test/mocks/server.js +178 -0
  334. package/management-ui/src/test/setup.js +61 -0
  335. package/management-ui/src/test/utils/test-utils.jsx +134 -0
  336. package/management-ui/src/utils/repository.js +98 -0
  337. package/management-ui/src/utils/repository.test.js +118 -0
  338. package/management-ui/src/workflows/phase2-integration-workflows.js +884 -0
  339. package/management-ui/tailwind.config.js +63 -0
  340. package/management-ui/tsconfig.json +37 -0
  341. package/management-ui/tsconfig.node.json +10 -0
  342. package/management-ui/vite.config.js +26 -0
  343. package/management-ui/vitest.config.js +38 -0
  344. package/package.json +35 -14
  345. package/test/index.js +2 -4
  346. package/test/mock-integration.js +4 -14
  347. package/infrastructure/app-handler-helpers.js +0 -57
  348. package/infrastructure/backend-utils.js +0 -87
  349. package/infrastructure/routers/auth.js +0 -26
  350. package/infrastructure/routers/integration-defined-routers.js +0 -42
  351. package/infrastructure/routers/middleware/loadUser.js +0 -15
  352. package/infrastructure/routers/middleware/requireLoggedInUser.js +0 -12
  353. package/infrastructure/routers/user.js +0 -41
  354. package/infrastructure/routers/websocket.js +0 -55
  355. package/infrastructure/serverless-template.js +0 -291
  356. package/infrastructure/workers/integration-defined-workers.js +0 -24
  357. package/test/auther-definition-tester.js +0 -125
@@ -0,0 +1,287 @@
1
+ /**
2
+ * Global test setup for Frigg CLI tests
3
+ * This file is executed before each test file
4
+ */
5
+
6
+ // Store original environment
7
+ const originalEnv = process.env;
8
+ const originalConsole = { ...console };
9
+ // Store original process methods (not entire object due to read-only properties)
10
+ const originalProcessExit = process.exit;
11
+ const originalProcessCwd = process.cwd;
12
+
13
+ // Mock console to prevent noisy output during tests
14
+ global.console = {
15
+ ...console,
16
+ log: jest.fn(),
17
+ info: jest.fn(),
18
+ warn: jest.fn(),
19
+ error: jest.fn(),
20
+ debug: jest.fn()
21
+ };
22
+
23
+ // Set up test environment variables
24
+ process.env = {
25
+ ...originalEnv,
26
+ NODE_ENV: 'test',
27
+ HOME: '/mock/home',
28
+ PATH: '/mock/path',
29
+ CI: 'true'
30
+ };
31
+
32
+ // Global setup before each test
33
+ beforeEach(() => {
34
+ // Clear all mocks
35
+ jest.clearAllMocks();
36
+
37
+ // Reset timers
38
+ jest.clearAllTimers();
39
+
40
+ // Reset modules
41
+ jest.resetModules();
42
+
43
+ // Mock process.exit to prevent actual exit
44
+ process.exit = jest.fn();
45
+
46
+ // Mock process.cwd to return predictable path
47
+ process.cwd = jest.fn().mockReturnValue('/mock/cwd');
48
+
49
+ // Reset console mocks
50
+ global.console.log.mockClear();
51
+ global.console.info.mockClear();
52
+ global.console.warn.mockClear();
53
+ global.console.error.mockClear();
54
+ global.console.debug.mockClear();
55
+ });
56
+
57
+ // Global cleanup after each test
58
+ afterEach(() => {
59
+ // Restore environment
60
+ process.env = { ...originalEnv };
61
+
62
+ // Restore process methods
63
+ process.exit = originalProcessExit;
64
+ process.cwd = originalProcessCwd;
65
+
66
+ // Clear any remaining timers
67
+ jest.clearAllTimers();
68
+
69
+ // Unmock all modules
70
+ jest.restoreAllMocks();
71
+ });
72
+
73
+ // Global teardown after all tests
74
+ afterAll(() => {
75
+ // Restore original environment completely
76
+ process.env = originalEnv;
77
+
78
+ // Restore original console
79
+ global.console = originalConsole;
80
+
81
+ // Restore original process methods
82
+ process.exit = originalProcessExit;
83
+ process.cwd = originalProcessCwd;
84
+ });
85
+
86
+ // Custom matchers for CLI testing
87
+ expect.extend({
88
+ toBeValidExitCode(received) {
89
+ const validCodes = [0, 1, 2];
90
+ const pass = validCodes.includes(received);
91
+
92
+ if (pass) {
93
+ return {
94
+ message: () => `expected ${received} not to be a valid exit code`,
95
+ pass: true
96
+ };
97
+ } else {
98
+ return {
99
+ message: () => `expected ${received} to be a valid exit code (0, 1, or 2)`,
100
+ pass: false
101
+ };
102
+ }
103
+ },
104
+
105
+ toHaveLoggedError(received, expected) {
106
+ const errorLogs = global.console.error.mock.calls;
107
+ const pass = errorLogs.some(call =>
108
+ call.some(arg =>
109
+ typeof arg === 'string' && arg.includes(expected)
110
+ )
111
+ );
112
+
113
+ if (pass) {
114
+ return {
115
+ message: () => `expected not to have logged error containing "${expected}"`,
116
+ pass: true
117
+ };
118
+ } else {
119
+ return {
120
+ message: () => `expected to have logged error containing "${expected}"`,
121
+ pass: false
122
+ };
123
+ }
124
+ },
125
+
126
+ toHaveLoggedInfo(received, expected) {
127
+ const infoLogs = global.console.info.mock.calls;
128
+ const pass = infoLogs.some(call =>
129
+ call.some(arg =>
130
+ typeof arg === 'string' && arg.includes(expected)
131
+ )
132
+ );
133
+
134
+ if (pass) {
135
+ return {
136
+ message: () => `expected not to have logged info containing "${expected}"`,
137
+ pass: true
138
+ };
139
+ } else {
140
+ return {
141
+ message: () => `expected to have logged info containing "${expected}"`,
142
+ pass: false
143
+ };
144
+ }
145
+ },
146
+
147
+ toBeWithinTimeLimit(received, limit) {
148
+ const pass = received <= limit;
149
+
150
+ if (pass) {
151
+ return {
152
+ message: () => `expected ${received}ms not to be within ${limit}ms`,
153
+ pass: true
154
+ };
155
+ } else {
156
+ return {
157
+ message: () => `expected ${received}ms to be within ${limit}ms`,
158
+ pass: false
159
+ };
160
+ }
161
+ }
162
+ });
163
+
164
+ // Helper functions available in all tests
165
+ global.TestHelpers = {
166
+ /**
167
+ * Create a temporary directory for tests
168
+ */
169
+ createTempDir() {
170
+ const fs = require('fs');
171
+ const path = require('path');
172
+ const os = require('os');
173
+
174
+ return fs.mkdtempSync(path.join(os.tmpdir(), 'frigg-cli-test-'));
175
+ },
176
+
177
+ /**
178
+ * Clean up temporary directory
179
+ */
180
+ cleanupTempDir(dirPath) {
181
+ const fs = require('fs');
182
+
183
+ if (fs.existsSync(dirPath)) {
184
+ fs.rmSync(dirPath, { recursive: true, force: true });
185
+ }
186
+ },
187
+
188
+ /**
189
+ * Create a mock package.json file
190
+ */
191
+ createMockPackageJson(overrides = {}) {
192
+ return JSON.stringify({
193
+ name: 'test-package',
194
+ version: '1.0.0',
195
+ main: 'index.js',
196
+ scripts: {
197
+ test: 'jest',
198
+ start: 'node index.js'
199
+ },
200
+ dependencies: {},
201
+ devDependencies: {},
202
+ ...overrides
203
+ }, null, 2);
204
+ },
205
+
206
+ /**
207
+ * Create a mock frigg.config.json file
208
+ */
209
+ createMockFriggConfig(overrides = {}) {
210
+ return JSON.stringify({
211
+ stage: 'dev',
212
+ region: 'us-east-1',
213
+ profile: 'default',
214
+ backend: {
215
+ runtime: 'nodejs18.x',
216
+ timeout: 30,
217
+ memory: 128
218
+ },
219
+ ...overrides
220
+ }, null, 2);
221
+ },
222
+
223
+ /**
224
+ * Wait for a specific amount of time
225
+ */
226
+ async delay(ms) {
227
+ return new Promise(resolve => setTimeout(resolve, ms));
228
+ },
229
+
230
+ /**
231
+ * Generate a random string for test data
232
+ */
233
+ randomString(length = 10) {
234
+ return Math.random().toString(36).substring(2, length + 2);
235
+ },
236
+
237
+ /**
238
+ * Simulate file system structure
239
+ */
240
+ mockFileSystem(structure) {
241
+ const fs = require('fs');
242
+
243
+ const originalExistsSync = fs.existsSync;
244
+ const originalReadFileSync = fs.readFileSync;
245
+ const originalWriteFileSync = fs.writeFileSync;
246
+
247
+ fs.existsSync = jest.fn((path) => {
248
+ return structure.hasOwnProperty(path);
249
+ });
250
+
251
+ fs.readFileSync = jest.fn((path) => {
252
+ if (structure.hasOwnProperty(path)) {
253
+ return structure[path];
254
+ }
255
+ throw new Error(`ENOENT: no such file or directory, open '${path}'`);
256
+ });
257
+
258
+ fs.writeFileSync = jest.fn((path, data) => {
259
+ structure[path] = data;
260
+ });
261
+
262
+ return {
263
+ restore() {
264
+ fs.existsSync = originalExistsSync;
265
+ fs.readFileSync = originalReadFileSync;
266
+ fs.writeFileSync = originalWriteFileSync;
267
+ }
268
+ };
269
+ }
270
+ };
271
+
272
+ // Global timeout for all tests
273
+ jest.setTimeout(30000);
274
+
275
+ // Suppress specific warnings during tests
276
+ // Note: console.warn is already mocked above, so we keep the mock
277
+ // and just suppress certain warnings in the implementation
278
+ const originalWarnMock = global.console.warn;
279
+ global.console.warn = jest.fn((...args) => {
280
+ // Suppress specific warnings that are expected during testing
281
+ const message = args.join(' ');
282
+ if (message.includes('ExperimentalWarning') ||
283
+ message.includes('DeprecationWarning')) {
284
+ return;
285
+ }
286
+ // Still track the call in the mock
287
+ });
@@ -1,27 +1,66 @@
1
- const { spawn } = require('child_process');
1
+ const { spawnSync } = require('child_process');
2
2
  const path = require('path');
3
3
 
4
- function buildCommand(...args) {
4
+ async function buildCommand(options) {
5
5
  console.log('Building the serverless application...');
6
+
7
+ // Suppress AWS SDK warning message about maintenance mode
8
+ process.env.AWS_SDK_JS_SUPPRESS_MAINTENANCE_MODE_MESSAGE = '1';
9
+
10
+ // Skip AWS discovery for local builds (unless --production flag is set)
11
+ if (!options.production) {
12
+ process.env.FRIGG_SKIP_AWS_DISCOVERY = 'true';
13
+ console.log('🏠 Building in local mode (use --production flag for production builds with AWS discovery)');
14
+ } else {
15
+ console.log('🚀 Building in production mode with AWS discovery enabled');
16
+ }
17
+
18
+ // AWS discovery is now handled directly in serverless-template.js
19
+ console.log('📦 Packaging serverless application...');
6
20
  const backendPath = path.resolve(process.cwd());
7
21
  const infrastructurePath = 'infrastructure.js';
8
- const command = 'serverless';
9
- const serverlessArgs = ['package', '--config', infrastructurePath, ...args.filter(arg => arg !== 'build')];
22
+ const command = 'osls'; // OSS-Serverless (drop-in replacement for serverless v3)
23
+ const serverlessArgs = [
24
+ 'package',
25
+ '--config',
26
+ infrastructurePath,
27
+ '--stage',
28
+ options.stage
29
+ ];
30
+
31
+ // Add support for --verbose option
32
+ if (options.verbose) {
33
+ serverlessArgs.push('--verbose');
34
+ }
35
+
36
+ console.log('Running command from ', backendPath);
37
+ console.log('Serverless Command:', command, serverlessArgs.join(' '));
10
38
 
11
- const childProcess = spawn(command, serverlessArgs, {
39
+ const result = spawnSync(command, serverlessArgs, {
12
40
  cwd: backendPath,
13
41
  stdio: 'inherit',
42
+ shell: true,
43
+ env: {
44
+ ...process.env,
45
+ NODE_PATH: path.resolve(backendPath, 'node_modules'),
46
+ SLS_STAGE: options.stage, // Set stage for resource discovery
47
+ }
14
48
  });
15
49
 
16
- childProcess.on('error', (error) => {
17
- console.error(`Error executing command: ${error.message}`);
18
- });
50
+ if (result.status !== 0) {
51
+ console.error(`Serverless build failed with code ${result.status}`);
52
+ process.exit(1);
53
+ }
19
54
 
20
- childProcess.on('close', (code) => {
21
- if (code !== 0) {
22
- console.log(`Child process exited with code ${code}`);
23
- }
24
- });
25
- }
55
+ // childProcess.on('error', (error) => {
56
+ // console.error(`Error executing command: ${error.message}`);
57
+ // });
58
+
59
+ // childProcess.on('close', (code) => {
60
+ // if (code !== 0) {
61
+ // console.log(`Child process exited with code ${code}`);
62
+ // }
63
+ // });
64
+ }
26
65
 
27
66
  module.exports = { buildCommand };
@@ -0,0 +1,246 @@
1
+ const path = require('path');
2
+ const chalk = require('chalk');
3
+ const dotenv = require('dotenv');
4
+ const {
5
+ validateDatabaseUrl,
6
+ getDatabaseType,
7
+ checkPrismaClientGenerated,
8
+ } = require('../utils/database-validator');
9
+ const {
10
+ runPrismaGenerate,
11
+ checkDatabaseState,
12
+ runPrismaMigrate,
13
+ runPrismaDbPush,
14
+ getMigrationCommand,
15
+ } = require('@friggframework/core/database/utils/prisma-runner');
16
+ const {
17
+ getDatabaseUrlMissingError,
18
+ getDatabaseTypeNotConfiguredError,
19
+ getPrismaCommandError,
20
+ getDatabaseSetupSuccess,
21
+ } = require('../utils/error-messages');
22
+
23
+ function getDatabaseDisplayName(dbType) {
24
+ switch (dbType) {
25
+ case 'postgresql':
26
+ return 'PostgreSQL';
27
+ case 'mongodb':
28
+ return 'MongoDB';
29
+ case 'documentdb':
30
+ return 'AWS DocumentDB (MongoDB-compatible)';
31
+ default:
32
+ return dbType;
33
+ }
34
+ }
35
+
36
+ function getPrismaRunnerDbType(dbType) {
37
+ return dbType === 'documentdb' ? 'mongodb' : dbType;
38
+ }
39
+
40
+ /**
41
+ * Database Setup Command
42
+ * Sets up the database for a Frigg application:
43
+ * - Validates configuration
44
+ * - Generates Prisma client
45
+ * - Runs migrations (PostgreSQL) or db push (MongoDB)
46
+ */
47
+
48
+ async function dbSetupCommand(options = {}) {
49
+ const verbose = options.verbose || false;
50
+ const stage = options.stage || process.env.STAGE || 'development';
51
+
52
+ console.log(chalk.blue('🔧 Frigg Database Setup'));
53
+ console.log(chalk.gray(`Stage: ${stage}\n`));
54
+
55
+ // Load environment variables from .env file
56
+ const envPath = path.join(process.cwd(), '.env');
57
+ dotenv.config({ path: envPath });
58
+
59
+ try {
60
+ // Step 1: Validate DATABASE_URL
61
+ if (verbose) {
62
+ console.log(chalk.gray('Step 1: Validating DATABASE_URL...'));
63
+ }
64
+
65
+ const urlValidation = validateDatabaseUrl();
66
+ if (!urlValidation.valid) {
67
+ console.error(getDatabaseUrlMissingError());
68
+ process.exit(1);
69
+ }
70
+
71
+ if (verbose) {
72
+ console.log(chalk.green('✓ DATABASE_URL found\n'));
73
+ }
74
+
75
+ // Step 2: Determine database type from app definition
76
+ if (verbose) {
77
+ console.log(chalk.gray('Step 2: Determining database type...'));
78
+ }
79
+
80
+ const dbTypeResult = getDatabaseType();
81
+ if (dbTypeResult.error) {
82
+ console.error(chalk.red('❌ ' + dbTypeResult.error));
83
+
84
+ // Show stack trace in verbose mode for debugging
85
+ if (verbose && dbTypeResult.stack) {
86
+ console.error(chalk.gray('\nStack trace:'));
87
+ console.error(chalk.gray(dbTypeResult.stack));
88
+ }
89
+
90
+ console.error(getDatabaseTypeNotConfiguredError());
91
+ process.exit(1);
92
+ }
93
+
94
+ const dbType = dbTypeResult.dbType;
95
+ const dbDisplayName = getDatabaseDisplayName(dbType);
96
+ const isPostgres = dbType === 'postgresql';
97
+ const isDocumentDb = dbType === 'documentdb';
98
+ const isMongoFamily = dbType === 'mongodb' || isDocumentDb;
99
+ const runnerDbType = getPrismaRunnerDbType(dbType);
100
+
101
+ console.log(chalk.cyan(`Database type: ${dbDisplayName}`));
102
+
103
+ if (verbose) {
104
+ console.log(chalk.green(`✓ Using ${dbDisplayName}\n`));
105
+ }
106
+
107
+ // Step 3: Check if Prisma client exists, generate if needed
108
+ if (verbose) {
109
+ console.log(chalk.gray('Step 3: Checking Prisma client...'));
110
+ }
111
+
112
+ const clientCheck = checkPrismaClientGenerated(dbType);
113
+ const forceRegenerate = options.force || false;
114
+
115
+ if (clientCheck.generated && !forceRegenerate) {
116
+ // Client already exists and --force not specified
117
+ console.log(
118
+ chalk.green(
119
+ '✓ Prisma client already exists (skipping generation)\n'
120
+ )
121
+ );
122
+ if (verbose) {
123
+ console.log(
124
+ chalk.gray(` Client location: ${clientCheck.path}\n`)
125
+ );
126
+ }
127
+ } else {
128
+ // Client doesn't exist OR --force specified - generate it
129
+ if (forceRegenerate && clientCheck.generated) {
130
+ console.log(
131
+ chalk.yellow('⚠️ Forcing Prisma client regeneration...')
132
+ );
133
+ } else {
134
+ console.log(chalk.cyan('Generating Prisma client...'));
135
+ }
136
+
137
+ const generateResult = await runPrismaGenerate(
138
+ runnerDbType,
139
+ verbose
140
+ );
141
+
142
+ if (!generateResult.success) {
143
+ console.error(
144
+ getPrismaCommandError('generate', generateResult.error)
145
+ );
146
+ if (generateResult.output) {
147
+ console.error(chalk.gray(generateResult.output));
148
+ }
149
+ process.exit(1);
150
+ }
151
+
152
+ console.log(chalk.green('✓ Prisma client generated\n'));
153
+ }
154
+
155
+ // Step 4: Check database state
156
+ // Note: We skip connection testing in db:setup because when using frigg:local,
157
+ // the CLI code runs from tmp/frigg but the client is in backend/node_modules,
158
+ // causing module resolution mismatches. Connection testing happens in frigg start.
159
+ if (verbose) {
160
+ console.log(chalk.gray('Step 4: Checking database state...'));
161
+ }
162
+
163
+ const stateCheck = await checkDatabaseState(runnerDbType);
164
+
165
+ // Step 5: Run migrations or db push
166
+ if (isPostgres) {
167
+ console.log(chalk.cyan('Running database migrations...'));
168
+
169
+ const migrationCommand = getMigrationCommand(stage);
170
+
171
+ if (verbose) {
172
+ console.log(
173
+ chalk.gray(`Using migration command: ${migrationCommand}`)
174
+ );
175
+ }
176
+
177
+ if (stateCheck.upToDate && migrationCommand === 'deploy') {
178
+ console.log(chalk.yellow('Database is already up-to-date'));
179
+ } else {
180
+ const migrateResult = await runPrismaMigrate(
181
+ migrationCommand,
182
+ verbose
183
+ );
184
+
185
+ if (!migrateResult.success) {
186
+ console.error(
187
+ getPrismaCommandError('migrate', migrateResult.error)
188
+ );
189
+ if (migrateResult.output) {
190
+ console.error(chalk.gray(migrateResult.output));
191
+ }
192
+ process.exit(1);
193
+ }
194
+
195
+ console.log(chalk.green('✓ Migrations applied\n'));
196
+ }
197
+ } else if (isMongoFamily) {
198
+ const targetName = isDocumentDb
199
+ ? 'AWS DocumentDB (MongoDB-compatible)'
200
+ : 'MongoDB';
201
+
202
+ console.log(chalk.cyan(`Pushing schema to ${targetName}...`));
203
+
204
+ const pushResult = await runPrismaDbPush(verbose);
205
+
206
+ if (!pushResult.success) {
207
+ console.error(
208
+ getPrismaCommandError('db push', pushResult.error)
209
+ );
210
+ if (pushResult.output) {
211
+ console.error(chalk.gray(pushResult.output));
212
+ }
213
+ process.exit(1);
214
+ }
215
+
216
+ console.log(chalk.green('✓ Schema pushed to database\n'));
217
+ }
218
+
219
+ // Success!
220
+ console.log(getDatabaseSetupSuccess(dbType, stage));
221
+ } catch (error) {
222
+ console.error(chalk.red('\n❌ Database setup failed'));
223
+ console.error(chalk.gray(error.message));
224
+
225
+ if (verbose && error.stack) {
226
+ console.error(chalk.gray('\nStack trace:'));
227
+ console.error(chalk.gray(error.stack));
228
+ }
229
+
230
+ console.error(chalk.yellow('\nTroubleshooting:'));
231
+ console.error(chalk.gray(' • Verify DATABASE_URL in your .env file'));
232
+ console.error(
233
+ chalk.gray(' • Check database is running and accessible')
234
+ );
235
+ console.error(
236
+ chalk.gray(' • Ensure app definition has database configuration')
237
+ );
238
+ console.error(
239
+ chalk.gray(' • Run with --verbose flag for more details')
240
+ );
241
+
242
+ process.exit(1);
243
+ }
244
+ }
245
+
246
+ module.exports = { dbSetupCommand };