@friggframework/devtools 2.0.0-next.4 → 2.0.0-next.40

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 (197) hide show
  1. package/frigg-cli/.eslintrc.js +141 -0
  2. package/frigg-cli/__tests__/jest.config.js +102 -0
  3. package/frigg-cli/__tests__/unit/commands/build.test.js +483 -0
  4. package/frigg-cli/__tests__/unit/commands/install.test.js +418 -0
  5. package/frigg-cli/__tests__/unit/commands/ui.test.js +592 -0
  6. package/frigg-cli/__tests__/utils/command-tester.js +170 -0
  7. package/frigg-cli/__tests__/utils/mock-factory.js +270 -0
  8. package/frigg-cli/__tests__/utils/test-fixtures.js +463 -0
  9. package/frigg-cli/__tests__/utils/test-setup.js +286 -0
  10. package/frigg-cli/build-command/index.js +54 -0
  11. package/frigg-cli/deploy-command/index.js +175 -0
  12. package/frigg-cli/generate-command/__tests__/generate-command.test.js +312 -0
  13. package/frigg-cli/generate-command/azure-generator.js +43 -0
  14. package/frigg-cli/generate-command/gcp-generator.js +47 -0
  15. package/frigg-cli/generate-command/index.js +332 -0
  16. package/frigg-cli/generate-command/terraform-generator.js +555 -0
  17. package/frigg-cli/generate-iam-command.js +115 -0
  18. package/frigg-cli/index.js +47 -1
  19. package/frigg-cli/index.test.js +1 -4
  20. package/frigg-cli/init-command/backend-first-handler.js +756 -0
  21. package/frigg-cli/init-command/index.js +93 -0
  22. package/frigg-cli/init-command/template-handler.js +143 -0
  23. package/frigg-cli/install-command/index.js +1 -4
  24. package/frigg-cli/package.json +51 -0
  25. package/frigg-cli/start-command/index.js +24 -4
  26. package/frigg-cli/test/init-command.test.js +180 -0
  27. package/frigg-cli/test/npm-registry.test.js +319 -0
  28. package/frigg-cli/ui-command/index.js +154 -0
  29. package/frigg-cli/utils/app-resolver.js +319 -0
  30. package/frigg-cli/utils/backend-path.js +16 -17
  31. package/frigg-cli/utils/npm-registry.js +167 -0
  32. package/frigg-cli/utils/process-manager.js +199 -0
  33. package/frigg-cli/utils/repo-detection.js +405 -0
  34. package/infrastructure/DEPLOYMENT-INSTRUCTIONS.md +268 -0
  35. package/infrastructure/GENERATE-IAM-DOCS.md +278 -0
  36. package/infrastructure/IAM-POLICY-TEMPLATES.md +176 -0
  37. package/infrastructure/README.md +443 -0
  38. package/infrastructure/WEBSOCKET-CONFIGURATION.md +105 -0
  39. package/infrastructure/__tests__/fixtures/mock-aws-resources.js +391 -0
  40. package/infrastructure/__tests__/helpers/test-utils.js +277 -0
  41. package/infrastructure/aws-discovery.js +1176 -0
  42. package/infrastructure/aws-discovery.test.js +1220 -0
  43. package/infrastructure/build-time-discovery.js +206 -0
  44. package/infrastructure/build-time-discovery.test.js +378 -0
  45. package/infrastructure/create-frigg-infrastructure.js +3 -5
  46. package/infrastructure/env-validator.js +77 -0
  47. package/infrastructure/frigg-deployment-iam-stack.yaml +401 -0
  48. package/infrastructure/iam-generator.js +836 -0
  49. package/infrastructure/iam-generator.test.js +172 -0
  50. package/infrastructure/iam-policy-basic.json +218 -0
  51. package/infrastructure/iam-policy-full.json +288 -0
  52. package/infrastructure/integration.test.js +383 -0
  53. package/infrastructure/run-discovery.js +110 -0
  54. package/infrastructure/serverless-template.js +1472 -138
  55. package/infrastructure/serverless-template.test.js +1759 -0
  56. package/management-ui/.eslintrc.js +22 -0
  57. package/management-ui/README.md +203 -0
  58. package/management-ui/components.json +21 -0
  59. package/management-ui/docs/phase2-integration-guide.md +320 -0
  60. package/management-ui/index.html +13 -0
  61. package/management-ui/package-lock.json +16517 -0
  62. package/management-ui/package.json +76 -0
  63. package/management-ui/packages/devtools/frigg-cli/ui-command/index.js +302 -0
  64. package/management-ui/postcss.config.js +6 -0
  65. package/management-ui/server/api/backend.js +256 -0
  66. package/management-ui/server/api/cli.js +315 -0
  67. package/management-ui/server/api/codegen.js +663 -0
  68. package/management-ui/server/api/connections.js +857 -0
  69. package/management-ui/server/api/discovery.js +185 -0
  70. package/management-ui/server/api/environment/index.js +1 -0
  71. package/management-ui/server/api/environment/router.js +378 -0
  72. package/management-ui/server/api/environment.js +328 -0
  73. package/management-ui/server/api/integrations.js +876 -0
  74. package/management-ui/server/api/logs.js +248 -0
  75. package/management-ui/server/api/monitoring.js +282 -0
  76. package/management-ui/server/api/open-ide.js +31 -0
  77. package/management-ui/server/api/project.js +1029 -0
  78. package/management-ui/server/api/users/sessions.js +371 -0
  79. package/management-ui/server/api/users/simulation.js +254 -0
  80. package/management-ui/server/api/users.js +362 -0
  81. package/management-ui/server/api-contract.md +275 -0
  82. package/management-ui/server/index.js +873 -0
  83. package/management-ui/server/middleware/errorHandler.js +93 -0
  84. package/management-ui/server/middleware/security.js +32 -0
  85. package/management-ui/server/processManager.js +296 -0
  86. package/management-ui/server/server.js +346 -0
  87. package/management-ui/server/services/aws-monitor.js +413 -0
  88. package/management-ui/server/services/npm-registry.js +347 -0
  89. package/management-ui/server/services/template-engine.js +538 -0
  90. package/management-ui/server/utils/cliIntegration.js +220 -0
  91. package/management-ui/server/utils/environment/auditLogger.js +471 -0
  92. package/management-ui/server/utils/environment/awsParameterStore.js +264 -0
  93. package/management-ui/server/utils/environment/encryption.js +278 -0
  94. package/management-ui/server/utils/environment/envFileManager.js +286 -0
  95. package/management-ui/server/utils/import-commonjs.js +28 -0
  96. package/management-ui/server/utils/response.js +83 -0
  97. package/management-ui/server/websocket/handler.js +325 -0
  98. package/management-ui/src/App.jsx +109 -0
  99. package/management-ui/src/assets/FriggLogo.svg +1 -0
  100. package/management-ui/src/components/AppRouter.jsx +65 -0
  101. package/management-ui/src/components/Button.jsx +70 -0
  102. package/management-ui/src/components/Card.jsx +97 -0
  103. package/management-ui/src/components/EnvironmentCompare.jsx +400 -0
  104. package/management-ui/src/components/EnvironmentEditor.jsx +372 -0
  105. package/management-ui/src/components/EnvironmentImportExport.jsx +469 -0
  106. package/management-ui/src/components/EnvironmentSchema.jsx +491 -0
  107. package/management-ui/src/components/EnvironmentSecurity.jsx +463 -0
  108. package/management-ui/src/components/ErrorBoundary.jsx +73 -0
  109. package/management-ui/src/components/IntegrationCard.jsx +481 -0
  110. package/management-ui/src/components/IntegrationCardEnhanced.jsx +770 -0
  111. package/management-ui/src/components/IntegrationExplorer.jsx +379 -0
  112. package/management-ui/src/components/IntegrationStatus.jsx +336 -0
  113. package/management-ui/src/components/Layout.jsx +716 -0
  114. package/management-ui/src/components/LoadingSpinner.jsx +113 -0
  115. package/management-ui/src/components/RepositoryPicker.jsx +248 -0
  116. package/management-ui/src/components/SessionMonitor.jsx +350 -0
  117. package/management-ui/src/components/StatusBadge.jsx +208 -0
  118. package/management-ui/src/components/UserContextSwitcher.jsx +212 -0
  119. package/management-ui/src/components/UserSimulation.jsx +327 -0
  120. package/management-ui/src/components/Welcome.jsx +434 -0
  121. package/management-ui/src/components/codegen/APIEndpointGenerator.jsx +637 -0
  122. package/management-ui/src/components/codegen/APIModuleSelector.jsx +227 -0
  123. package/management-ui/src/components/codegen/CodeGenerationWizard.jsx +247 -0
  124. package/management-ui/src/components/codegen/CodePreviewEditor.jsx +316 -0
  125. package/management-ui/src/components/codegen/DynamicModuleForm.jsx +271 -0
  126. package/management-ui/src/components/codegen/FormBuilder.jsx +737 -0
  127. package/management-ui/src/components/codegen/IntegrationGenerator.jsx +855 -0
  128. package/management-ui/src/components/codegen/ProjectScaffoldWizard.jsx +797 -0
  129. package/management-ui/src/components/codegen/SchemaBuilder.jsx +303 -0
  130. package/management-ui/src/components/codegen/TemplateSelector.jsx +586 -0
  131. package/management-ui/src/components/codegen/index.js +10 -0
  132. package/management-ui/src/components/connections/ConnectionConfigForm.jsx +362 -0
  133. package/management-ui/src/components/connections/ConnectionHealthMonitor.jsx +182 -0
  134. package/management-ui/src/components/connections/ConnectionTester.jsx +200 -0
  135. package/management-ui/src/components/connections/EntityRelationshipMapper.jsx +292 -0
  136. package/management-ui/src/components/connections/OAuthFlow.jsx +204 -0
  137. package/management-ui/src/components/connections/index.js +5 -0
  138. package/management-ui/src/components/index.js +21 -0
  139. package/management-ui/src/components/monitoring/APIGatewayMetrics.jsx +222 -0
  140. package/management-ui/src/components/monitoring/LambdaMetrics.jsx +169 -0
  141. package/management-ui/src/components/monitoring/MetricsChart.jsx +197 -0
  142. package/management-ui/src/components/monitoring/MonitoringDashboard.jsx +393 -0
  143. package/management-ui/src/components/monitoring/SQSMetrics.jsx +246 -0
  144. package/management-ui/src/components/monitoring/index.js +6 -0
  145. package/management-ui/src/components/monitoring/monitoring.css +218 -0
  146. package/management-ui/src/components/theme-provider.jsx +52 -0
  147. package/management-ui/src/components/theme-toggle.jsx +39 -0
  148. package/management-ui/src/components/ui/badge.tsx +36 -0
  149. package/management-ui/src/components/ui/button.test.jsx +56 -0
  150. package/management-ui/src/components/ui/button.tsx +57 -0
  151. package/management-ui/src/components/ui/card.tsx +76 -0
  152. package/management-ui/src/components/ui/dropdown-menu.tsx +199 -0
  153. package/management-ui/src/components/ui/select.tsx +157 -0
  154. package/management-ui/src/components/ui/skeleton.jsx +15 -0
  155. package/management-ui/src/hooks/useFrigg.jsx +601 -0
  156. package/management-ui/src/hooks/useSocket.jsx +58 -0
  157. package/management-ui/src/index.css +193 -0
  158. package/management-ui/src/lib/utils.ts +6 -0
  159. package/management-ui/src/main.jsx +10 -0
  160. package/management-ui/src/pages/CodeGeneration.jsx +14 -0
  161. package/management-ui/src/pages/Connections.jsx +252 -0
  162. package/management-ui/src/pages/ConnectionsEnhanced.jsx +633 -0
  163. package/management-ui/src/pages/Dashboard.jsx +311 -0
  164. package/management-ui/src/pages/Environment.jsx +314 -0
  165. package/management-ui/src/pages/IntegrationConfigure.jsx +669 -0
  166. package/management-ui/src/pages/IntegrationDiscovery.jsx +567 -0
  167. package/management-ui/src/pages/IntegrationTest.jsx +742 -0
  168. package/management-ui/src/pages/Integrations.jsx +253 -0
  169. package/management-ui/src/pages/Monitoring.jsx +17 -0
  170. package/management-ui/src/pages/Simulation.jsx +155 -0
  171. package/management-ui/src/pages/Users.jsx +492 -0
  172. package/management-ui/src/services/api.js +41 -0
  173. package/management-ui/src/services/apiModuleService.js +193 -0
  174. package/management-ui/src/services/websocket-handlers.js +120 -0
  175. package/management-ui/src/test/api/project.test.js +273 -0
  176. package/management-ui/src/test/components/Welcome.test.jsx +378 -0
  177. package/management-ui/src/test/mocks/server.js +178 -0
  178. package/management-ui/src/test/setup.js +61 -0
  179. package/management-ui/src/test/utils/test-utils.jsx +134 -0
  180. package/management-ui/src/utils/repository.js +98 -0
  181. package/management-ui/src/utils/repository.test.js +118 -0
  182. package/management-ui/src/workflows/phase2-integration-workflows.js +884 -0
  183. package/management-ui/tailwind.config.js +63 -0
  184. package/management-ui/tsconfig.json +37 -0
  185. package/management-ui/tsconfig.node.json +10 -0
  186. package/management-ui/vite.config.js +26 -0
  187. package/management-ui/vitest.config.js +38 -0
  188. package/package.json +20 -9
  189. package/infrastructure/app-handler-helpers.js +0 -57
  190. package/infrastructure/backend-utils.js +0 -90
  191. package/infrastructure/routers/auth.js +0 -26
  192. package/infrastructure/routers/integration-defined-routers.js +0 -37
  193. package/infrastructure/routers/middleware/loadUser.js +0 -15
  194. package/infrastructure/routers/middleware/requireLoggedInUser.js +0 -12
  195. package/infrastructure/routers/user.js +0 -41
  196. package/infrastructure/routers/websocket.js +0 -55
  197. package/infrastructure/workers/integration-defined-workers.js +0 -24
@@ -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'