sst 3.0.0 → 3.0.1-1
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 +7 -139
- package/src/index.ts +1 -0
- package/src/resource.ts +15 -0
- package/tsconfig.json +11 -0
- package/LICENSE +0 -21
- package/README.md +0 -43
- package/bootstrap.d.ts +0 -5
- package/bootstrap.js +0 -318
- package/bus.d.ts +0 -20
- package/bus.js +0 -52
- package/cache.d.ts +0 -4
- package/cache.js +0 -31
- package/cdk/deploy-stack.d.ts +0 -223
- package/cdk/deploy-stack.js +0 -562
- package/cdk/deployments-wrapper.d.ts +0 -3
- package/cdk/deployments-wrapper.js +0 -135
- package/cdk/deployments.d.ts +0 -327
- package/cdk/deployments.js +0 -360
- package/cdk/util.d.ts +0 -1
- package/cdk/util.js +0 -17
- package/cli/ci-info.d.ts +0 -4
- package/cli/ci-info.js +0 -8
- package/cli/colors.d.ts +0 -17
- package/cli/colors.js +0 -27
- package/cli/commands/bind.d.ts +0 -19
- package/cli/commands/bind.js +0 -360
- package/cli/commands/bootstrap.d.ts +0 -15
- package/cli/commands/bootstrap.js +0 -11
- package/cli/commands/build.d.ts +0 -17
- package/cli/commands/build.js +0 -25
- package/cli/commands/connect.d.ts +0 -17
- package/cli/commands/connect.js +0 -55
- package/cli/commands/console.d.ts +0 -15
- package/cli/commands/console.js +0 -22
- package/cli/commands/deploy.d.ts +0 -19
- package/cli/commands/deploy.js +0 -112
- package/cli/commands/dev.d.ts +0 -25
- package/cli/commands/dev.js +0 -351
- package/cli/commands/diff.d.ts +0 -19
- package/cli/commands/diff.js +0 -89
- package/cli/commands/plugins/kysely.d.ts +0 -1
- package/cli/commands/plugins/kysely.js +0 -87
- package/cli/commands/plugins/pothos.d.ts +0 -1
- package/cli/commands/plugins/pothos.js +0 -58
- package/cli/commands/plugins/warmer.d.ts +0 -1
- package/cli/commands/plugins/warmer.js +0 -33
- package/cli/commands/remove.d.ts +0 -19
- package/cli/commands/remove.js +0 -62
- package/cli/commands/secrets/get.d.ts +0 -19
- package/cli/commands/secrets/get.js +0 -27
- package/cli/commands/secrets/list.d.ts +0 -19
- package/cli/commands/secrets/list.js +0 -69
- package/cli/commands/secrets/load.d.ts +0 -17
- package/cli/commands/secrets/load.js +0 -47
- package/cli/commands/secrets/remove.d.ts +0 -19
- package/cli/commands/secrets/remove.js +0 -27
- package/cli/commands/secrets/secrets.d.ts +0 -2
- package/cli/commands/secrets/secrets.js +0 -16
- package/cli/commands/secrets/set.d.ts +0 -21
- package/cli/commands/secrets/set.js +0 -54
- package/cli/commands/telemetry.d.ts +0 -17
- package/cli/commands/telemetry.js +0 -24
- package/cli/commands/transform.d.ts +0 -17
- package/cli/commands/transform.js +0 -62
- package/cli/commands/types.d.ts +0 -15
- package/cli/commands/types.js +0 -25
- package/cli/commands/update.d.ts +0 -17
- package/cli/commands/update.js +0 -116
- package/cli/commands/version.d.ts +0 -15
- package/cli/commands/version.js +0 -15
- package/cli/local/router.d.ts +0 -44
- package/cli/local/router.js +0 -43
- package/cli/local/server.d.ts +0 -22
- package/cli/local/server.js +0 -319
- package/cli/program.d.ts +0 -19
- package/cli/program.js +0 -87
- package/cli/spinner.d.ts +0 -3
- package/cli/spinner.js +0 -14
- package/cli/sst.d.ts +0 -2
- package/cli/sst.js +0 -74
- package/cli/telemetry/environment.d.ts +0 -15
- package/cli/telemetry/environment.js +0 -27
- package/cli/telemetry/post-payload.d.ts +0 -1
- package/cli/telemetry/post-payload.js +0 -27
- package/cli/telemetry/project-id.d.ts +0 -2
- package/cli/telemetry/project-id.js +0 -47
- package/cli/telemetry/telemetry.d.ts +0 -19
- package/cli/telemetry/telemetry.js +0 -103
- package/cli/terminal.d.ts +0 -1
- package/cli/terminal.js +0 -8
- package/cli/ui/deploy.d.ts +0 -10
- package/cli/ui/deploy.js +0 -172
- package/cli/ui/functions.d.ts +0 -2
- package/cli/ui/functions.js +0 -130
- package/cli/ui/header.d.ts +0 -5
- package/cli/ui/header.js +0 -16
- package/cli/ui/stack.d.ts +0 -1
- package/cli/ui/stack.js +0 -6
- package/config.d.ts +0 -56
- package/config.js +0 -244
- package/constructs/Api.d.ts +0 -814
- package/constructs/Api.js +0 -743
- package/constructs/ApiGatewayV1Api.d.ts +0 -642
- package/constructs/ApiGatewayV1Api.js +0 -767
- package/constructs/App.d.ts +0 -168
- package/constructs/App.js +0 -493
- package/constructs/AppSyncApi.d.ts +0 -550
- package/constructs/AppSyncApi.js +0 -493
- package/constructs/AstroSite.d.ts +0 -39
- package/constructs/AstroSite.js +0 -78
- package/constructs/AstroSite.tsdoc.d.ts +0 -2
- package/constructs/AstroSite.tsdoc.js +0 -2
- package/constructs/Auth.d.ts +0 -100
- package/constructs/Auth.js +0 -177
- package/constructs/BaseSite.d.ts +0 -29
- package/constructs/BaseSite.js +0 -43
- package/constructs/Bucket.d.ts +0 -364
- package/constructs/Bucket.js +0 -327
- package/constructs/Cognito.d.ts +0 -232
- package/constructs/Cognito.js +0 -370
- package/constructs/Config.d.ts +0 -3
- package/constructs/Config.js +0 -3
- package/constructs/Construct.d.ts +0 -23
- package/constructs/Construct.js +0 -46
- package/constructs/Cron.d.ts +0 -164
- package/constructs/Cron.js +0 -114
- package/constructs/Distribution.d.ts +0 -143
- package/constructs/Distribution.js +0 -260
- package/constructs/EdgeFunction.d.ts +0 -49
- package/constructs/EdgeFunction.js +0 -442
- package/constructs/EventBus.d.ts +0 -444
- package/constructs/EventBus.js +0 -440
- package/constructs/Function.d.ts +0 -690
- package/constructs/Function.js +0 -583
- package/constructs/FunctionalStack.d.ts +0 -13
- package/constructs/FunctionalStack.js +0 -62
- package/constructs/Job.d.ts +0 -337
- package/constructs/Job.js +0 -404
- package/constructs/KinesisStream.d.ts +0 -224
- package/constructs/KinesisStream.js +0 -207
- package/constructs/Metadata.d.ts +0 -60
- package/constructs/Metadata.js +0 -1
- package/constructs/NextjsSite.d.ts +0 -104
- package/constructs/NextjsSite.js +0 -308
- package/constructs/Parameter.d.ts +0 -37
- package/constructs/Parameter.js +0 -53
- package/constructs/Queue.d.ts +0 -194
- package/constructs/Queue.js +0 -204
- package/constructs/RDS.d.ts +0 -221
- package/constructs/RDS.js +0 -363
- package/constructs/RemixSite.d.ts +0 -42
- package/constructs/RemixSite.js +0 -158
- package/constructs/RemixSite.tsdoc.d.ts +0 -2
- package/constructs/RemixSite.tsdoc.js +0 -2
- package/constructs/Script.d.ts +0 -160
- package/constructs/Script.js +0 -179
- package/constructs/Secret.d.ts +0 -30
- package/constructs/Secret.js +0 -59
- package/constructs/Service.d.ts +0 -487
- package/constructs/Service.js +0 -655
- package/constructs/SolidStartSite.d.ts +0 -37
- package/constructs/SolidStartSite.js +0 -66
- package/constructs/SolidStartSite.tsdoc.d.ts +0 -2
- package/constructs/SolidStartSite.tsdoc.js +0 -2
- package/constructs/SsrFunction.d.ts +0 -60
- package/constructs/SsrFunction.js +0 -226
- package/constructs/SsrSite.d.ts +0 -407
- package/constructs/SsrSite.js +0 -850
- package/constructs/Stack.d.ts +0 -127
- package/constructs/Stack.js +0 -243
- package/constructs/StaticSite.d.ts +0 -348
- package/constructs/StaticSite.js +0 -468
- package/constructs/SvelteKitSite.d.ts +0 -40
- package/constructs/SvelteKitSite.js +0 -106
- package/constructs/SvelteKitSite.tsdoc.d.ts +0 -2
- package/constructs/SvelteKitSite.tsdoc.js +0 -2
- package/constructs/Table.d.ts +0 -410
- package/constructs/Table.js +0 -425
- package/constructs/Topic.d.ts +0 -257
- package/constructs/Topic.js +0 -273
- package/constructs/WebSocketApi.d.ts +0 -355
- package/constructs/WebSocketApi.js +0 -404
- package/constructs/cdk/HttpAwsIntegration.d.ts +0 -32
- package/constructs/cdk/HttpAwsIntegration.js +0 -24
- package/constructs/cdk/certificate-base.d.ts +0 -18
- package/constructs/cdk/certificate-base.js +0 -26
- package/constructs/cdk/dns-validated-certificate.d.ts +0 -77
- package/constructs/cdk/dns-validated-certificate.js +0 -125
- package/constructs/cdk/website-redirect.d.ts +0 -53
- package/constructs/cdk/website-redirect.js +0 -77
- package/constructs/context.d.ts +0 -3
- package/constructs/context.js +0 -27
- package/constructs/deferred_task.d.ts +0 -6
- package/constructs/deferred_task.js +0 -45
- package/constructs/deprecated/NextjsSite.d.ts +0 -309
- package/constructs/deprecated/NextjsSite.js +0 -1074
- package/constructs/deprecated/cross-region-helper.d.ts +0 -7
- package/constructs/deprecated/cross-region-helper.js +0 -152
- package/constructs/deprecated/index.d.ts +0 -1
- package/constructs/deprecated/index.js +0 -1
- package/constructs/future/Auth.d.ts +0 -80
- package/constructs/future/Auth.js +0 -122
- package/constructs/future/index.d.ts +0 -1
- package/constructs/future/index.js +0 -1
- package/constructs/index.d.ts +0 -32
- package/constructs/index.js +0 -32
- package/constructs/static-file-list.d.ts +0 -1
- package/constructs/static-file-list.js +0 -51
- package/constructs/util/apiGatewayV1AccessLog.d.ts +0 -15
- package/constructs/util/apiGatewayV1AccessLog.js +0 -76
- package/constructs/util/apiGatewayV2AccessLog.d.ts +0 -10
- package/constructs/util/apiGatewayV2AccessLog.js +0 -107
- package/constructs/util/apiGatewayV2Cors.d.ts +0 -67
- package/constructs/util/apiGatewayV2Cors.js +0 -21
- package/constructs/util/apiGatewayV2Domain.d.ts +0 -47
- package/constructs/util/apiGatewayV2Domain.js +0 -208
- package/constructs/util/appSyncApiDomain.d.ts +0 -41
- package/constructs/util/appSyncApiDomain.js +0 -176
- package/constructs/util/builder.d.ts +0 -3
- package/constructs/util/builder.js +0 -9
- package/constructs/util/duration.d.ts +0 -3
- package/constructs/util/duration.js +0 -19
- package/constructs/util/functionBinding.d.ts +0 -31
- package/constructs/util/functionBinding.js +0 -104
- package/constructs/util/functionUrlCors.d.ts +0 -67
- package/constructs/util/functionUrlCors.js +0 -23
- package/constructs/util/permission.d.ts +0 -8
- package/constructs/util/permission.js +0 -228
- package/constructs/util/size.d.ts +0 -3
- package/constructs/util/size.js +0 -12
- package/constructs/util/warning.d.ts +0 -11
- package/constructs/util/warning.js +0 -21
- package/context/context.d.ts +0 -13
- package/context/context.js +0 -69
- package/context/context2.d.ts +0 -16
- package/context/context2.js +0 -108
- package/context/handler.d.ts +0 -25
- package/context/handler.js +0 -21
- package/context/index.d.ts +0 -2
- package/context/index.js +0 -2
- package/credentials.d.ts +0 -9
- package/credentials.js +0 -145
- package/error.d.ts +0 -6
- package/error.js +0 -10
- package/index.d.ts +0 -1
- package/index.js +0 -1
- package/iot.d.ts +0 -6
- package/iot.js +0 -163
- package/logger.d.ts +0 -3
- package/logger.js +0 -32
- package/node/actor/index.d.ts +0 -29
- package/node/actor/index.js +0 -17
- package/node/api/index.d.ts +0 -64
- package/node/api/index.js +0 -179
- package/node/auth/adapter/adapter.d.ts +0 -3
- package/node/auth/adapter/adapter.js +0 -3
- package/node/auth/adapter/facebook.d.ts +0 -2
- package/node/auth/adapter/facebook.js +0 -26
- package/node/auth/adapter/github.d.ts +0 -2
- package/node/auth/adapter/github.js +0 -21
- package/node/auth/adapter/google.d.ts +0 -9
- package/node/auth/adapter/google.js +0 -18
- package/node/auth/adapter/link.d.ts +0 -8
- package/node/auth/adapter/link.js +0 -39
- package/node/auth/adapter/oauth.d.ts +0 -25
- package/node/auth/adapter/oauth.js +0 -52
- package/node/auth/adapter/oidc.d.ts +0 -17
- package/node/auth/adapter/oidc.js +0 -50
- package/node/auth/adapter/twitch.d.ts +0 -2
- package/node/auth/adapter/twitch.js +0 -11
- package/node/auth/auth.d.ts +0 -24
- package/node/auth/auth.js +0 -74
- package/node/auth/index.d.ts +0 -13
- package/node/auth/index.js +0 -12
- package/node/auth/session.d.ts +0 -76
- package/node/auth/session.js +0 -121
- package/node/bucket/index.d.ts +0 -3
- package/node/bucket/index.js +0 -2
- package/node/config/index.d.ts +0 -13
- package/node/config/index.js +0 -22
- package/node/event-bus/index.d.ts +0 -51
- package/node/event-bus/index.js +0 -76
- package/node/function/index.d.ts +0 -3
- package/node/function/index.js +0 -3
- package/node/future/auth/adapter/adapter.d.ts +0 -10
- package/node/future/auth/adapter/adapter.js +0 -1
- package/node/future/auth/adapter/code.d.ts +0 -17
- package/node/future/auth/adapter/code.js +0 -68
- package/node/future/auth/adapter/facebook.d.ts +0 -16
- package/node/future/auth/adapter/facebook.js +0 -27
- package/node/future/auth/adapter/github.d.ts +0 -23
- package/node/future/auth/adapter/github.js +0 -23
- package/node/future/auth/adapter/google.d.ts +0 -28
- package/node/future/auth/adapter/google.js +0 -22
- package/node/future/auth/adapter/link.d.ts +0 -13
- package/node/future/auth/adapter/link.js +0 -47
- package/node/future/auth/adapter/microsoft.d.ts +0 -22
- package/node/future/auth/adapter/microsoft.js +0 -16
- package/node/future/auth/adapter/oauth.d.ts +0 -41
- package/node/future/auth/adapter/oauth.js +0 -67
- package/node/future/auth/adapter/oidc.d.ts +0 -30
- package/node/future/auth/adapter/oidc.js +0 -63
- package/node/future/auth/adapter/spotify.d.ts +0 -23
- package/node/future/auth/adapter/spotify.js +0 -22
- package/node/future/auth/encryption.d.ts +0 -2
- package/node/future/auth/encryption.js +0 -30
- package/node/future/auth/handler.d.ts +0 -46
- package/node/future/auth/handler.js +0 -280
- package/node/future/auth/index.d.ts +0 -17
- package/node/future/auth/index.js +0 -15
- package/node/future/auth/session.d.ts +0 -71
- package/node/future/auth/session.js +0 -146
- package/node/graphql/index.d.ts +0 -15
- package/node/graphql/index.js +0 -32
- package/node/job/index.d.ts +0 -37
- package/node/job/index.js +0 -64
- package/node/kinesis-stream/index.d.ts +0 -3
- package/node/kinesis-stream/index.js +0 -3
- package/node/queue/index.d.ts +0 -3
- package/node/queue/index.js +0 -2
- package/node/rds/index.d.ts +0 -3
- package/node/rds/index.js +0 -2
- package/node/service/index.d.ts +0 -3
- package/node/service/index.js +0 -4
- package/node/site/index.d.ts +0 -18
- package/node/site/index.js +0 -18
- package/node/table/index.d.ts +0 -3
- package/node/table/index.js +0 -4
- package/node/topic/index.d.ts +0 -3
- package/node/topic/index.js +0 -4
- package/node/util/index.d.ts +0 -2
- package/node/util/index.js +0 -196
- package/node/util/loader.d.ts +0 -2
- package/node/util/loader.js +0 -51
- package/node/websocket-api/index.d.ts +0 -23
- package/node/websocket-api/index.js +0 -48
- package/pothos.d.ts +0 -7
- package/pothos.js +0 -160
- package/project.d.ts +0 -75
- package/project.js +0 -188
- package/runtime/handlers/container.d.ts +0 -2
- package/runtime/handlers/container.js +0 -263
- package/runtime/handlers/dotnet.d.ts +0 -2
- package/runtime/handlers/dotnet.js +0 -115
- package/runtime/handlers/go.d.ts +0 -2
- package/runtime/handlers/go.js +0 -126
- package/runtime/handlers/java.d.ts +0 -2
- package/runtime/handlers/java.js +0 -103
- package/runtime/handlers/node.d.ts +0 -2
- package/runtime/handlers/node.js +0 -269
- package/runtime/handlers/python.d.ts +0 -2
- package/runtime/handlers/python.js +0 -141
- package/runtime/handlers/pythonBundling.d.ts +0 -82
- package/runtime/handlers/pythonBundling.js +0 -80
- package/runtime/handlers/rust.d.ts +0 -2
- package/runtime/handlers/rust.js +0 -110
- package/runtime/handlers.d.ts +0 -74
- package/runtime/handlers.js +0 -151
- package/runtime/iot.d.ts +0 -1
- package/runtime/iot.js +0 -17
- package/runtime/runtime.d.ts +0 -32
- package/runtime/runtime.js +0 -1
- package/runtime/server.d.ts +0 -6
- package/runtime/server.js +0 -150
- package/runtime/workers.d.ts +0 -37
- package/runtime/workers.js +0 -85
- package/stacks/app-metadata.d.ts +0 -7
- package/stacks/app-metadata.js +0 -75
- package/stacks/assembly.d.ts +0 -1
- package/stacks/assembly.js +0 -4
- package/stacks/build.d.ts +0 -9
- package/stacks/build.js +0 -110
- package/stacks/deploy.d.ts +0 -9
- package/stacks/deploy.js +0 -240
- package/stacks/diff.d.ts +0 -8
- package/stacks/diff.js +0 -62
- package/stacks/index.d.ts +0 -10
- package/stacks/index.js +0 -10
- package/stacks/metadata.d.ts +0 -11
- package/stacks/metadata.js +0 -83
- package/stacks/monitor.d.ts +0 -32
- package/stacks/monitor.js +0 -151
- package/stacks/remove.d.ts +0 -8
- package/stacks/remove.js +0 -76
- package/stacks/synth.d.ts +0 -12
- package/stacks/synth.js +0 -94
- package/support/base-site-archiver.mjs +0 -99
- package/support/base-site-custom-resource/s3-handler.py +0 -195
- package/support/base-site-custom-resource/s3-upload.py +0 -89
- package/support/bootstrap-metadata-function/index.mjs +0 -58011
- package/support/bridge/Dockerfile +0 -3
- package/support/bridge/bridge.mjs +0 -146
- package/support/certificate-requestor/index.js +0 -549
- package/support/custom-resources/index.mjs +0 -180627
- package/support/dotnet31-bootstrap/Program.cs +0 -17
- package/support/dotnet31-bootstrap/dotnet-bootstrap.csproj +0 -12
- package/support/dotnet31-bootstrap/release/Amazon.Lambda.Core.dll +0 -0
- package/support/dotnet31-bootstrap/release/Amazon.Lambda.RuntimeSupport.dll +0 -0
- package/support/dotnet31-bootstrap/release/System.Runtime.CompilerServices.Unsafe.dll +0 -0
- package/support/dotnet31-bootstrap/release/System.Text.Encodings.Web.dll +0 -0
- package/support/dotnet31-bootstrap/release/System.Text.Json.dll +0 -0
- package/support/dotnet31-bootstrap/release/dotnet-bootstrap +0 -0
- package/support/dotnet31-bootstrap/release/dotnet-bootstrap.deps.json +0 -230
- package/support/dotnet31-bootstrap/release/dotnet-bootstrap.dll +0 -0
- package/support/dotnet31-bootstrap/release/dotnet-bootstrap.pdb +0 -0
- package/support/dotnet31-bootstrap/release/dotnet-bootstrap.runtimeconfig.json +0 -9
- package/support/dotnet6-bootstrap/Program.cs +0 -17
- package/support/dotnet6-bootstrap/dotnet-bootstrap.csproj +0 -12
- package/support/dotnet6-bootstrap/release/Amazon.Lambda.Core.dll +0 -0
- package/support/dotnet6-bootstrap/release/Amazon.Lambda.RuntimeSupport.dll +0 -0
- package/support/dotnet6-bootstrap/release/dotnet-bootstrap +0 -0
- package/support/dotnet6-bootstrap/release/dotnet-bootstrap.deps.json +0 -59
- package/support/dotnet6-bootstrap/release/dotnet-bootstrap.dll +0 -0
- package/support/dotnet6-bootstrap/release/dotnet-bootstrap.pdb +0 -0
- package/support/dotnet6-bootstrap/release/dotnet-bootstrap.runtimeconfig.json +0 -12
- package/support/edge-function/edge-lambda-version.mjs +0 -3
- package/support/edge-function/edge-lambda.mjs +0 -3
- package/support/edge-function/s3-bucket.mjs +0 -3
- package/support/event-bus-retrier/index.mjs +0 -75
- package/support/java-runtime/install.sh +0 -25
- package/support/java-runtime/pom.xml +0 -39
- package/support/java-runtime/release/aws-lambda-java-core-1.2.0.jar +0 -0
- package/support/java-runtime/release/aws-lambda-java-runtime-interface-client-1.1.0.jar +0 -0
- package/support/java-runtime/release/aws-lambda-java-serialization-1.0.0.jar +0 -0
- package/support/job-manager/index.mjs +0 -57679
- package/support/nixpacks/Dockerfile +0 -6
- package/support/nodejs-runtime/index.mjs +0 -169
- package/support/python-runtime/Dockerfile +0 -9
- package/support/python-runtime/Dockerfile.custom +0 -21
- package/support/python-runtime/Dockerfile.dependencies +0 -26
- package/support/python-runtime/runtime.py +0 -127
- package/support/rds-migrator/index.mjs +0 -49
- package/support/remix-site-function/edge-server.js +0 -161
- package/support/remix-site-function/polyfill.js +0 -24
- package/support/remix-site-function/regional-server.js +0 -164
- package/support/script-function/index.mjs +0 -48760
- package/support/service-dev-function/index.js +0 -1
- package/support/signing-function/index.mjs +0 -3769
- package/support/sls-nextjs-site-build-helper/build.cjs +0 -91
- package/support/sls-nextjs-site-build-helper/index-wrapper.js +0 -19
- package/support/sls-nextjs-site-function-code-replacer/lambda-code-updater.py +0 -156
- package/support/sls-nextjs-site-stub/index.html +0 -99
- package/support/ssr-site-function-archiver.mjs +0 -96
- package/support/ssr-site-function-stub/index.js +0 -5
- package/support/ssr-warmer/index.mjs +0 -34235
- package/util/error.d.ts +0 -3
- package/util/error.js +0 -6
- package/util/fs.d.ts +0 -4
- package/util/fs.js +0 -46
- package/util/lazy.d.ts +0 -1
- package/util/lazy.js +0 -11
- package/util/module.d.ts +0 -1
- package/util/module.js +0 -5
- package/util/process.d.ts +0 -2
- package/util/process.js +0 -3
- package/watcher.d.ts +0 -14
- package/watcher.js +0 -35
package/runtime/handlers/go.js
DELETED
|
@@ -1,126 +0,0 @@
|
|
|
1
|
-
import path from "path";
|
|
2
|
-
import fs from "fs/promises";
|
|
3
|
-
import os from "os";
|
|
4
|
-
import { useRuntimeWorkers } from "../workers.js";
|
|
5
|
-
import { VisibleError } from "../../error.js";
|
|
6
|
-
import { spawn } from "child_process";
|
|
7
|
-
import { useRuntimeServerConfig } from "../server.js";
|
|
8
|
-
import { isChild } from "../../util/fs.js";
|
|
9
|
-
import { execAsync } from "../../util/process.js";
|
|
10
|
-
export const useGoHandler = () => {
|
|
11
|
-
const processes = new Map();
|
|
12
|
-
const sources = new Map();
|
|
13
|
-
const handlerName = process.platform === "win32" ? `bootstrap.exe` : `bootstrap`;
|
|
14
|
-
return {
|
|
15
|
-
shouldBuild: (input) => {
|
|
16
|
-
const parent = sources.get(input.functionID);
|
|
17
|
-
if (!parent)
|
|
18
|
-
return false;
|
|
19
|
-
return isChild(parent, input.file);
|
|
20
|
-
},
|
|
21
|
-
canHandle: (input) => input.startsWith("go"),
|
|
22
|
-
startWorker: async (input) => {
|
|
23
|
-
const workers = await useRuntimeWorkers();
|
|
24
|
-
const server = await useRuntimeServerConfig();
|
|
25
|
-
const proc = spawn(path.join(input.out, handlerName), {
|
|
26
|
-
env: {
|
|
27
|
-
...process.env,
|
|
28
|
-
...input.environment,
|
|
29
|
-
IS_LOCAL: "true",
|
|
30
|
-
AWS_LAMBDA_RUNTIME_API: `localhost:${server.port}/${input.workerID}`,
|
|
31
|
-
},
|
|
32
|
-
cwd: input.out,
|
|
33
|
-
});
|
|
34
|
-
proc.on("exit", () => workers.exited(input.workerID));
|
|
35
|
-
proc.stdout.on("data", (data) => {
|
|
36
|
-
workers.stdout(input.workerID, data.toString());
|
|
37
|
-
});
|
|
38
|
-
proc.stderr.on("data", (data) => {
|
|
39
|
-
workers.stdout(input.workerID, data.toString());
|
|
40
|
-
});
|
|
41
|
-
processes.set(input.workerID, proc);
|
|
42
|
-
},
|
|
43
|
-
stopWorker: async (workerID) => {
|
|
44
|
-
const proc = processes.get(workerID);
|
|
45
|
-
if (proc) {
|
|
46
|
-
proc.kill();
|
|
47
|
-
processes.delete(workerID);
|
|
48
|
-
}
|
|
49
|
-
},
|
|
50
|
-
build: async (input) => {
|
|
51
|
-
const parsed = path.parse(input.props.handler);
|
|
52
|
-
const project = await find(parsed.dir, "go.mod");
|
|
53
|
-
sources.set(input.functionID, project);
|
|
54
|
-
const src = path.relative(project, input.props.handler);
|
|
55
|
-
const ldFlags = input.props.go?.ldFlags || ["-s", "-w"];
|
|
56
|
-
const buildTags = input.props.go?.buildTags || [];
|
|
57
|
-
if (input.mode === "start") {
|
|
58
|
-
try {
|
|
59
|
-
const target = path.join(input.out, handlerName);
|
|
60
|
-
const srcPath = os.platform() === "win32" ? src.replaceAll("\\", "\\\\") : src;
|
|
61
|
-
const result = await execAsync([
|
|
62
|
-
"go",
|
|
63
|
-
"build",
|
|
64
|
-
...(ldFlags.length ? [`-ldflags "${ldFlags.join(" ")}"`] : []),
|
|
65
|
-
...(buildTags.length ? [`-tags ${buildTags.join(" ")}`] : []),
|
|
66
|
-
`-o "${target}"`,
|
|
67
|
-
`./${srcPath}`,
|
|
68
|
-
].join(" "), {
|
|
69
|
-
cwd: project,
|
|
70
|
-
env: {
|
|
71
|
-
...process.env,
|
|
72
|
-
},
|
|
73
|
-
});
|
|
74
|
-
}
|
|
75
|
-
catch (ex) {
|
|
76
|
-
return {
|
|
77
|
-
type: "error",
|
|
78
|
-
errors: [String(ex)],
|
|
79
|
-
};
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
if (input.mode === "deploy") {
|
|
83
|
-
try {
|
|
84
|
-
const target = path.join(input.out, "bootstrap");
|
|
85
|
-
const srcPath = os.platform() === "win32" ? src.replaceAll("\\", "\\\\") : src;
|
|
86
|
-
await execAsync([
|
|
87
|
-
"go",
|
|
88
|
-
"build",
|
|
89
|
-
...(ldFlags.length ? [`-ldflags "${ldFlags.join(" ")}"`] : []),
|
|
90
|
-
...(buildTags.length ? [`-tags ${buildTags.join(" ")}`] : []),
|
|
91
|
-
`-o "${target}"`,
|
|
92
|
-
`./${srcPath}`,
|
|
93
|
-
].join(" "), {
|
|
94
|
-
cwd: project,
|
|
95
|
-
env: {
|
|
96
|
-
...process.env,
|
|
97
|
-
CGO_ENABLED: input.props.go?.cgoEnabled ? "1" : "0",
|
|
98
|
-
GOARCH: input.props.architecture === "arm_64" ? "arm64" : "amd64",
|
|
99
|
-
GOOS: "linux",
|
|
100
|
-
},
|
|
101
|
-
});
|
|
102
|
-
}
|
|
103
|
-
catch (ex) {
|
|
104
|
-
return {
|
|
105
|
-
type: "error",
|
|
106
|
-
errors: [String(ex)],
|
|
107
|
-
};
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
return {
|
|
111
|
-
type: "success",
|
|
112
|
-
handler: "bootstrap",
|
|
113
|
-
};
|
|
114
|
-
},
|
|
115
|
-
};
|
|
116
|
-
};
|
|
117
|
-
async function find(dir, target) {
|
|
118
|
-
if (dir === "/")
|
|
119
|
-
throw new VisibleError(`Could not find a ${target} file`);
|
|
120
|
-
if (await fs
|
|
121
|
-
.access(path.join(dir, target))
|
|
122
|
-
.then(() => true)
|
|
123
|
-
.catch(() => false))
|
|
124
|
-
return dir;
|
|
125
|
-
return find(path.join(dir, ".."), target);
|
|
126
|
-
}
|
package/runtime/handlers/java.js
DELETED
|
@@ -1,103 +0,0 @@
|
|
|
1
|
-
import path from "path";
|
|
2
|
-
import fs from "fs/promises";
|
|
3
|
-
import os from "os";
|
|
4
|
-
import { useRuntimeWorkers } from "../workers.js";
|
|
5
|
-
import { spawn } from "child_process";
|
|
6
|
-
import { useRuntimeServerConfig } from "../server.js";
|
|
7
|
-
import { existsAsync, findBelow, isChild } from "../../util/fs.js";
|
|
8
|
-
import { useProject } from "../../project.js";
|
|
9
|
-
import { execAsync } from "../../util/process.js";
|
|
10
|
-
import url from "url";
|
|
11
|
-
import AdmZip from "adm-zip";
|
|
12
|
-
export const useJavaHandler = () => {
|
|
13
|
-
const processes = new Map();
|
|
14
|
-
const sources = new Map();
|
|
15
|
-
const runningBuilds = new Map();
|
|
16
|
-
return {
|
|
17
|
-
shouldBuild: (input) => {
|
|
18
|
-
if (!input.file.endsWith(".java"))
|
|
19
|
-
return false;
|
|
20
|
-
const parent = sources.get(input.functionID);
|
|
21
|
-
if (!parent)
|
|
22
|
-
return false;
|
|
23
|
-
return isChild(parent, input.file);
|
|
24
|
-
},
|
|
25
|
-
canHandle: (input) => input.startsWith("java"),
|
|
26
|
-
startWorker: async (input) => {
|
|
27
|
-
const workers = await useRuntimeWorkers();
|
|
28
|
-
const server = await useRuntimeServerConfig();
|
|
29
|
-
const proc = spawn(`java`, [
|
|
30
|
-
`-cp`,
|
|
31
|
-
[
|
|
32
|
-
url.fileURLToPath(new URL("../../support/java-runtime/release/*", import.meta.url)),
|
|
33
|
-
].join(os.platform() === "win32" ? ";" : ":"),
|
|
34
|
-
"com.amazonaws.services.lambda.runtime.api.client.AWSLambda",
|
|
35
|
-
input.handler,
|
|
36
|
-
], {
|
|
37
|
-
env: {
|
|
38
|
-
...process.env,
|
|
39
|
-
...input.environment,
|
|
40
|
-
IS_LOCAL: "true",
|
|
41
|
-
AWS_LAMBDA_RUNTIME_API: `localhost:${server.port}/${input.workerID}`,
|
|
42
|
-
},
|
|
43
|
-
cwd: input.out,
|
|
44
|
-
});
|
|
45
|
-
proc.on("exit", () => workers.exited(input.workerID));
|
|
46
|
-
proc.stdout.on("data", (data) => {
|
|
47
|
-
workers.stdout(input.workerID, data.toString());
|
|
48
|
-
});
|
|
49
|
-
proc.stderr.on("data", (data) => {
|
|
50
|
-
workers.stdout(input.workerID, data.toString());
|
|
51
|
-
});
|
|
52
|
-
processes.set(input.workerID, proc);
|
|
53
|
-
},
|
|
54
|
-
stopWorker: async (workerID) => {
|
|
55
|
-
const proc = processes.get(workerID);
|
|
56
|
-
if (proc) {
|
|
57
|
-
proc.kill();
|
|
58
|
-
processes.delete(workerID);
|
|
59
|
-
}
|
|
60
|
-
},
|
|
61
|
-
build: async (input) => {
|
|
62
|
-
const project = useProject();
|
|
63
|
-
const srcPath = await findBelow(project.paths.root, "build.gradle");
|
|
64
|
-
const buildBinary = await getGradleBinary(srcPath);
|
|
65
|
-
const buildTask = input.props.java?.buildTask || "build";
|
|
66
|
-
const outputDir = input.props.java?.buildOutputDir || "distributions";
|
|
67
|
-
sources.set(input.functionID, srcPath);
|
|
68
|
-
try {
|
|
69
|
-
// Build
|
|
70
|
-
// Note: run gradle build once per directory. Otherwise they'll interfere
|
|
71
|
-
// with one another
|
|
72
|
-
const buildPromise = runningBuilds.get(buildBinary) ??
|
|
73
|
-
execAsync(`${buildBinary} ${buildTask} -Dorg.gradle.logging.level=${process.env.DEBUG ? "debug" : "lifecycle"}`, {
|
|
74
|
-
cwd: srcPath,
|
|
75
|
-
});
|
|
76
|
-
runningBuilds.set(buildBinary, buildPromise);
|
|
77
|
-
await buildPromise;
|
|
78
|
-
runningBuilds.delete(buildBinary);
|
|
79
|
-
// unzip
|
|
80
|
-
const buildOutput = path.join(srcPath, "build", outputDir);
|
|
81
|
-
const zip = (await fs.readdir(buildOutput)).find((f) => f.endsWith(".zip"));
|
|
82
|
-
const zipper = new AdmZip(path.join(buildOutput, zip));
|
|
83
|
-
zipper.extractAllTo(input.out, false, false);
|
|
84
|
-
return {
|
|
85
|
-
type: "success",
|
|
86
|
-
handler: input.props.handler,
|
|
87
|
-
};
|
|
88
|
-
}
|
|
89
|
-
catch (ex) {
|
|
90
|
-
return {
|
|
91
|
-
type: "error",
|
|
92
|
-
errors: [ex.stderr],
|
|
93
|
-
};
|
|
94
|
-
}
|
|
95
|
-
},
|
|
96
|
-
};
|
|
97
|
-
};
|
|
98
|
-
async function getGradleBinary(srcPath) {
|
|
99
|
-
// Use a gradle wrapper if provided in the folder, otherwise fall back
|
|
100
|
-
// to system "gradle"
|
|
101
|
-
const gradleWrapperPath = path.resolve(path.join(srcPath, "gradlew"));
|
|
102
|
-
return (await existsAsync(gradleWrapperPath)) ? gradleWrapperPath : "gradle";
|
|
103
|
-
}
|
package/runtime/handlers/node.js
DELETED
|
@@ -1,269 +0,0 @@
|
|
|
1
|
-
import os from "os";
|
|
2
|
-
import path from "path";
|
|
3
|
-
import fs from "fs/promises";
|
|
4
|
-
import { exec } from "child_process";
|
|
5
|
-
import fsSync from "fs";
|
|
6
|
-
import { useProject } from "../../project.js";
|
|
7
|
-
import esbuild from "esbuild";
|
|
8
|
-
import url from "url";
|
|
9
|
-
import { Worker } from "worker_threads";
|
|
10
|
-
import { useRuntimeWorkers } from "../workers.js";
|
|
11
|
-
import { Colors } from "../../cli/colors.js";
|
|
12
|
-
import { Logger } from "../../logger.js";
|
|
13
|
-
import { findAbove } from "../../util/fs.js";
|
|
14
|
-
export const useNodeHandler = () => {
|
|
15
|
-
const rebuildCache = {};
|
|
16
|
-
process.on("exit", () => {
|
|
17
|
-
for (const { ctx } of Object.values(rebuildCache)) {
|
|
18
|
-
ctx.dispose();
|
|
19
|
-
}
|
|
20
|
-
});
|
|
21
|
-
const project = useProject();
|
|
22
|
-
const threads = new Map();
|
|
23
|
-
return {
|
|
24
|
-
shouldBuild: (input) => {
|
|
25
|
-
const cache = rebuildCache[input.functionID];
|
|
26
|
-
if (!cache)
|
|
27
|
-
return false;
|
|
28
|
-
const relative = path
|
|
29
|
-
.relative(project.paths.root, input.file)
|
|
30
|
-
.split(path.sep)
|
|
31
|
-
.join(path.posix.sep);
|
|
32
|
-
return Boolean(cache.result.metafile?.inputs[relative]);
|
|
33
|
-
},
|
|
34
|
-
canHandle: (input) => input.startsWith("nodejs"),
|
|
35
|
-
startWorker: async (input) => {
|
|
36
|
-
const workers = await useRuntimeWorkers();
|
|
37
|
-
new Promise(async () => {
|
|
38
|
-
const worker = new Worker(url.fileURLToPath(new URL("../../support/nodejs-runtime/index.mjs", import.meta.url)), {
|
|
39
|
-
env: {
|
|
40
|
-
...input.environment,
|
|
41
|
-
IS_LOCAL: "true",
|
|
42
|
-
},
|
|
43
|
-
execArgv: ["--enable-source-maps"],
|
|
44
|
-
workerData: input,
|
|
45
|
-
stderr: true,
|
|
46
|
-
stdin: true,
|
|
47
|
-
stdout: true,
|
|
48
|
-
});
|
|
49
|
-
worker.stdout.on("data", (data) => {
|
|
50
|
-
workers.stdout(input.workerID, data.toString());
|
|
51
|
-
});
|
|
52
|
-
worker.stderr.on("data", (data) => {
|
|
53
|
-
workers.stdout(input.workerID, data.toString());
|
|
54
|
-
});
|
|
55
|
-
worker.on("exit", () => workers.exited(input.workerID));
|
|
56
|
-
threads.set(input.workerID, worker);
|
|
57
|
-
});
|
|
58
|
-
},
|
|
59
|
-
stopWorker: async (workerID) => {
|
|
60
|
-
const worker = threads.get(workerID);
|
|
61
|
-
await worker?.terminate();
|
|
62
|
-
},
|
|
63
|
-
build: async (input) => {
|
|
64
|
-
const parsed = path.parse(input.props.handler);
|
|
65
|
-
const file = [
|
|
66
|
-
".ts",
|
|
67
|
-
".tsx",
|
|
68
|
-
".mts",
|
|
69
|
-
".cts",
|
|
70
|
-
".js",
|
|
71
|
-
".jsx",
|
|
72
|
-
".mjs",
|
|
73
|
-
".cjs",
|
|
74
|
-
]
|
|
75
|
-
.map((ext) => path.join(parsed.dir, parsed.name + ext))
|
|
76
|
-
.find((file) => {
|
|
77
|
-
return fsSync.existsSync(file);
|
|
78
|
-
});
|
|
79
|
-
if (!file)
|
|
80
|
-
return {
|
|
81
|
-
type: "error",
|
|
82
|
-
errors: [`Could not find file for handler "${input.props.handler}"`],
|
|
83
|
-
};
|
|
84
|
-
const nodejs = input.props.nodejs || {};
|
|
85
|
-
const isESM = (nodejs.format || "esm") === "esm";
|
|
86
|
-
const relative = path.relative(project.paths.root, path.resolve(parsed.dir));
|
|
87
|
-
const extension = isESM ? ".mjs" : ".cjs";
|
|
88
|
-
const target = path.join(input.out, !relative.startsWith("..") && !path.isAbsolute(input.props.handler)
|
|
89
|
-
? relative
|
|
90
|
-
: "", parsed.name + extension);
|
|
91
|
-
const handler = path
|
|
92
|
-
.relative(input.out, target.replace(extension, parsed.ext))
|
|
93
|
-
.split(path.sep)
|
|
94
|
-
.join(path.posix.sep);
|
|
95
|
-
if (input.mode === "start") {
|
|
96
|
-
const root = await findAbove(parsed.dir, "package.json");
|
|
97
|
-
if (!root) {
|
|
98
|
-
return {
|
|
99
|
-
type: "error",
|
|
100
|
-
errors: [
|
|
101
|
-
`Could not find package.json for handler "${input.props.handler}"`,
|
|
102
|
-
],
|
|
103
|
-
};
|
|
104
|
-
}
|
|
105
|
-
const dir = path.join(root, "node_modules");
|
|
106
|
-
try {
|
|
107
|
-
await fs.symlink(path.resolve(dir), path.resolve(path.join(input.out, "node_modules")), "dir");
|
|
108
|
-
}
|
|
109
|
-
catch { }
|
|
110
|
-
}
|
|
111
|
-
// Rebuilt using existing esbuild context
|
|
112
|
-
let ctx = rebuildCache[input.functionID]?.ctx;
|
|
113
|
-
const forceExternal = [
|
|
114
|
-
"sharp",
|
|
115
|
-
"pg-native",
|
|
116
|
-
...(isESM || input.props.runtime === "nodejs18.x" ? [] : ["aws-sdk"]),
|
|
117
|
-
];
|
|
118
|
-
const { external, ...override } = nodejs.esbuild || {};
|
|
119
|
-
if (!ctx) {
|
|
120
|
-
const options = {
|
|
121
|
-
entryPoints: [file],
|
|
122
|
-
platform: "node",
|
|
123
|
-
external: [
|
|
124
|
-
...forceExternal,
|
|
125
|
-
...(nodejs.install || []),
|
|
126
|
-
...(external || []),
|
|
127
|
-
],
|
|
128
|
-
loader: nodejs.loader,
|
|
129
|
-
keepNames: true,
|
|
130
|
-
bundle: true,
|
|
131
|
-
logLevel: "silent",
|
|
132
|
-
metafile: true,
|
|
133
|
-
...(isESM
|
|
134
|
-
? {
|
|
135
|
-
format: "esm",
|
|
136
|
-
target: "esnext",
|
|
137
|
-
mainFields: ["module", "main"],
|
|
138
|
-
banner: {
|
|
139
|
-
js: [
|
|
140
|
-
`import { createRequire as topLevelCreateRequire } from 'module';`,
|
|
141
|
-
`const require = topLevelCreateRequire(import.meta.url);`,
|
|
142
|
-
`import { fileURLToPath as topLevelFileUrlToPath, URL as topLevelURL } from "url"`,
|
|
143
|
-
`const __dirname = topLevelFileUrlToPath(new topLevelURL(".", import.meta.url))`,
|
|
144
|
-
nodejs.banner || "",
|
|
145
|
-
].join("\n"),
|
|
146
|
-
},
|
|
147
|
-
}
|
|
148
|
-
: {
|
|
149
|
-
format: "cjs",
|
|
150
|
-
target: "node14",
|
|
151
|
-
banner: nodejs.banner
|
|
152
|
-
? {
|
|
153
|
-
js: nodejs.banner,
|
|
154
|
-
}
|
|
155
|
-
: undefined,
|
|
156
|
-
}),
|
|
157
|
-
outfile: target,
|
|
158
|
-
// always generate sourcemaps in local
|
|
159
|
-
// never generate sourcemaps if explicitly false
|
|
160
|
-
// otherwise generate sourcemaps
|
|
161
|
-
sourcemap: input.mode === "start"
|
|
162
|
-
? "linked"
|
|
163
|
-
: nodejs.sourcemap === false
|
|
164
|
-
? false
|
|
165
|
-
: true,
|
|
166
|
-
minify: nodejs.minify,
|
|
167
|
-
...override,
|
|
168
|
-
};
|
|
169
|
-
ctx = await esbuild.context(options);
|
|
170
|
-
}
|
|
171
|
-
try {
|
|
172
|
-
const result = await ctx.rebuild();
|
|
173
|
-
// Install node_modules
|
|
174
|
-
const installPackages = [
|
|
175
|
-
...(nodejs.install || []),
|
|
176
|
-
...forceExternal
|
|
177
|
-
.filter((pkg) => pkg !== "aws-sdk")
|
|
178
|
-
.filter((pkg) => !external?.includes(pkg))
|
|
179
|
-
.filter((pkg) => Object.values(result.metafile?.inputs || {}).some(({ imports }) => imports.some(({ path }) => path === pkg))),
|
|
180
|
-
];
|
|
181
|
-
// TODO bubble up the warnings
|
|
182
|
-
const warnings = [];
|
|
183
|
-
Object.entries(result.metafile?.inputs || {}).forEach(([inputPath, { imports }]) => imports
|
|
184
|
-
.filter(({ path }) => path.includes("sst/constructs"))
|
|
185
|
-
.forEach(({ path }) => {
|
|
186
|
-
warnings.push(`You are importing from "${path}" in "${inputPath}". Did you mean to import from "sst/node"?`);
|
|
187
|
-
}));
|
|
188
|
-
if (input.mode === "deploy" && installPackages) {
|
|
189
|
-
const src = await findAbove(parsed.dir, "package.json");
|
|
190
|
-
if (!src) {
|
|
191
|
-
return {
|
|
192
|
-
type: "error",
|
|
193
|
-
errors: [
|
|
194
|
-
`Could not find package.json for handler "${input.props.handler}"`,
|
|
195
|
-
],
|
|
196
|
-
};
|
|
197
|
-
}
|
|
198
|
-
const json = JSON.parse(await fs
|
|
199
|
-
.readFile(path.join(src, "package.json"))
|
|
200
|
-
.then((x) => x.toString()));
|
|
201
|
-
await fs.writeFile(path.join(input.out, "package.json"), JSON.stringify({
|
|
202
|
-
dependencies: Object.fromEntries(installPackages.map((x) => [x, json.dependencies?.[x] || "*"])),
|
|
203
|
-
}));
|
|
204
|
-
const cmd = ["npm install"];
|
|
205
|
-
if (installPackages.includes("sharp")) {
|
|
206
|
-
cmd.push("--platform=linux", input.props.architecture === "arm_64"
|
|
207
|
-
? "--arch=arm64"
|
|
208
|
-
: "--arch=x64");
|
|
209
|
-
}
|
|
210
|
-
await new Promise((resolve, reject) => {
|
|
211
|
-
exec(cmd.join(" "), { cwd: input.out }, (error) => {
|
|
212
|
-
if (error) {
|
|
213
|
-
reject(error);
|
|
214
|
-
}
|
|
215
|
-
resolve();
|
|
216
|
-
});
|
|
217
|
-
});
|
|
218
|
-
}
|
|
219
|
-
// Cache esbuild result and context for rebuild
|
|
220
|
-
if (input.mode === "start") {
|
|
221
|
-
rebuildCache[input.functionID] = { ctx, result };
|
|
222
|
-
}
|
|
223
|
-
if (input.mode === "deploy") {
|
|
224
|
-
ctx.dispose();
|
|
225
|
-
}
|
|
226
|
-
logMemoryUsage(input.functionID, input.props.handler);
|
|
227
|
-
return {
|
|
228
|
-
type: "success",
|
|
229
|
-
handler,
|
|
230
|
-
sourcemap: !nodejs.sourcemap
|
|
231
|
-
? Object.keys(result.metafile?.outputs || {}).find((item) => item.endsWith(".map"))
|
|
232
|
-
: undefined,
|
|
233
|
-
};
|
|
234
|
-
}
|
|
235
|
-
catch (ex) {
|
|
236
|
-
const result = ex;
|
|
237
|
-
if ("errors" in result) {
|
|
238
|
-
return {
|
|
239
|
-
type: "error",
|
|
240
|
-
errors: result.errors.flatMap((x) => [
|
|
241
|
-
Colors.bold(x.text),
|
|
242
|
-
x.location?.file || "",
|
|
243
|
-
Colors.dim(x.location?.line, "│", x.location?.lineText),
|
|
244
|
-
]),
|
|
245
|
-
};
|
|
246
|
-
}
|
|
247
|
-
return {
|
|
248
|
-
type: "error",
|
|
249
|
-
errors: [ex.toString()],
|
|
250
|
-
};
|
|
251
|
-
}
|
|
252
|
-
},
|
|
253
|
-
};
|
|
254
|
-
};
|
|
255
|
-
function logMemoryUsage(functionID, handler) {
|
|
256
|
-
const printInMB = (bytes) => `${Math.round(bytes / 1024 / 1024)} MB`;
|
|
257
|
-
const used = process.memoryUsage();
|
|
258
|
-
for (const key in used) {
|
|
259
|
-
// @ts-ignore
|
|
260
|
-
used[key] = printInMB(used[key]);
|
|
261
|
-
}
|
|
262
|
-
Logger.debug({
|
|
263
|
-
functionID,
|
|
264
|
-
handler,
|
|
265
|
-
freeMemory: printInMB(os.freemem()),
|
|
266
|
-
totalMemory: printInMB(os.totalmem()),
|
|
267
|
-
...used,
|
|
268
|
-
});
|
|
269
|
-
}
|
|
@@ -1,141 +0,0 @@
|
|
|
1
|
-
import path from "path";
|
|
2
|
-
import { useRuntimeWorkers } from "../workers.js";
|
|
3
|
-
import { spawn } from "child_process";
|
|
4
|
-
import { useRuntimeServerConfig } from "../server.js";
|
|
5
|
-
import { findAbove, isChild } from "../../util/fs.js";
|
|
6
|
-
import { Runtime } from "aws-cdk-lib/aws-lambda";
|
|
7
|
-
import { bundle } from "./pythonBundling.js";
|
|
8
|
-
import os from "os";
|
|
9
|
-
import url from "url";
|
|
10
|
-
const RUNTIME_MAP = {
|
|
11
|
-
"python2.7": Runtime.PYTHON_2_7,
|
|
12
|
-
"python3.6": Runtime.PYTHON_3_6,
|
|
13
|
-
"python3.7": Runtime.PYTHON_3_7,
|
|
14
|
-
"python3.8": Runtime.PYTHON_3_8,
|
|
15
|
-
"python3.9": Runtime.PYTHON_3_9,
|
|
16
|
-
"python3.10": Runtime.PYTHON_3_10,
|
|
17
|
-
"python3.11": Runtime.PYTHON_3_11,
|
|
18
|
-
};
|
|
19
|
-
export const usePythonHandler = () => {
|
|
20
|
-
const processes = new Map();
|
|
21
|
-
const sources = new Map();
|
|
22
|
-
async function findSrc(input) {
|
|
23
|
-
const hints = ["requirements.txt", "Pipfile", "poetry.lock"];
|
|
24
|
-
for (const hint of hints) {
|
|
25
|
-
const result = await findAbove(input, hint);
|
|
26
|
-
if (result)
|
|
27
|
-
return result;
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
return {
|
|
31
|
-
shouldBuild: (input) => {
|
|
32
|
-
const parent = sources.get(input.functionID);
|
|
33
|
-
if (!parent)
|
|
34
|
-
return false;
|
|
35
|
-
return isChild(parent, input.file);
|
|
36
|
-
},
|
|
37
|
-
canHandle: (input) => input.startsWith("python"),
|
|
38
|
-
startWorker: async (input) => {
|
|
39
|
-
const workers = await useRuntimeWorkers();
|
|
40
|
-
const server = await useRuntimeServerConfig();
|
|
41
|
-
const src = await findSrc(input.handler);
|
|
42
|
-
if (!src)
|
|
43
|
-
throw new Error(`Could not find src for ${input.handler}`);
|
|
44
|
-
const parsed = path.parse(path.relative(src, input.handler));
|
|
45
|
-
const target = [...parsed.dir.split(path.sep), parsed.name].join(".");
|
|
46
|
-
const proc = spawn(os.platform() === "win32" ? "python.exe" : "python3", [
|
|
47
|
-
"-u",
|
|
48
|
-
url.fileURLToPath(new URL("../../support/python-runtime/runtime.py", import.meta.url)),
|
|
49
|
-
target,
|
|
50
|
-
src,
|
|
51
|
-
parsed.ext.substring(1),
|
|
52
|
-
], {
|
|
53
|
-
env: {
|
|
54
|
-
...process.env,
|
|
55
|
-
...input.environment,
|
|
56
|
-
IS_LOCAL: "true",
|
|
57
|
-
AWS_LAMBDA_FUNCTION_MEMORY_SIZE: "1024",
|
|
58
|
-
AWS_LAMBDA_RUNTIME_API: `localhost:${server.port}/${input.workerID}`,
|
|
59
|
-
},
|
|
60
|
-
shell: true,
|
|
61
|
-
cwd: src,
|
|
62
|
-
});
|
|
63
|
-
proc.on("exit", () => workers.exited(input.workerID));
|
|
64
|
-
proc.stdout.on("data", (data) => {
|
|
65
|
-
workers.stdout(input.workerID, data.toString());
|
|
66
|
-
});
|
|
67
|
-
proc.stderr.on("data", (data) => {
|
|
68
|
-
workers.stdout(input.workerID, data.toString());
|
|
69
|
-
});
|
|
70
|
-
processes.set(input.workerID, proc);
|
|
71
|
-
},
|
|
72
|
-
stopWorker: async (workerID) => {
|
|
73
|
-
const proc = processes.get(workerID);
|
|
74
|
-
if (proc) {
|
|
75
|
-
proc.kill();
|
|
76
|
-
processes.delete(workerID);
|
|
77
|
-
}
|
|
78
|
-
},
|
|
79
|
-
build: async (input) => {
|
|
80
|
-
if (input.mode === "start")
|
|
81
|
-
return {
|
|
82
|
-
type: "success",
|
|
83
|
-
handler: input.props.handler,
|
|
84
|
-
};
|
|
85
|
-
const src = await findSrc(input.props.handler);
|
|
86
|
-
if (!src)
|
|
87
|
-
return {
|
|
88
|
-
type: "error",
|
|
89
|
-
errors: [`Could not find src for ${input.props.handler}`],
|
|
90
|
-
};
|
|
91
|
-
bundle({
|
|
92
|
-
installCommands: input.props.python?.installCommands,
|
|
93
|
-
entry: src,
|
|
94
|
-
runtime: RUNTIME_MAP[input.props.runtime],
|
|
95
|
-
architecture: input.props.architecture,
|
|
96
|
-
outputPathSuffix: ".",
|
|
97
|
-
out: input.out,
|
|
98
|
-
});
|
|
99
|
-
/*
|
|
100
|
-
await fs.cp(src, input.out, {
|
|
101
|
-
recursive: true,
|
|
102
|
-
filter: (src) => !src.includes(".sst"),
|
|
103
|
-
});
|
|
104
|
-
|
|
105
|
-
if (await existsAsync(path.join(src, "Pipfile"))) {
|
|
106
|
-
await execAsync("pipenv requirements > requirements.txt", {
|
|
107
|
-
cwd: input.out,
|
|
108
|
-
});
|
|
109
|
-
}
|
|
110
|
-
if (await existsAsync(path.join(src, "poetry.lock"))) {
|
|
111
|
-
await execAsync(
|
|
112
|
-
"poetry export --with-credentials --format requirements.txt --output requirements.txt",
|
|
113
|
-
{
|
|
114
|
-
cwd: input.out,
|
|
115
|
-
}
|
|
116
|
-
);
|
|
117
|
-
}
|
|
118
|
-
if (await existsAsync(path.join(src, "requirements.txt"))) {
|
|
119
|
-
await execAsync("pip install -r requirements.txt", {
|
|
120
|
-
cwd: input.out,
|
|
121
|
-
});
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
if (input.props.python?.installCommands) {
|
|
125
|
-
for (const cmd of input.props.python.installCommands) {
|
|
126
|
-
await execAsync(cmd, {
|
|
127
|
-
cwd: input.out,
|
|
128
|
-
});
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
*/
|
|
132
|
-
return {
|
|
133
|
-
type: "success",
|
|
134
|
-
handler: path
|
|
135
|
-
.relative(src, path.resolve(input.props.handler))
|
|
136
|
-
.split(path.sep)
|
|
137
|
-
.join(path.posix.sep),
|
|
138
|
-
};
|
|
139
|
-
},
|
|
140
|
-
};
|
|
141
|
-
};
|