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

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,401 @@
1
+ AWSTemplateFormatVersion: '2010-09-09'
2
+ Description: 'IAM roles and policies for Frigg application deployment pipeline'
3
+
4
+ Parameters:
5
+ DeploymentUserName:
6
+ Type: String
7
+ Default: 'frigg-deployment-user'
8
+ Description: 'Name for the IAM user that will deploy Frigg applications'
9
+
10
+ EnableVPCSupport:
11
+ Type: String
12
+ Default: 'true'
13
+ AllowedValues: ['true', 'false']
14
+ Description: 'Enable VPC-related permissions for Frigg applications'
15
+
16
+ EnableKMSSupport:
17
+ Type: String
18
+ Default: 'true'
19
+ AllowedValues: ['true', 'false']
20
+ Description: 'Enable KMS encryption permissions for Frigg applications'
21
+
22
+ EnableSSMSupport:
23
+ Type: String
24
+ Default: 'true'
25
+ AllowedValues: ['true', 'false']
26
+ Description: 'Enable SSM Parameter Store permissions for Frigg applications'
27
+
28
+ Conditions:
29
+ CreateVPCPermissions: !Equals [!Ref EnableVPCSupport, 'true']
30
+ CreateKMSPermissions: !Equals [!Ref EnableKMSSupport, 'true']
31
+ CreateSSMPermissions: !Equals [!Ref EnableSSMSupport, 'true']
32
+
33
+ Resources:
34
+ # IAM User for deployment
35
+ FriggDeploymentUser:
36
+ Type: AWS::IAM::User
37
+ Properties:
38
+ UserName: !Ref DeploymentUserName
39
+ ManagedPolicyArns:
40
+ - !Ref FriggDiscoveryPolicy
41
+ - !Ref FriggCoreDeploymentPolicy
42
+ - !If [CreateVPCPermissions, !Ref FriggVPCPolicy, !Ref 'AWS::NoValue']
43
+ - !If [CreateKMSPermissions, !Ref FriggKMSPolicy, !Ref 'AWS::NoValue']
44
+ - !If [CreateSSMPermissions, !Ref FriggSSMPolicy, !Ref 'AWS::NoValue']
45
+
46
+ # Access key for the deployment user
47
+ FriggDeploymentAccessKey:
48
+ Type: AWS::IAM::AccessKey
49
+ Properties:
50
+ UserName: !Ref FriggDeploymentUser
51
+
52
+ # Discovery-time permissions (required for build process)
53
+ FriggDiscoveryPolicy:
54
+ Type: AWS::IAM::ManagedPolicy
55
+ Properties:
56
+ ManagedPolicyName: 'FriggDiscoveryPolicy'
57
+ Description: 'Permissions for AWS resource discovery during Frigg build process'
58
+ PolicyDocument:
59
+ Version: '2012-10-17'
60
+ Statement:
61
+ - Sid: 'AWSDiscoveryPermissions'
62
+ Effect: Allow
63
+ Action:
64
+ - 'sts:GetCallerIdentity'
65
+ - 'ec2:DescribeVpcs'
66
+ - 'ec2:DescribeSubnets'
67
+ - 'ec2:DescribeSecurityGroups'
68
+ - 'ec2:DescribeRouteTables'
69
+ - 'kms:ListKeys'
70
+ - 'kms:DescribeKey'
71
+ Resource: '*'
72
+
73
+ # Core deployment permissions
74
+ FriggCoreDeploymentPolicy:
75
+ Type: AWS::IAM::ManagedPolicy
76
+ Properties:
77
+ ManagedPolicyName: 'FriggCoreDeploymentPolicy'
78
+ Description: 'Core permissions for deploying Frigg applications'
79
+ PolicyDocument:
80
+ Version: '2012-10-17'
81
+ Statement:
82
+ # CloudFormation permissions
83
+ - Sid: 'CloudFormationFriggStacks'
84
+ Effect: Allow
85
+ Action:
86
+ - 'cloudformation:CreateStack'
87
+ - 'cloudformation:UpdateStack'
88
+ - 'cloudformation:DeleteStack'
89
+ - 'cloudformation:DescribeStacks'
90
+ - 'cloudformation:DescribeStackEvents'
91
+ - 'cloudformation:DescribeStackResources'
92
+ - 'cloudformation:DescribeStackResource'
93
+ - 'cloudformation:ListStackResources'
94
+ - 'cloudformation:GetTemplate'
95
+ - 'cloudformation:DescribeChangeSet'
96
+ - 'cloudformation:CreateChangeSet'
97
+ - 'cloudformation:DeleteChangeSet'
98
+ - 'cloudformation:ExecuteChangeSet'
99
+ Resource:
100
+ - !Sub 'arn:aws:cloudformation:*:${AWS::AccountId}:stack/*frigg*/*'
101
+
102
+ # ValidateTemplate needs to be allowed on all resources
103
+ - Sid: 'CloudFormationValidateTemplate'
104
+ Effect: Allow
105
+ Action:
106
+ - 'cloudformation:ValidateTemplate'
107
+ Resource: '*'
108
+
109
+ # S3 deployment bucket permissions
110
+ - Sid: 'S3DeploymentBucket'
111
+ Effect: Allow
112
+ Action:
113
+ - 's3:CreateBucket'
114
+ - 's3:PutObject'
115
+ - 's3:GetObject'
116
+ - 's3:DeleteObject'
117
+ - 's3:PutBucketPolicy'
118
+ - 's3:PutBucketVersioning'
119
+ - 's3:PutBucketPublicAccessBlock'
120
+ - 's3:GetBucketLocation'
121
+ - 's3:ListBucket'
122
+ - 's3:PutBucketTagging'
123
+ - 's3:GetBucketTagging'
124
+ Resource:
125
+ - 'arn:aws:s3:::*serverless*'
126
+ - 'arn:aws:s3:::*serverless*/*'
127
+
128
+ # Lambda function permissions
129
+ - Sid: 'LambdaFriggFunctions'
130
+ Effect: Allow
131
+ Action:
132
+ - 'lambda:CreateFunction'
133
+ - 'lambda:UpdateFunctionCode'
134
+ - 'lambda:UpdateFunctionConfiguration'
135
+ - 'lambda:DeleteFunction'
136
+ - 'lambda:GetFunction'
137
+ - 'lambda:ListFunctions'
138
+ - 'lambda:PublishVersion'
139
+ - 'lambda:CreateAlias'
140
+ - 'lambda:UpdateAlias'
141
+ - 'lambda:DeleteAlias'
142
+ - 'lambda:GetAlias'
143
+ - 'lambda:AddPermission'
144
+ - 'lambda:RemovePermission'
145
+ - 'lambda:GetPolicy'
146
+ - 'lambda:PutProvisionedConcurrencyConfig'
147
+ - 'lambda:DeleteProvisionedConcurrencyConfig'
148
+ - 'lambda:PutConcurrency'
149
+ - 'lambda:DeleteConcurrency'
150
+ - 'lambda:TagResource'
151
+ - 'lambda:UntagResource'
152
+ - 'lambda:ListVersionsByFunction'
153
+ Resource:
154
+ - !Sub 'arn:aws:lambda:*:${AWS::AccountId}:function:*frigg*'
155
+
156
+ # Lambda EventSourceMapping permissions
157
+ - Sid: 'FriggLambdaEventSourceMapping'
158
+ Effect: Allow
159
+ Action:
160
+ - 'lambda:CreateEventSourceMapping'
161
+ - 'lambda:DeleteEventSourceMapping'
162
+ - 'lambda:GetEventSourceMapping'
163
+ - 'lambda:UpdateEventSourceMapping'
164
+ - 'lambda:ListEventSourceMappings'
165
+ Resource:
166
+ - !Sub 'arn:aws:lambda:*:${AWS::AccountId}:event-source-mapping:*'
167
+
168
+ # IAM role permissions
169
+ - Sid: 'IAMRolesForFriggLambda'
170
+ Effect: Allow
171
+ Action:
172
+ - 'iam:CreateRole'
173
+ - 'iam:DeleteRole'
174
+ - 'iam:GetRole'
175
+ - 'iam:PassRole'
176
+ - 'iam:PutRolePolicy'
177
+ - 'iam:DeleteRolePolicy'
178
+ - 'iam:GetRolePolicy'
179
+ - 'iam:AttachRolePolicy'
180
+ - 'iam:DetachRolePolicy'
181
+ - 'iam:TagRole'
182
+ - 'iam:UntagRole'
183
+ Resource:
184
+ - !Sub 'arn:aws:iam::${AWS::AccountId}:role/*frigg*'
185
+ - !Sub 'arn:aws:iam::${AWS::AccountId}:role/*frigg*LambdaRole*'
186
+
187
+ # IAM policy permissions
188
+ - Sid: 'IAMPolicyVersionPermissions'
189
+ Effect: Allow
190
+ Action:
191
+ - 'iam:ListPolicyVersions'
192
+ Resource:
193
+ - !Sub 'arn:aws:iam::${AWS::AccountId}:policy/*'
194
+
195
+ # SQS permissions
196
+ - Sid: 'FriggMessagingServices'
197
+ Effect: Allow
198
+ Action:
199
+ - 'sqs:CreateQueue'
200
+ - 'sqs:DeleteQueue'
201
+ - 'sqs:GetQueueAttributes'
202
+ - 'sqs:SetQueueAttributes'
203
+ - 'sqs:GetQueueUrl'
204
+ - 'sqs:TagQueue'
205
+ - 'sqs:UntagQueue'
206
+ Resource:
207
+ - !Sub 'arn:aws:sqs:*:${AWS::AccountId}:*frigg*'
208
+ - !Sub 'arn:aws:sqs:*:${AWS::AccountId}:internal-error-queue-*'
209
+
210
+ # SNS permissions
211
+ - Sid: 'FriggSNSTopics'
212
+ Effect: Allow
213
+ Action:
214
+ - 'sns:CreateTopic'
215
+ - 'sns:DeleteTopic'
216
+ - 'sns:GetTopicAttributes'
217
+ - 'sns:SetTopicAttributes'
218
+ - 'sns:Subscribe'
219
+ - 'sns:Unsubscribe'
220
+ - 'sns:ListSubscriptionsByTopic'
221
+ - 'sns:TagResource'
222
+ - 'sns:UntagResource'
223
+ Resource:
224
+ - !Sub 'arn:aws:sns:*:${AWS::AccountId}:*frigg*'
225
+
226
+ # CloudWatch and Logs permissions
227
+ - Sid: 'FriggMonitoringAndLogs'
228
+ Effect: Allow
229
+ Action:
230
+ - 'cloudwatch:PutMetricAlarm'
231
+ - 'cloudwatch:DeleteAlarms'
232
+ - 'cloudwatch:DescribeAlarms'
233
+ - 'logs:CreateLogGroup'
234
+ - 'logs:CreateLogStream'
235
+ - 'logs:DeleteLogGroup'
236
+ - 'logs:DescribeLogGroups'
237
+ - 'logs:DescribeLogStreams'
238
+ - 'logs:FilterLogEvents'
239
+ - 'logs:PutLogEvents'
240
+ - 'logs:PutRetentionPolicy'
241
+ Resource:
242
+ - !Sub 'arn:aws:logs:*:${AWS::AccountId}:log-group:/aws/lambda/*frigg*'
243
+ - !Sub 'arn:aws:logs:*:${AWS::AccountId}:log-group:/aws/lambda/*frigg*:*'
244
+ - !Sub 'arn:aws:cloudwatch:*:${AWS::AccountId}:alarm:*frigg*'
245
+
246
+ # API Gateway permissions
247
+ - Sid: 'FriggAPIGateway'
248
+ Effect: Allow
249
+ Action:
250
+ - 'apigateway:POST'
251
+ - 'apigateway:PUT'
252
+ - 'apigateway:DELETE'
253
+ - 'apigateway:GET'
254
+ - 'apigateway:PATCH'
255
+ Resource:
256
+ - 'arn:aws:apigateway:*::/restapis'
257
+ - 'arn:aws:apigateway:*::/restapis/*'
258
+ - 'arn:aws:apigateway:*::/domainnames'
259
+ - 'arn:aws:apigateway:*::/domainnames/*'
260
+
261
+ # API Gateway v2 permissions
262
+ - Sid: 'FriggAPIGatewayV2'
263
+ Effect: Allow
264
+ Action:
265
+ - 'apigateway:GET'
266
+ - 'apigateway:DELETE'
267
+ - 'apigateway:PATCH'
268
+ - 'apigateway:POST'
269
+ - 'apigateway:PUT'
270
+ Resource:
271
+ - 'arn:aws:apigateway:*::/apis'
272
+ - 'arn:aws:apigateway:*::/apis/*'
273
+ - 'arn:aws:apigateway:*::/apis/*/stages'
274
+ - 'arn:aws:apigateway:*::/apis/*/stages/*'
275
+ - 'arn:aws:apigateway:*::/apis/*/mappings'
276
+ - 'arn:aws:apigateway:*::/apis/*/mappings/*'
277
+ - 'arn:aws:apigateway:*::/domainnames'
278
+ - 'arn:aws:apigateway:*::/domainnames/*'
279
+ - 'arn:aws:apigateway:*::/domainnames/*/apimappings'
280
+
281
+ # VPC-specific permissions
282
+ FriggVPCPolicy:
283
+ Type: AWS::IAM::ManagedPolicy
284
+ Condition: CreateVPCPermissions
285
+ Properties:
286
+ ManagedPolicyName: 'FriggVPCPolicy'
287
+ Description: 'VPC-related permissions for Frigg applications'
288
+ PolicyDocument:
289
+ Version: '2012-10-17'
290
+ Statement:
291
+ - Sid: 'FriggVPCEndpointManagement'
292
+ Effect: Allow
293
+ Action:
294
+ - 'ec2:CreateVpcEndpoint'
295
+ - 'ec2:DeleteVpcEndpoints'
296
+ - 'ec2:DescribeVpcEndpoints'
297
+ - 'ec2:ModifyVpcEndpoint'
298
+ - 'ec2:CreateNatGateway'
299
+ - 'ec2:DeleteNatGateway'
300
+ - 'ec2:DescribeNatGateways'
301
+ - 'ec2:AllocateAddress'
302
+ - 'ec2:ReleaseAddress'
303
+ - 'ec2:DescribeAddresses'
304
+ - 'ec2:CreateRouteTable'
305
+ - 'ec2:DeleteRouteTable'
306
+ - 'ec2:DescribeRouteTables'
307
+ - 'ec2:CreateRoute'
308
+ - 'ec2:DeleteRoute'
309
+ - 'ec2:AssociateRouteTable'
310
+ - 'ec2:DisassociateRouteTable'
311
+ - 'ec2:CreateSecurityGroup'
312
+ - 'ec2:DeleteSecurityGroup'
313
+ - 'ec2:AuthorizeSecurityGroupEgress'
314
+ - 'ec2:AuthorizeSecurityGroupIngress'
315
+ - 'ec2:RevokeSecurityGroupEgress'
316
+ - 'ec2:RevokeSecurityGroupIngress'
317
+ - 'ec2:CreateTags'
318
+ - 'ec2:DeleteTags'
319
+ - 'ec2:DescribeTags'
320
+ - 'ec2:DetachInternetGateway'
321
+ - 'ec2:DeleteSubnet'
322
+ Resource: '*'
323
+
324
+ # KMS permissions
325
+ FriggKMSPolicy:
326
+ Type: AWS::IAM::ManagedPolicy
327
+ Condition: CreateKMSPermissions
328
+ Properties:
329
+ ManagedPolicyName: 'FriggKMSPolicy'
330
+ Description: 'KMS encryption permissions for Frigg applications'
331
+ PolicyDocument:
332
+ Version: '2012-10-17'
333
+ Statement:
334
+ - Sid: 'FriggKMSEncryptionRuntime'
335
+ Effect: Allow
336
+ Action:
337
+ - 'kms:GenerateDataKey'
338
+ - 'kms:Decrypt'
339
+ Resource:
340
+ - !Sub 'arn:aws:kms:*:${AWS::AccountId}:key/*'
341
+ Condition:
342
+ StringEquals:
343
+ 'kms:ViaService':
344
+ - 'lambda.*.amazonaws.com'
345
+ - 's3.*.amazonaws.com'
346
+
347
+ # SSM Parameter Store permissions
348
+ FriggSSMPolicy:
349
+ Type: AWS::IAM::ManagedPolicy
350
+ Condition: CreateSSMPermissions
351
+ Properties:
352
+ ManagedPolicyName: 'FriggSSMPolicy'
353
+ Description: 'SSM Parameter Store permissions for Frigg applications'
354
+ PolicyDocument:
355
+ Version: '2012-10-17'
356
+ Statement:
357
+ - Sid: 'FriggSSMParameterAccess'
358
+ Effect: Allow
359
+ Action:
360
+ - 'ssm:GetParameter'
361
+ - 'ssm:GetParameters'
362
+ - 'ssm:GetParametersByPath'
363
+ Resource:
364
+ - !Sub 'arn:aws:ssm:*:${AWS::AccountId}:parameter/*frigg*'
365
+ - !Sub 'arn:aws:ssm:*:${AWS::AccountId}:parameter/*frigg*/*'
366
+
367
+ # Store access key in Secrets Manager
368
+ FriggDeploymentCredentials:
369
+ Type: AWS::SecretsManager::Secret
370
+ Properties:
371
+ Name: 'frigg-deployment-credentials'
372
+ Description: 'Access credentials for Frigg deployment user'
373
+ SecretString: !Sub |
374
+ {
375
+ "AccessKeyId": "${FriggDeploymentAccessKey}",
376
+ "SecretAccessKey": "${FriggDeploymentAccessKey.SecretAccessKey}"
377
+ }
378
+
379
+ Outputs:
380
+ DeploymentUserArn:
381
+ Description: 'ARN of the Frigg deployment user'
382
+ Value: !GetAtt FriggDeploymentUser.Arn
383
+ Export:
384
+ Name: !Sub '${AWS::StackName}-UserArn'
385
+
386
+ AccessKeyId:
387
+ Description: 'Access Key ID for the deployment user'
388
+ Value: !Ref FriggDeploymentAccessKey
389
+ Export:
390
+ Name: !Sub '${AWS::StackName}-AccessKeyId'
391
+
392
+ SecretAccessKeyCommand:
393
+ Description: 'Command to retrieve the secret access key'
394
+ Value: !Sub |
395
+ aws secretsmanager get-secret-value --secret-id frigg-deployment-credentials --query SecretString --output text | jq -r .SecretAccessKey
396
+
397
+ CredentialsSecretArn:
398
+ Description: 'ARN of the secret containing deployment credentials'
399
+ Value: !Ref FriggDeploymentCredentials
400
+ Export:
401
+ Name: !Sub '${AWS::StackName}-CredentialsSecretArn'
@@ -0,0 +1,218 @@
1
+ {
2
+ "Version": "2012-10-17",
3
+ "Statement": [
4
+ {
5
+ "Sid": "AWSDiscoveryPermissions",
6
+ "Effect": "Allow",
7
+ "Action": [
8
+ "sts:GetCallerIdentity",
9
+ "ec2:DescribeVpcs",
10
+ "ec2:DescribeSubnets",
11
+ "ec2:DescribeSecurityGroups",
12
+ "ec2:DescribeRouteTables",
13
+ "kms:ListKeys",
14
+ "kms:DescribeKey"
15
+ ],
16
+ "Resource": "*"
17
+ },
18
+ {
19
+ "Sid": "CloudFormationFriggStacks",
20
+ "Effect": "Allow",
21
+ "Action": [
22
+ "cloudformation:CreateStack",
23
+ "cloudformation:UpdateStack",
24
+ "cloudformation:DeleteStack",
25
+ "cloudformation:DescribeStacks",
26
+ "cloudformation:DescribeStackEvents",
27
+ "cloudformation:DescribeStackResources",
28
+ "cloudformation:DescribeStackResource",
29
+ "cloudformation:ListStackResources",
30
+ "cloudformation:GetTemplate",
31
+ "cloudformation:ValidateTemplate",
32
+ "cloudformation:DescribeChangeSet",
33
+ "cloudformation:CreateChangeSet",
34
+ "cloudformation:DeleteChangeSet",
35
+ "cloudformation:ExecuteChangeSet"
36
+ ],
37
+ "Resource": [
38
+ "arn:aws:cloudformation:*:*:stack/*frigg*/*"
39
+ ]
40
+ },
41
+ {
42
+ "Sid": "S3DeploymentBucket",
43
+ "Effect": "Allow",
44
+ "Action": [
45
+ "s3:CreateBucket",
46
+ "s3:PutObject",
47
+ "s3:GetObject",
48
+ "s3:DeleteObject",
49
+ "s3:PutBucketPolicy",
50
+ "s3:PutBucketVersioning",
51
+ "s3:PutBucketPublicAccessBlock",
52
+ "s3:GetBucketLocation",
53
+ "s3:ListBucket",
54
+ "s3:PutBucketTagging",
55
+ "s3:GetBucketTagging"
56
+ ],
57
+ "Resource": [
58
+ "arn:aws:s3:::*serverless*",
59
+ "arn:aws:s3:::*serverless*/*"
60
+ ]
61
+ },
62
+ {
63
+ "Sid": "LambdaFriggFunctions",
64
+ "Effect": "Allow",
65
+ "Action": [
66
+ "lambda:CreateFunction",
67
+ "lambda:UpdateFunctionCode",
68
+ "lambda:UpdateFunctionConfiguration",
69
+ "lambda:DeleteFunction",
70
+ "lambda:GetFunction",
71
+ "lambda:ListFunctions",
72
+ "lambda:PublishVersion",
73
+ "lambda:CreateAlias",
74
+ "lambda:UpdateAlias",
75
+ "lambda:DeleteAlias",
76
+ "lambda:GetAlias",
77
+ "lambda:AddPermission",
78
+ "lambda:RemovePermission",
79
+ "lambda:GetPolicy",
80
+ "lambda:PutProvisionedConcurrencyConfig",
81
+ "lambda:DeleteProvisionedConcurrencyConfig",
82
+ "lambda:PutConcurrency",
83
+ "lambda:DeleteConcurrency",
84
+ "lambda:TagResource",
85
+ "lambda:UntagResource",
86
+ "lambda:ListVersionsByFunction"
87
+ ],
88
+ "Resource": [
89
+ "arn:aws:lambda:*:*:function:*frigg*"
90
+ ]
91
+ },
92
+ {
93
+ "Sid": "FriggLambdaEventSourceMapping",
94
+ "Effect": "Allow",
95
+ "Action": [
96
+ "lambda:CreateEventSourceMapping",
97
+ "lambda:DeleteEventSourceMapping",
98
+ "lambda:GetEventSourceMapping",
99
+ "lambda:UpdateEventSourceMapping",
100
+ "lambda:ListEventSourceMappings"
101
+ ],
102
+ "Resource": [
103
+ "arn:aws:lambda:*:*:event-source-mapping:*"
104
+ ]
105
+ },
106
+ {
107
+ "Sid": "IAMRolesForFriggLambda",
108
+ "Effect": "Allow",
109
+ "Action": [
110
+ "iam:CreateRole",
111
+ "iam:DeleteRole",
112
+ "iam:GetRole",
113
+ "iam:PassRole",
114
+ "iam:PutRolePolicy",
115
+ "iam:DeleteRolePolicy",
116
+ "iam:GetRolePolicy",
117
+ "iam:AttachRolePolicy",
118
+ "iam:DetachRolePolicy",
119
+ "iam:TagRole",
120
+ "iam:UntagRole"
121
+ ],
122
+ "Resource": [
123
+ "arn:aws:iam::*:role/*frigg*",
124
+ "arn:aws:iam::*:role/*frigg*LambdaRole*"
125
+ ]
126
+ },
127
+ {
128
+ "Sid": "IAMPolicyVersionPermissions",
129
+ "Effect": "Allow",
130
+ "Action": [
131
+ "iam:ListPolicyVersions"
132
+ ],
133
+ "Resource": [
134
+ "arn:aws:iam::*:policy/*"
135
+ ]
136
+ },
137
+ {
138
+ "Sid": "FriggMessagingServices",
139
+ "Effect": "Allow",
140
+ "Action": [
141
+ "sqs:CreateQueue",
142
+ "sqs:DeleteQueue",
143
+ "sqs:GetQueueAttributes",
144
+ "sqs:SetQueueAttributes",
145
+ "sqs:GetQueueUrl",
146
+ "sqs:TagQueue",
147
+ "sqs:UntagQueue"
148
+ ],
149
+ "Resource": [
150
+ "arn:aws:sqs:*:*:*frigg*",
151
+ "arn:aws:sqs:*:*:internal-error-queue-*"
152
+ ]
153
+ },
154
+ {
155
+ "Sid": "FriggSNSTopics",
156
+ "Effect": "Allow",
157
+ "Action": [
158
+ "sns:CreateTopic",
159
+ "sns:DeleteTopic",
160
+ "sns:GetTopicAttributes",
161
+ "sns:SetTopicAttributes",
162
+ "sns:Subscribe",
163
+ "sns:Unsubscribe",
164
+ "sns:ListSubscriptionsByTopic",
165
+ "sns:TagResource",
166
+ "sns:UntagResource"
167
+ ],
168
+ "Resource": [
169
+ "arn:aws:sns:*:*:*frigg*"
170
+ ]
171
+ },
172
+ {
173
+ "Sid": "FriggMonitoringAndLogs",
174
+ "Effect": "Allow",
175
+ "Action": [
176
+ "cloudwatch:PutMetricAlarm",
177
+ "cloudwatch:DeleteAlarms",
178
+ "cloudwatch:DescribeAlarms",
179
+ "logs:CreateLogGroup",
180
+ "logs:CreateLogStream",
181
+ "logs:DeleteLogGroup",
182
+ "logs:DescribeLogGroups",
183
+ "logs:DescribeLogStreams",
184
+ "logs:FilterLogEvents",
185
+ "logs:PutLogEvents",
186
+ "logs:PutRetentionPolicy"
187
+ ],
188
+ "Resource": [
189
+ "arn:aws:logs:*:*:log-group:/aws/lambda/*frigg*",
190
+ "arn:aws:logs:*:*:log-group:/aws/lambda/*frigg*:*",
191
+ "arn:aws:cloudwatch:*:*:alarm:*frigg*"
192
+ ]
193
+ },
194
+ {
195
+ "Sid": "FriggAPIGateway",
196
+ "Effect": "Allow",
197
+ "Action": [
198
+ "apigateway:POST",
199
+ "apigateway:PUT",
200
+ "apigateway:DELETE",
201
+ "apigateway:GET",
202
+ "apigateway:PATCH",
203
+ "apigateway:TagResource",
204
+ "apigateway:UntagResource"
205
+ ],
206
+ "Resource": [
207
+ "arn:aws:apigateway:*::/restapis",
208
+ "arn:aws:apigateway:*::/restapis/*",
209
+ "arn:aws:apigateway:*::/apis",
210
+ "arn:aws:apigateway:*::/apis/*",
211
+ "arn:aws:apigateway:*::/apis/*/stages",
212
+ "arn:aws:apigateway:*::/apis/*/stages/*",
213
+ "arn:aws:apigateway:*::/domainnames",
214
+ "arn:aws:apigateway:*::/domainnames/*"
215
+ ]
216
+ }
217
+ ]
218
+ }