@aws/nx-plugin 0.46.0 → 0.48.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/src/infra/app/generator.js +4 -1
- package/src/infra/app/generator.js.map +1 -1
- package/src/mcp-server/tools/create-workspace-command.js +4 -0
- package/src/mcp-server/tools/create-workspace-command.js.map +1 -1
- package/src/mcp-server/tools/general-guidance.js +3 -1
- package/src/mcp-server/tools/general-guidance.js.map +1 -1
- package/src/preset/__snapshots__/generator.spec.ts.snap +9 -0
- package/src/preset/generator.d.ts +1 -1
- package/src/preset/generator.js +4 -1
- package/src/preset/generator.js.map +1 -1
- package/src/preset/schema.d.ts +3 -0
- package/src/preset/schema.json +9 -1
- package/src/py/fast-api/__snapshots__/generator.spec.ts.snap +60 -0
- package/src/py/fast-api/generator.js +5 -3
- package/src/py/fast-api/generator.js.map +1 -1
- package/src/py/fast-api/react/__snapshots__/generator.spec.ts.snap +1 -0
- package/src/py/fast-api/schema.d.ts +3 -1
- package/src/py/fast-api/schema.json +4 -4
- package/src/py/lambda-function/__snapshots__/generator.spec.ts.snap +310 -0
- package/src/py/lambda-function/generator.js +17 -25
- package/src/py/lambda-function/generator.js.map +1 -1
- package/src/py/lambda-function/schema.d.ts +3 -0
- package/src/py/lambda-function/schema.json +8 -0
- package/src/py/mcp-server/generator.js +4 -2
- package/src/py/mcp-server/generator.js.map +1 -1
- package/src/py/mcp-server/schema.d.ts +4 -1
- package/src/py/mcp-server/schema.json +4 -4
- package/src/py/strands-agent/generator.js +4 -2
- package/src/py/strands-agent/generator.js.map +1 -1
- package/src/py/strands-agent/schema.d.ts +3 -1
- package/src/py/strands-agent/schema.json +4 -4
- package/src/terraform/project/generator.js +2 -1
- package/src/terraform/project/generator.js.map +1 -1
- package/src/trpc/backend/__snapshots__/generator.spec.ts.snap +60 -0
- package/src/trpc/backend/generator.js +4 -2
- package/src/trpc/backend/generator.js.map +1 -1
- package/src/trpc/backend/schema.d.ts +2 -1
- package/src/trpc/backend/schema.json +4 -4
- package/src/trpc/react/__snapshots__/generator.spec.ts.snap +1 -0
- package/src/ts/lambda-function/__snapshots__/generator.spec.ts.snap +310 -0
- package/src/ts/lambda-function/generator.js +17 -27
- package/src/ts/lambda-function/generator.js.map +1 -1
- package/src/ts/lambda-function/schema.d.ts +3 -0
- package/src/ts/lambda-function/schema.json +8 -0
- package/src/ts/mcp-server/generator.js +4 -2
- package/src/ts/mcp-server/generator.js.map +1 -1
- package/src/ts/mcp-server/schema.d.ts +3 -1
- package/src/ts/mcp-server/schema.json +4 -4
- package/src/ts/nx-generator/__snapshots__/generator.spec.ts.snap +27 -1
- package/src/ts/nx-generator/files/nx-plugin-for-aws/docs/__nameKebabCase__.mdx.template +31 -0
- package/src/ts/nx-generator/files/nx-plugin-for-aws/generator/generator.spec.ts.template +1 -1
- package/src/ts/react-website/app/__snapshots__/generator.spec.ts.snap +756 -0
- package/src/ts/react-website/app/generator.js +44 -43
- package/src/ts/react-website/app/generator.js.map +1 -1
- package/src/ts/react-website/app/schema.d.ts +2 -0
- package/src/ts/react-website/app/schema.json +8 -0
- package/src/ts/react-website/cognito-auth/__snapshots__/generator.spec.ts.snap +259 -0
- package/src/ts/react-website/cognito-auth/generator.js +12 -13
- package/src/ts/react-website/cognito-auth/generator.js.map +1 -1
- package/src/ts/react-website/cognito-auth/schema.d.ts +4 -0
- package/src/ts/react-website/cognito-auth/schema.json +8 -0
- package/src/ts/react-website/runtime-config/__snapshots__/generator.spec.ts.snap +0 -40
- package/src/ts/react-website/runtime-config/generator.js +0 -2
- package/src/ts/react-website/runtime-config/generator.js.map +1 -1
- package/src/utils/agent-core-constructs/agent-core-constructs.d.ts +4 -2
- package/src/utils/agent-core-constructs/agent-core-constructs.js.map +1 -1
- package/src/utils/api-constructs/api-constructs.d.ts +2 -1
- package/src/utils/api-constructs/api-constructs.js.map +1 -1
- package/src/utils/api-constructs/files/terraform/app/apis/http/__apiNameKebabCase__/__apiNameKebabCase__.tf.template +10 -0
- package/src/utils/api-constructs/files/terraform/app/apis/rest/__apiNameKebabCase__/__apiNameKebabCase__.tf.template +10 -0
- package/src/utils/config/index.d.ts +6 -0
- package/src/utils/config/index.js.map +1 -1
- package/src/utils/files/terraform/src/core/runtime-config/entry/entry.tf.template +119 -0
- package/src/utils/files/terraform/src/core/runtime-config/read/read.tf.template +28 -0
- package/src/utils/files/terraform/src/metrics/metrics.tf.template +7 -1
- package/src/{py/lambda-function/files/common/constructs/src/app/lambda-functions/__constructFunctionKebabCase__.ts.template → utils/function-constructs/files/cdk/app/lambda-functions/__functionNameKebabCase__.ts.template} +5 -5
- package/src/utils/function-constructs/files/terraform/app/lambda-functions/__functionNameKebabCase__/__functionNameKebabCase__.tf.template +150 -0
- package/src/utils/function-constructs/function-constructs.d.ts +20 -0
- package/src/utils/function-constructs/function-constructs.js +57 -0
- package/src/utils/function-constructs/function-constructs.js.map +1 -0
- package/src/utils/iac.d.ts +21 -0
- package/src/utils/iac.js +25 -0
- package/src/utils/iac.js.map +1 -0
- package/src/utils/identity-constructs/files/terraform/core/user-identity/add-callback-url/add-callback-url.tf.template +123 -0
- package/src/utils/identity-constructs/files/terraform/core/user-identity/identity/identity.tf.template +421 -0
- package/src/utils/identity-constructs/files/terraform/core/user-identity/main.tf.template +47 -0
- package/src/utils/identity-constructs/identity-constructs.d.ts +16 -0
- package/src/utils/identity-constructs/identity-constructs.js +84 -0
- package/src/utils/identity-constructs/identity-constructs.js.map +1 -0
- package/src/utils/metrics.js +1 -1
- package/src/utils/metrics.js.map +1 -1
- package/src/utils/shared-constructs.d.ts +3 -2
- package/src/utils/shared-constructs.js +27 -3
- package/src/utils/shared-constructs.js.map +1 -1
- package/src/utils/website-constructs/files/terraform/app/static-websites/__websiteNameKebabCase__/__websiteNameKebabCase__.tf.template +42 -0
- package/src/utils/website-constructs/files/terraform/core/static-website/static-website.tf.template +709 -0
- package/src/utils/website-constructs/website-constructs.d.ts +19 -0
- package/src/utils/website-constructs/website-constructs.js +61 -0
- package/src/utils/website-constructs/website-constructs.js.map +1 -0
- package/src/ts/lambda-function/files/common/constructs/src/app/lambda-functions/__constructFunctionNameKebabCase__.ts.template +0 -24
- /package/src/{ts/react-website/cognito-auth/files/common/constructs/src → utils/identity-constructs/files/cdk}/core/user-identity.ts.template +0 -0
- /package/src/{ts/react-website/app/files/common/constructs/src → utils/website-constructs/files/cdk}/app/static-websites/__websiteNameKebabCase__.ts.template +0 -0
- /package/src/{ts/react-website/app/files/common/constructs/src → utils/website-constructs/files/cdk}/core/static-website.ts.template +0 -0
|
@@ -64,3 +64,313 @@ export class TestProjectTestFunction extends Function {
|
|
|
64
64
|
",
|
|
65
65
|
}
|
|
66
66
|
`;
|
|
67
|
+
|
|
68
|
+
exports[`lambda-handler project generator > terraform iacProvider > should generate terraform files for python lambda function and snapshot them > terraform-python-lambda-files 1`] = `
|
|
69
|
+
{
|
|
70
|
+
"test-project-test-function.tf": "variable "tags" {
|
|
71
|
+
description = "Tags to apply to resources"
|
|
72
|
+
type = map(string)
|
|
73
|
+
default = {}
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
variable "env" {
|
|
77
|
+
description = "Additional environment variables for the Lambda function"
|
|
78
|
+
type = map(string)
|
|
79
|
+
default = {}
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
variable "additional_iam_policy_statements" {
|
|
83
|
+
description = "Additional IAM policy statements to attach to the Lambda role"
|
|
84
|
+
type = list(object({
|
|
85
|
+
Effect = string
|
|
86
|
+
Action = list(string)
|
|
87
|
+
Resource = list(string)
|
|
88
|
+
}))
|
|
89
|
+
default = []
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
data "aws_caller_identity" "current" {}
|
|
93
|
+
data "aws_region" "current" {}
|
|
94
|
+
|
|
95
|
+
locals {
|
|
96
|
+
aws_account_id = data.aws_caller_identity.current.account_id
|
|
97
|
+
aws_region = data.aws_region.current.name
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
resource "random_string" "suffix" {
|
|
101
|
+
length = 8
|
|
102
|
+
special = false
|
|
103
|
+
upper = false
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
resource "aws_iam_role" "lambda_role" {
|
|
107
|
+
name = "test-project-test-function-role-\${random_string.suffix.result}"
|
|
108
|
+
|
|
109
|
+
assume_role_policy = jsonencode({
|
|
110
|
+
Version = "2012-10-17"
|
|
111
|
+
Statement = [
|
|
112
|
+
{
|
|
113
|
+
Sid = "LambdaAssumeRolePolicy"
|
|
114
|
+
Effect = "Allow"
|
|
115
|
+
Principal = {
|
|
116
|
+
Service = "lambda.amazonaws.com"
|
|
117
|
+
}
|
|
118
|
+
Action = "sts:AssumeRole"
|
|
119
|
+
}
|
|
120
|
+
]
|
|
121
|
+
})
|
|
122
|
+
|
|
123
|
+
tags = var.tags
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
resource "aws_iam_policy" "lambda_policy" {
|
|
127
|
+
name = "test-project-test-function-policy-\${random_string.suffix.result}"
|
|
128
|
+
description = "Policy for test-project-test-function Lambda function"
|
|
129
|
+
|
|
130
|
+
policy = jsonencode({
|
|
131
|
+
Version = "2012-10-17"
|
|
132
|
+
Statement = concat([
|
|
133
|
+
{
|
|
134
|
+
Sid = "CloudWatchLogsAccess"
|
|
135
|
+
Effect = "Allow"
|
|
136
|
+
Action = [
|
|
137
|
+
"logs:CreateLogGroup",
|
|
138
|
+
"logs:CreateLogStream",
|
|
139
|
+
"logs:PutLogEvents"
|
|
140
|
+
]
|
|
141
|
+
Resource = [
|
|
142
|
+
"arn:aws:logs:\${local.aws_region}:\${local.aws_account_id}:log-group:/aws/lambda/test-project-test-function-\${random_string.suffix.result}:*"
|
|
143
|
+
]
|
|
144
|
+
},
|
|
145
|
+
{
|
|
146
|
+
Sid = "XRayAccess"
|
|
147
|
+
Effect = "Allow"
|
|
148
|
+
Action = [
|
|
149
|
+
"xray:PutTraceSegments",
|
|
150
|
+
"xray:PutTelemetryRecords"
|
|
151
|
+
]
|
|
152
|
+
Resource = ["*"]
|
|
153
|
+
}
|
|
154
|
+
], var.additional_iam_policy_statements)
|
|
155
|
+
})
|
|
156
|
+
|
|
157
|
+
tags = var.tags
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
# Attach the policy to the role
|
|
161
|
+
resource "aws_iam_role_policy_attachment" "lambda_policy_attachment" {
|
|
162
|
+
role = aws_iam_role.lambda_role.name
|
|
163
|
+
policy_arn = aws_iam_policy.lambda_policy.arn
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
data "archive_file" "lambda_zip" {
|
|
167
|
+
type = "zip"
|
|
168
|
+
source_dir = "\${path.module}/../../../../../../../dist/apps/test_project/bundle"
|
|
169
|
+
output_path = "\${path.module}/../../../../../../../dist/packages/common/terraform/lambda-functions/test-project-test-function/lambda.zip"
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
resource "aws_lambda_function" "lambda_function" {
|
|
173
|
+
#checkov:skip=CKV_AWS_117:Lambda function does not need to be in VPC for this use case
|
|
174
|
+
#checkov:skip=CKV_AWS_116:Dead Letter Queue not required for this simple use case
|
|
175
|
+
#checkov:skip=CKV_AWS_272:Code signing not required for this use case
|
|
176
|
+
#checkov:skip=CKV_AWS_115:Concurrent execution limit not required for this use case
|
|
177
|
+
#checkov:skip=CKV_AWS_173:Lambda environment variables encrypted by managed key
|
|
178
|
+
filename = data.archive_file.lambda_zip.output_path
|
|
179
|
+
function_name = "test-project-test-function-\${random_string.suffix.result}"
|
|
180
|
+
role = aws_iam_role.lambda_role.arn
|
|
181
|
+
handler = "test_project.test_function.lambda_handler"
|
|
182
|
+
source_code_hash = data.archive_file.lambda_zip.output_base64sha256
|
|
183
|
+
runtime = "python3.12"
|
|
184
|
+
timeout = 30
|
|
185
|
+
|
|
186
|
+
tracing_config {
|
|
187
|
+
mode = "Active"
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
environment {
|
|
191
|
+
variables = merge({
|
|
192
|
+
AWS_CONNECTION_REUSE_ENABLED = "1"
|
|
193
|
+
}, var.env)
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
tags = var.tags
|
|
197
|
+
|
|
198
|
+
depends_on = [aws_iam_role_policy_attachment.lambda_policy_attachment]
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
output "function_name" {
|
|
202
|
+
description = "Name of the Lambda function"
|
|
203
|
+
value = aws_lambda_function.lambda_function.function_name
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
output "function_arn" {
|
|
207
|
+
description = "ARN of the Lambda function"
|
|
208
|
+
value = aws_lambda_function.lambda_function.arn
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
output "role_arn" {
|
|
212
|
+
description = "ARN of the Lambda execution role"
|
|
213
|
+
value = aws_iam_role.lambda_role.arn
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
output "role_name" {
|
|
217
|
+
description = "Name of the Lambda execution role"
|
|
218
|
+
value = aws_iam_role.lambda_role.name
|
|
219
|
+
}
|
|
220
|
+
",
|
|
221
|
+
}
|
|
222
|
+
`;
|
|
223
|
+
|
|
224
|
+
exports[`lambda-handler project generator > terraform iacProvider > should match snapshot for terraform generated files with different configurations > terraform-python-lambda-snapshot-function.tf 1`] = `
|
|
225
|
+
"variable "tags" {
|
|
226
|
+
description = "Tags to apply to resources"
|
|
227
|
+
type = map(string)
|
|
228
|
+
default = {}
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
variable "env" {
|
|
232
|
+
description = "Additional environment variables for the Lambda function"
|
|
233
|
+
type = map(string)
|
|
234
|
+
default = {}
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
variable "additional_iam_policy_statements" {
|
|
238
|
+
description = "Additional IAM policy statements to attach to the Lambda role"
|
|
239
|
+
type = list(object({
|
|
240
|
+
Effect = string
|
|
241
|
+
Action = list(string)
|
|
242
|
+
Resource = list(string)
|
|
243
|
+
}))
|
|
244
|
+
default = []
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
data "aws_caller_identity" "current" {}
|
|
248
|
+
data "aws_region" "current" {}
|
|
249
|
+
|
|
250
|
+
locals {
|
|
251
|
+
aws_account_id = data.aws_caller_identity.current.account_id
|
|
252
|
+
aws_region = data.aws_region.current.name
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
resource "random_string" "suffix" {
|
|
256
|
+
length = 8
|
|
257
|
+
special = false
|
|
258
|
+
upper = false
|
|
259
|
+
}
|
|
260
|
+
|
|
261
|
+
resource "aws_iam_role" "lambda_role" {
|
|
262
|
+
name = "test-project-snapshot-function-role-\${random_string.suffix.result}"
|
|
263
|
+
|
|
264
|
+
assume_role_policy = jsonencode({
|
|
265
|
+
Version = "2012-10-17"
|
|
266
|
+
Statement = [
|
|
267
|
+
{
|
|
268
|
+
Sid = "LambdaAssumeRolePolicy"
|
|
269
|
+
Effect = "Allow"
|
|
270
|
+
Principal = {
|
|
271
|
+
Service = "lambda.amazonaws.com"
|
|
272
|
+
}
|
|
273
|
+
Action = "sts:AssumeRole"
|
|
274
|
+
}
|
|
275
|
+
]
|
|
276
|
+
})
|
|
277
|
+
|
|
278
|
+
tags = var.tags
|
|
279
|
+
}
|
|
280
|
+
|
|
281
|
+
resource "aws_iam_policy" "lambda_policy" {
|
|
282
|
+
name = "test-project-snapshot-function-policy-\${random_string.suffix.result}"
|
|
283
|
+
description = "Policy for test-project-snapshot-function Lambda function"
|
|
284
|
+
|
|
285
|
+
policy = jsonencode({
|
|
286
|
+
Version = "2012-10-17"
|
|
287
|
+
Statement = concat([
|
|
288
|
+
{
|
|
289
|
+
Sid = "CloudWatchLogsAccess"
|
|
290
|
+
Effect = "Allow"
|
|
291
|
+
Action = [
|
|
292
|
+
"logs:CreateLogGroup",
|
|
293
|
+
"logs:CreateLogStream",
|
|
294
|
+
"logs:PutLogEvents"
|
|
295
|
+
]
|
|
296
|
+
Resource = [
|
|
297
|
+
"arn:aws:logs:\${local.aws_region}:\${local.aws_account_id}:log-group:/aws/lambda/test-project-snapshot-function-\${random_string.suffix.result}:*"
|
|
298
|
+
]
|
|
299
|
+
},
|
|
300
|
+
{
|
|
301
|
+
Sid = "XRayAccess"
|
|
302
|
+
Effect = "Allow"
|
|
303
|
+
Action = [
|
|
304
|
+
"xray:PutTraceSegments",
|
|
305
|
+
"xray:PutTelemetryRecords"
|
|
306
|
+
]
|
|
307
|
+
Resource = ["*"]
|
|
308
|
+
}
|
|
309
|
+
], var.additional_iam_policy_statements)
|
|
310
|
+
})
|
|
311
|
+
|
|
312
|
+
tags = var.tags
|
|
313
|
+
}
|
|
314
|
+
|
|
315
|
+
# Attach the policy to the role
|
|
316
|
+
resource "aws_iam_role_policy_attachment" "lambda_policy_attachment" {
|
|
317
|
+
role = aws_iam_role.lambda_role.name
|
|
318
|
+
policy_arn = aws_iam_policy.lambda_policy.arn
|
|
319
|
+
}
|
|
320
|
+
|
|
321
|
+
data "archive_file" "lambda_zip" {
|
|
322
|
+
type = "zip"
|
|
323
|
+
source_dir = "\${path.module}/../../../../../../../dist/apps/test_project/bundle"
|
|
324
|
+
output_path = "\${path.module}/../../../../../../../dist/packages/common/terraform/lambda-functions/test-project-snapshot-function/lambda.zip"
|
|
325
|
+
}
|
|
326
|
+
|
|
327
|
+
resource "aws_lambda_function" "lambda_function" {
|
|
328
|
+
#checkov:skip=CKV_AWS_117:Lambda function does not need to be in VPC for this use case
|
|
329
|
+
#checkov:skip=CKV_AWS_116:Dead Letter Queue not required for this simple use case
|
|
330
|
+
#checkov:skip=CKV_AWS_272:Code signing not required for this use case
|
|
331
|
+
#checkov:skip=CKV_AWS_115:Concurrent execution limit not required for this use case
|
|
332
|
+
#checkov:skip=CKV_AWS_173:Lambda environment variables encrypted by managed key
|
|
333
|
+
filename = data.archive_file.lambda_zip.output_path
|
|
334
|
+
function_name = "test-project-snapshot-function-\${random_string.suffix.result}"
|
|
335
|
+
role = aws_iam_role.lambda_role.arn
|
|
336
|
+
handler = "test_project.snapshot_function.lambda_handler"
|
|
337
|
+
source_code_hash = data.archive_file.lambda_zip.output_base64sha256
|
|
338
|
+
runtime = "python3.12"
|
|
339
|
+
timeout = 30
|
|
340
|
+
|
|
341
|
+
tracing_config {
|
|
342
|
+
mode = "Active"
|
|
343
|
+
}
|
|
344
|
+
|
|
345
|
+
environment {
|
|
346
|
+
variables = merge({
|
|
347
|
+
AWS_CONNECTION_REUSE_ENABLED = "1"
|
|
348
|
+
}, var.env)
|
|
349
|
+
}
|
|
350
|
+
|
|
351
|
+
tags = var.tags
|
|
352
|
+
|
|
353
|
+
depends_on = [aws_iam_role_policy_attachment.lambda_policy_attachment]
|
|
354
|
+
}
|
|
355
|
+
|
|
356
|
+
output "function_name" {
|
|
357
|
+
description = "Name of the Lambda function"
|
|
358
|
+
value = aws_lambda_function.lambda_function.function_name
|
|
359
|
+
}
|
|
360
|
+
|
|
361
|
+
output "function_arn" {
|
|
362
|
+
description = "ARN of the Lambda function"
|
|
363
|
+
value = aws_lambda_function.lambda_function.arn
|
|
364
|
+
}
|
|
365
|
+
|
|
366
|
+
output "role_arn" {
|
|
367
|
+
description = "ARN of the Lambda execution role"
|
|
368
|
+
value = aws_iam_role.lambda_role.arn
|
|
369
|
+
}
|
|
370
|
+
|
|
371
|
+
output "role_name" {
|
|
372
|
+
description = "Name of the Lambda execution role"
|
|
373
|
+
value = aws_iam_role.lambda_role.name
|
|
374
|
+
}
|
|
375
|
+
"
|
|
376
|
+
`;
|
|
@@ -10,9 +10,7 @@ const devkit_1 = require("@nx/devkit");
|
|
|
10
10
|
const provider_1 = require("@nxlv/python/src/provider/uv/provider");
|
|
11
11
|
const logger_1 = require("@nxlv/python/src/executors/utils/logger");
|
|
12
12
|
const shared_constructs_1 = require("../../utils/shared-constructs");
|
|
13
|
-
const shared_constructs_constants_1 = require("../../utils/shared-constructs-constants");
|
|
14
13
|
const names_1 = require("../../utils/names");
|
|
15
|
-
const ast_1 = require("../../utils/ast");
|
|
16
14
|
const format_1 = require("../../utils/format");
|
|
17
15
|
const npm_scope_1 = require("../../utils/npm-scope");
|
|
18
16
|
const object_1 = require("../../utils/object");
|
|
@@ -20,6 +18,8 @@ const nx_1 = require("../../utils/nx");
|
|
|
20
18
|
const metrics_1 = require("../../utils/metrics");
|
|
21
19
|
const bundle_1 = require("../../utils/bundle");
|
|
22
20
|
const py_1 = require("../../utils/py");
|
|
21
|
+
const function_constructs_1 = require("../../utils/function-constructs/function-constructs");
|
|
22
|
+
const iac_1 = require("../../utils/iac");
|
|
23
23
|
exports.LAMBDA_FUNCTION_GENERATOR_INFO = (0, nx_1.getGeneratorInfo)(__filename);
|
|
24
24
|
const getLambdaFunctionDetails = (tree, schema) => {
|
|
25
25
|
const scope = (0, names_1.toSnakeCase)((0, npm_scope_1.getNpmScope)(tree));
|
|
@@ -52,7 +52,7 @@ const pyLambdaFunctionGenerator = (tree, schema) => tslib_1.__awaiter(void 0, vo
|
|
|
52
52
|
// Module name is the last part of the source root,
|
|
53
53
|
const sourceParts = projectConfig.sourceRoot.split('/');
|
|
54
54
|
const moduleName = sourceParts[sourceParts.length - 1];
|
|
55
|
-
const {
|
|
55
|
+
const { normalizedFunctionName, normalizedFunctionPath } = getLambdaFunctionDetails(tree, {
|
|
56
56
|
moduleName,
|
|
57
57
|
functionName: schema.functionName,
|
|
58
58
|
functionPath: schema.functionPath,
|
|
@@ -66,10 +66,21 @@ const pyLambdaFunctionGenerator = (tree, schema) => tslib_1.__awaiter(void 0, vo
|
|
|
66
66
|
if (tree.exists(functionPath)) {
|
|
67
67
|
throw new Error(`This project already has a a lambda function with the name ${normalizedFunctionName}. Please remove the lambda function before running this generator or use a different name.`);
|
|
68
68
|
}
|
|
69
|
-
yield (0,
|
|
69
|
+
const iacProvider = yield (0, iac_1.resolveIacProvider)(tree, schema.iacProvider);
|
|
70
|
+
yield (0, shared_constructs_1.sharedConstructsGenerator)(tree, {
|
|
71
|
+
iacProvider,
|
|
72
|
+
});
|
|
73
|
+
(0, function_constructs_1.addLambdaFunctionInfra)(tree, {
|
|
74
|
+
functionProjectName: projectConfig.name,
|
|
75
|
+
functionNameClassName: constructFunctionClassName,
|
|
76
|
+
functionNameKebabCase: constructFunctionKebabCase,
|
|
77
|
+
handler: normalizedFunctionPath,
|
|
78
|
+
bundlePathFromRoot: `dist/${dir}/bundle`,
|
|
79
|
+
runtime: 'python',
|
|
80
|
+
iacProvider,
|
|
81
|
+
});
|
|
70
82
|
const enhancedOptions = Object.assign(Object.assign({}, schema), { dir,
|
|
71
|
-
|
|
72
|
-
constructFunctionKebabCase, constructHandlerFilePath: normalizedFunctionPath, lambdaFunctionClassName, lambdaFunctionSnakeCase: normalizedFunctionName });
|
|
83
|
+
lambdaFunctionClassName, lambdaFunctionSnakeCase: normalizedFunctionName });
|
|
73
84
|
// Check if the project has a bundle target and if not add it
|
|
74
85
|
(0, bundle_1.addPythonBundleTarget)(projectConfig);
|
|
75
86
|
projectConfig.targets = (0, object_1.sortObjectKeys)(projectConfig.targets);
|
|
@@ -80,25 +91,6 @@ const pyLambdaFunctionGenerator = (tree, schema) => tslib_1.__awaiter(void 0, vo
|
|
|
80
91
|
(0, devkit_1.joinPathFragments)(projectConfig.sourceRoot, (_b = schema.functionPath) !== null && _b !== void 0 ? _b : ''), enhancedOptions, { overwriteStrategy: devkit_1.OverwriteStrategy.Overwrite });
|
|
81
92
|
// Generate the lambda handler test file
|
|
82
93
|
(0, devkit_1.generateFiles)(tree, (0, devkit_1.joinPathFragments)(__dirname, 'files', 'tests'), (0, devkit_1.joinPathFragments)(dir, 'tests'), enhancedOptions, { overwriteStrategy: devkit_1.OverwriteStrategy.Overwrite });
|
|
83
|
-
if (!tree.exists((0, devkit_1.joinPathFragments)(shared_constructs_constants_1.PACKAGES_DIR, shared_constructs_constants_1.SHARED_CONSTRUCTS_DIR, 'src', 'app', 'lambda-functions', `${constructFunctionKebabCase}.ts`))) {
|
|
84
|
-
(0, devkit_1.generateFiles)(tree, (0, devkit_1.joinPathFragments)(__dirname, 'files', shared_constructs_constants_1.SHARED_CONSTRUCTS_DIR, 'src', 'app'), (0, devkit_1.joinPathFragments)(shared_constructs_constants_1.PACKAGES_DIR, shared_constructs_constants_1.SHARED_CONSTRUCTS_DIR, 'src', 'app'), enhancedOptions, { overwriteStrategy: devkit_1.OverwriteStrategy.KeepExisting });
|
|
85
|
-
(0, ast_1.addStarExport)(tree, (0, devkit_1.joinPathFragments)(shared_constructs_constants_1.PACKAGES_DIR, shared_constructs_constants_1.SHARED_CONSTRUCTS_DIR, 'src', 'app', 'index.ts'), './lambda-functions/index.js');
|
|
86
|
-
(0, ast_1.addStarExport)(tree, (0, devkit_1.joinPathFragments)(shared_constructs_constants_1.PACKAGES_DIR, shared_constructs_constants_1.SHARED_CONSTRUCTS_DIR, 'src', 'app', 'lambda-functions', 'index.ts'), `./${constructFunctionKebabCase}.js`);
|
|
87
|
-
}
|
|
88
|
-
(0, devkit_1.updateJson)(tree, (0, devkit_1.joinPathFragments)(shared_constructs_constants_1.PACKAGES_DIR, shared_constructs_constants_1.SHARED_CONSTRUCTS_DIR, 'project.json'), (config) => {
|
|
89
|
-
var _a;
|
|
90
|
-
if (!config.targets) {
|
|
91
|
-
config.targets = {};
|
|
92
|
-
}
|
|
93
|
-
if (!config.targets.build) {
|
|
94
|
-
config.targets.build = {};
|
|
95
|
-
}
|
|
96
|
-
config.targets.build.dependsOn = [
|
|
97
|
-
...((_a = config.targets.build.dependsOn) !== null && _a !== void 0 ? _a : []).filter((t) => t !== `${projectConfig.name}:build`),
|
|
98
|
-
`${projectConfig.name}:build`,
|
|
99
|
-
];
|
|
100
|
-
return config;
|
|
101
|
-
});
|
|
102
94
|
(0, py_1.addDependenciesToPyProjectToml)(tree, dir, [
|
|
103
95
|
'aws-lambda-powertools',
|
|
104
96
|
'aws-lambda-powertools[tracer]',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generator.js","sourceRoot":"","sources":["../../../../../../packages/nx-plugin/src/py/lambda-function/generator.ts"],"names":[],"mappings":";;;;AAAA;;;GAGG;AACH,
|
|
1
|
+
{"version":3,"file":"generator.js","sourceRoot":"","sources":["../../../../../../packages/nx-plugin/src/py/lambda-function/generator.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,6 +3,8 @@
|
|
|
3
3
|
* SPDX-License-Identifier: Apache-2.0
|
|
4
4
|
*/
|
|
5
5
|
|
|
6
|
+
import { IacProviderOption } from '../../utils/iac';
|
|
7
|
+
|
|
6
8
|
type EventSource =
|
|
7
9
|
| 'Any'
|
|
8
10
|
| 'AlbModel'
|
|
@@ -50,4 +52,5 @@ export interface PyLambdaFunctionGeneratorSchema {
|
|
|
50
52
|
readonly functionName: string;
|
|
51
53
|
readonly functionPath?: string;
|
|
52
54
|
readonly eventSource?: EventSource;
|
|
55
|
+
readonly iacProvider: IacProviderOption;
|
|
53
56
|
}
|
|
@@ -74,6 +74,14 @@
|
|
|
74
74
|
],
|
|
75
75
|
"default": "Any",
|
|
76
76
|
"x-prompt": "Enter the event source model to use for the lambda function"
|
|
77
|
+
},
|
|
78
|
+
"iacProvider": {
|
|
79
|
+
"type": "string",
|
|
80
|
+
"description": "The preferred IaC provider. By default this is inherited from your initial selection.",
|
|
81
|
+
"enum": ["Inherit", "CDK", "Terraform"],
|
|
82
|
+
"x-priority": "important",
|
|
83
|
+
"default": "Inherit",
|
|
84
|
+
"x-prompt": "Which provider would you like to manage your infrastructure? (default: Inherit)"
|
|
77
85
|
}
|
|
78
86
|
},
|
|
79
87
|
"required": ["project", "functionName"]
|
|
@@ -19,6 +19,7 @@ const bundle_1 = require("../../utils/bundle");
|
|
|
19
19
|
const versions_1 = require("../../utils/versions");
|
|
20
20
|
const logger_1 = require("@nxlv/python/src/executors/utils/logger");
|
|
21
21
|
const provider_1 = require("@nxlv/python/src/provider/uv/provider");
|
|
22
|
+
const iac_1 = require("../../utils/iac");
|
|
22
23
|
exports.PY_MCP_SERVER_GENERATOR_INFO = (0, nx_1.getGeneratorInfo)(__filename);
|
|
23
24
|
const pyMcpServerGenerator = (tree, options) => tslib_1.__awaiter(void 0, void 0, void 0, function* () {
|
|
24
25
|
var _a, _b, _c, _d, _e, _f, _g;
|
|
@@ -81,14 +82,15 @@ const pyMcpServerGenerator = (tree, options) => tslib_1.__awaiter(void 0, void 0
|
|
|
81
82
|
'docker',
|
|
82
83
|
] });
|
|
83
84
|
// Add shared constructs
|
|
84
|
-
yield (0,
|
|
85
|
+
const iacProvider = yield (0, iac_1.resolveIacProvider)(tree, options.iacProvider);
|
|
86
|
+
yield (0, shared_constructs_1.sharedConstructsGenerator)(tree, { iacProvider });
|
|
85
87
|
// Add the construct to deploy the mcp server
|
|
86
88
|
(0, agent_core_constructs_1.addMcpServerInfra)(tree, {
|
|
87
89
|
mcpServerNameKebabCase: name,
|
|
88
90
|
mcpServerNameClassName,
|
|
89
91
|
projectName: project.name,
|
|
90
92
|
dockerImageTag,
|
|
91
|
-
iacProvider
|
|
93
|
+
iacProvider,
|
|
92
94
|
});
|
|
93
95
|
}
|
|
94
96
|
else {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generator.js","sourceRoot":"","sources":["../../../../../../packages/nx-plugin/src/py/mcp-server/generator.ts"],"names":[],"mappings":";;;;AAAA;;;GAGG;AACH,uCASoB;AAEpB,uCAIwB;AACxB,iDAAsE;AACtE,+CAA0D;AAC1D,6CAAwE;AACxE,uCAAgE;AAChE,qDAAoD;AACpD,mGAA4F;AAC5F,qEAA0E;AAC1E,+CAA2D;AAC3D,mDAAoD;AACpD,oEAAiE;AACjE,oEAAmE;
|
|
1
|
+
{"version":3,"file":"generator.js","sourceRoot":"","sources":["../../../../../../packages/nx-plugin/src/py/mcp-server/generator.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,6 +2,9 @@
|
|
|
2
2
|
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
3
3
|
* SPDX-License-Identifier: Apache-2.0
|
|
4
4
|
*/
|
|
5
|
+
|
|
6
|
+
import { IacProviderOption } from '../../utils/iac';
|
|
7
|
+
|
|
5
8
|
export type PyMcpServerComputeType = 'None' | 'BedrockAgentCoreRuntime';
|
|
6
9
|
|
|
7
10
|
/**
|
|
@@ -12,5 +15,5 @@ export interface PyMcpServerGeneratorSchema {
|
|
|
12
15
|
project: string;
|
|
13
16
|
name?: string;
|
|
14
17
|
computeType?: PyMcpServerComputeType;
|
|
15
|
-
iacProvider:
|
|
18
|
+
iacProvider: IacProviderOption;
|
|
16
19
|
}
|
|
@@ -30,11 +30,11 @@
|
|
|
30
30
|
},
|
|
31
31
|
"iacProvider": {
|
|
32
32
|
"type": "string",
|
|
33
|
-
"description": "The preferred IaC provider",
|
|
34
|
-
"enum": ["CDK", "Terraform"],
|
|
33
|
+
"description": "The preferred IaC provider. By default this is inherited from your initial selection.",
|
|
34
|
+
"enum": ["Inherit", "CDK", "Terraform"],
|
|
35
35
|
"x-priority": "important",
|
|
36
|
-
"default": "
|
|
37
|
-
"x-prompt": "Which provider would you like to manage your infrastructure? (default:
|
|
36
|
+
"default": "Inherit",
|
|
37
|
+
"x-prompt": "Which provider would you like to manage your infrastructure? (default: Inherit)"
|
|
38
38
|
}
|
|
39
39
|
},
|
|
40
40
|
"required": ["project"]
|
|
@@ -18,6 +18,7 @@ const npm_scope_1 = require("../../utils/npm-scope");
|
|
|
18
18
|
const shared_constructs_1 = require("../../utils/shared-constructs");
|
|
19
19
|
const logger_1 = require("@nxlv/python/src/executors/utils/logger");
|
|
20
20
|
const provider_1 = require("@nxlv/python/src/provider/uv/provider");
|
|
21
|
+
const iac_1 = require("../../utils/iac");
|
|
21
22
|
exports.PY_STRANDS_AGENT_GENERATOR_INFO = (0, nx_1.getGeneratorInfo)(__filename);
|
|
22
23
|
const pyStrandsAgentGenerator = (tree, options) => tslib_1.__awaiter(void 0, void 0, void 0, function* () {
|
|
23
24
|
var _a, _b, _c, _d, _e, _f, _g;
|
|
@@ -83,13 +84,14 @@ const pyStrandsAgentGenerator = (tree, options) => tslib_1.__awaiter(void 0, voi
|
|
|
83
84
|
'docker',
|
|
84
85
|
] });
|
|
85
86
|
// Add shared constructs
|
|
86
|
-
yield (0,
|
|
87
|
+
const iacProvider = yield (0, iac_1.resolveIacProvider)(tree, options.iacProvider);
|
|
88
|
+
yield (0, shared_constructs_1.sharedConstructsGenerator)(tree, { iacProvider });
|
|
87
89
|
// Add the construct to deploy the agent
|
|
88
90
|
(0, agent_core_constructs_1.addAgentInfra)(tree, {
|
|
89
91
|
agentNameKebabCase: name,
|
|
90
92
|
agentNameClassName,
|
|
91
93
|
dockerImageTag,
|
|
92
|
-
iacProvider
|
|
94
|
+
iacProvider,
|
|
93
95
|
projectName: project.name,
|
|
94
96
|
});
|
|
95
97
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generator.js","sourceRoot":"","sources":["../../../../../../packages/nx-plugin/src/py/strands-agent/generator.ts"],"names":[],"mappings":";;;;AAAA;;;GAGG;AACH,uCAQoB;AAEpB,uCAIwB;AACxB,iDAAsE;AACtE,+CAA0D;AAC1D,6CAAwE;AACxE,uCAAgE;AAChE,mGAAwF;AACxF,+CAA2D;AAC3D,qDAAoD;AACpD,qEAA0E;AAC1E,oEAAiE;AACjE,oEAAmE;
|
|
1
|
+
{"version":3,"file":"generator.js","sourceRoot":"","sources":["../../../../../../packages/nx-plugin/src/py/strands-agent/generator.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,11 +3,13 @@
|
|
|
3
3
|
* SPDX-License-Identifier: Apache-2.0
|
|
4
4
|
*/
|
|
5
5
|
|
|
6
|
+
import { IacProviderOption } from '../../utils/iac';
|
|
7
|
+
|
|
6
8
|
export type PyStrandsAgentComputeType = 'BedrockAgentCoreRuntime' | 'None';
|
|
7
9
|
|
|
8
10
|
export interface PyStrandsAgentGeneratorSchema {
|
|
9
11
|
project: string;
|
|
10
12
|
name?: string;
|
|
11
13
|
computeType?: PyStrandsAgentComputeType;
|
|
12
|
-
iacProvider:
|
|
14
|
+
iacProvider: IacProviderOption;
|
|
13
15
|
}
|
|
@@ -30,11 +30,11 @@
|
|
|
30
30
|
},
|
|
31
31
|
"iacProvider": {
|
|
32
32
|
"type": "string",
|
|
33
|
-
"description": "The preferred IaC provider",
|
|
34
|
-
"enum": ["CDK", "Terraform"],
|
|
33
|
+
"description": "The preferred IaC provider. By default this is inherited from your initial selection.",
|
|
34
|
+
"enum": ["Inherit", "CDK", "Terraform"],
|
|
35
35
|
"x-priority": "important",
|
|
36
|
-
"default": "
|
|
37
|
-
"x-prompt": "Which provider would you like to manage your infrastructure? (default:
|
|
36
|
+
"default": "Inherit",
|
|
37
|
+
"x-prompt": "Which provider would you like to manage your infrastructure? (default: Inherit)"
|
|
38
38
|
}
|
|
39
39
|
},
|
|
40
40
|
"required": ["project"]
|
|
@@ -18,6 +18,7 @@ const metrics_1 = require("../../utils/metrics");
|
|
|
18
18
|
const shared_constructs_1 = require("../../utils/shared-constructs");
|
|
19
19
|
const py_1 = require("../../utils/py");
|
|
20
20
|
const shared_constructs_constants_1 = require("../../utils/shared-constructs-constants");
|
|
21
|
+
const names_1 = require("../../utils/names");
|
|
21
22
|
const NX_EXTEND_PLUGIN = '@nx-extend/terraform';
|
|
22
23
|
exports.TERRAFORM_PROJECT_GENERATOR_INFO = (0, nx_1.getGeneratorInfo)(__filename);
|
|
23
24
|
function terraformProjectGenerator(tree, schema) {
|
|
@@ -94,7 +95,7 @@ function terraformProjectGenerator(tree, schema) {
|
|
|
94
95
|
defaultConfiguration: 'dev',
|
|
95
96
|
configurations: {
|
|
96
97
|
dev: {
|
|
97
|
-
command:
|
|
98
|
+
command: `terraform init -reconfigure -backend-config="region=$(aws configure get region)" -backend-config="bucket=$(aws sts get-caller-identity --query Account --output text)-tf-state-$(aws configure get region)" -backend-config="key=${(0, names_1.kebabCase)(lib.fullyQualifiedName)}/dev/terraform.tfstate"`,
|
|
98
99
|
},
|
|
99
100
|
},
|
|
100
101
|
options: {
|