sst 3.0.0 → 3.0.1-2
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 +8 -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/project.js
DELETED
|
@@ -1,188 +0,0 @@
|
|
|
1
|
-
import fs from "fs/promises";
|
|
2
|
-
import fsSync from "fs";
|
|
3
|
-
import path from "path";
|
|
4
|
-
import url from "url";
|
|
5
|
-
import os from "os";
|
|
6
|
-
import { Logger } from "./logger.js";
|
|
7
|
-
import { VisibleError } from "./error.js";
|
|
8
|
-
import { blue } from "colorette";
|
|
9
|
-
import dotenv from "dotenv";
|
|
10
|
-
import { load } from "./stacks/build.js";
|
|
11
|
-
const DEFAULTS = {
|
|
12
|
-
stage: undefined,
|
|
13
|
-
ssmPrefix: undefined,
|
|
14
|
-
};
|
|
15
|
-
let project;
|
|
16
|
-
export function useProject() {
|
|
17
|
-
if (!project)
|
|
18
|
-
throw new Error("Project not initialized");
|
|
19
|
-
return project;
|
|
20
|
-
}
|
|
21
|
-
const CONFIG_EXTENSIONS = [
|
|
22
|
-
".config.ts",
|
|
23
|
-
".config.mts",
|
|
24
|
-
".config.cts",
|
|
25
|
-
".config.cjs",
|
|
26
|
-
".config.mjs",
|
|
27
|
-
".config.js",
|
|
28
|
-
];
|
|
29
|
-
export async function initProject(globals) {
|
|
30
|
-
// Logger.debug("initing project");
|
|
31
|
-
const root = globals.root || (await findRoot());
|
|
32
|
-
const out = path.join(root, ".sst");
|
|
33
|
-
await fs.mkdir(out, {
|
|
34
|
-
recursive: true,
|
|
35
|
-
});
|
|
36
|
-
// Logger.debug("made out dir");
|
|
37
|
-
let file;
|
|
38
|
-
const [metafile, sstConfig] = await (async function () {
|
|
39
|
-
for (const ext of CONFIG_EXTENSIONS) {
|
|
40
|
-
file = path.join(root, "sst" + ext);
|
|
41
|
-
if (!fsSync.existsSync(file))
|
|
42
|
-
continue;
|
|
43
|
-
// Logger.debug("found sst config");
|
|
44
|
-
const [metafile, config] = await load(file, true);
|
|
45
|
-
// Logger.debug("loaded sst config");
|
|
46
|
-
return [metafile, config];
|
|
47
|
-
}
|
|
48
|
-
throw new VisibleError("Could not found a configuration file", "Make sure one of the following exists", ...CONFIG_EXTENSIONS.map((x) => ` - sst${x}`));
|
|
49
|
-
})();
|
|
50
|
-
const config = await Promise.resolve(sstConfig.config(globals));
|
|
51
|
-
const stage = process.env.SST_STAGE ||
|
|
52
|
-
globals.stage ||
|
|
53
|
-
config.stage ||
|
|
54
|
-
(await usePersonalStage(out)) ||
|
|
55
|
-
(await promptPersonalStage(out));
|
|
56
|
-
// Set stage to SST_STAGE so that if SST spawned processes are aware
|
|
57
|
-
// of the stage. ie.
|
|
58
|
-
// `sst deploy --stage prod`: `prod` stage passed in via CLI
|
|
59
|
-
// -> spawns `open-next build`
|
|
60
|
-
// -> spawns `sst bind`: `prod` stage read from SST_STAGE
|
|
61
|
-
process.env.SST_STAGE = stage;
|
|
62
|
-
const [version, cdkVersion, constructsVersion] = await (async () => {
|
|
63
|
-
try {
|
|
64
|
-
const packageJson = JSON.parse(await fs
|
|
65
|
-
.readFile(url.fileURLToPath(new URL("./package.json", import.meta.url)))
|
|
66
|
-
.then((x) => x.toString()));
|
|
67
|
-
return [
|
|
68
|
-
packageJson.version,
|
|
69
|
-
packageJson.dependencies["aws-cdk-lib"],
|
|
70
|
-
packageJson.dependencies["constructs"],
|
|
71
|
-
];
|
|
72
|
-
}
|
|
73
|
-
catch {
|
|
74
|
-
return ["unknown", "unknown"];
|
|
75
|
-
}
|
|
76
|
-
})();
|
|
77
|
-
project = {
|
|
78
|
-
version,
|
|
79
|
-
cdkVersion,
|
|
80
|
-
constructsVersion,
|
|
81
|
-
config: {
|
|
82
|
-
...config,
|
|
83
|
-
stage,
|
|
84
|
-
profile: process.env.AWS_ACCESS_KEY_ID && process.env.AWS_SECRET_ACCESS_KEY
|
|
85
|
-
? undefined
|
|
86
|
-
: globals.profile || config.profile,
|
|
87
|
-
region: globals.region || config.region,
|
|
88
|
-
role: globals.role || config.role,
|
|
89
|
-
ssmPrefix: config.ssmPrefix || `/sst/${config.name}/${stage}/`,
|
|
90
|
-
bootstrap: config.bootstrap,
|
|
91
|
-
cdk: config.cdk,
|
|
92
|
-
},
|
|
93
|
-
stacks: sstConfig.stacks,
|
|
94
|
-
metafile,
|
|
95
|
-
paths: {
|
|
96
|
-
config: file,
|
|
97
|
-
root,
|
|
98
|
-
out,
|
|
99
|
-
artifacts: path.join(out, "artifacts"),
|
|
100
|
-
},
|
|
101
|
-
};
|
|
102
|
-
// Cleanup old config files
|
|
103
|
-
(async function () {
|
|
104
|
-
const files = await fs.readdir(project.paths.root);
|
|
105
|
-
for (const file of files) {
|
|
106
|
-
if (file.startsWith(".sst.config")) {
|
|
107
|
-
// Do not remove recently generated config files. This allows for multiple
|
|
108
|
-
// SST processes to run concurrently.
|
|
109
|
-
const timeGenerated = (file.match(/\b\d{13}\b/g) ?? []).at(0);
|
|
110
|
-
if (timeGenerated && Date.now() - parseInt(timeGenerated, 10) < 30000) {
|
|
111
|
-
continue;
|
|
112
|
-
}
|
|
113
|
-
await fs.unlink(path.join(project.paths.root, file));
|
|
114
|
-
Logger.debug(`Removed old config file ${file}`);
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
})();
|
|
118
|
-
// Load .env files
|
|
119
|
-
[
|
|
120
|
-
path.join(project.paths.root, `.env`),
|
|
121
|
-
path.join(project.paths.root, `.env.local`),
|
|
122
|
-
path.join(project.paths.root, `.env.${project.config.stage}`),
|
|
123
|
-
path.join(project.paths.root, `.env.${project.config.stage}.local`),
|
|
124
|
-
].forEach((path) => dotenv.config({ path, override: true }));
|
|
125
|
-
Logger.debug("Config loaded", project);
|
|
126
|
-
}
|
|
127
|
-
async function usePersonalStage(out) {
|
|
128
|
-
try {
|
|
129
|
-
const result = await fs.readFile(path.join(out, "stage"));
|
|
130
|
-
return result.toString("utf8").trim();
|
|
131
|
-
}
|
|
132
|
-
catch {
|
|
133
|
-
return;
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
async function promptPersonalStage(out, isRetry) {
|
|
137
|
-
const readline = await import("readline");
|
|
138
|
-
const rl = readline.createInterface({
|
|
139
|
-
input: process.stdin,
|
|
140
|
-
output: process.stdout,
|
|
141
|
-
});
|
|
142
|
-
const stage = await new Promise((resolve) => {
|
|
143
|
-
const suggested = sanitizeStageName(os.userInfo().username) || "local";
|
|
144
|
-
const instruction = !isRetry
|
|
145
|
-
? `Please enter a name you’d like to use for your personal stage.`
|
|
146
|
-
: `Please enter a name that starts with a letter, followed by letters, numbers, or hyphens.`;
|
|
147
|
-
rl.question(`${instruction} Or hit enter to use ${blue(suggested)}: `, async (input) => {
|
|
148
|
-
rl.close();
|
|
149
|
-
const result = input === "" ? suggested : input;
|
|
150
|
-
resolve(result);
|
|
151
|
-
});
|
|
152
|
-
});
|
|
153
|
-
// Validate stage name
|
|
154
|
-
if (isValidStageName(stage)) {
|
|
155
|
-
await fs.writeFile(path.join(out, "stage"), stage);
|
|
156
|
-
return stage;
|
|
157
|
-
}
|
|
158
|
-
return await promptPersonalStage(out, true);
|
|
159
|
-
}
|
|
160
|
-
async function findRoot() {
|
|
161
|
-
async function find(dir) {
|
|
162
|
-
if (dir === "/")
|
|
163
|
-
throw new VisibleError("Could not found a configuration file", "Make sure one of the following exists", ...CONFIG_EXTENSIONS.map((ext) => ` - sst${ext}`));
|
|
164
|
-
for (const ext of CONFIG_EXTENSIONS) {
|
|
165
|
-
const configPath = path.join(dir, `sst${ext}`);
|
|
166
|
-
if (fsSync.existsSync(configPath)) {
|
|
167
|
-
return dir;
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
return await find(path.join(dir, ".."));
|
|
171
|
-
}
|
|
172
|
-
const result = await find(process.cwd());
|
|
173
|
-
return result;
|
|
174
|
-
}
|
|
175
|
-
function sanitizeStageName(stage) {
|
|
176
|
-
return (stage
|
|
177
|
-
.replace(/[^A-Za-z0-9-]/g, "-")
|
|
178
|
-
.replace(/--+/g, "-")
|
|
179
|
-
.replace(/^[^A-Za-z]/, "")
|
|
180
|
-
.replace(/-$/, "") || "local");
|
|
181
|
-
}
|
|
182
|
-
function isValidStageName(stage) {
|
|
183
|
-
return Boolean(stage.match(/^[A-Za-z][A-Za-z0-9-]*$/));
|
|
184
|
-
}
|
|
185
|
-
export const exportedForTesting = {
|
|
186
|
-
sanitizeStageName,
|
|
187
|
-
isValidStageName,
|
|
188
|
-
};
|
|
@@ -1,263 +0,0 @@
|
|
|
1
|
-
import http from "http";
|
|
2
|
-
import { spawn } from "child_process";
|
|
3
|
-
import { useRuntimeWorkers } from "../workers.js";
|
|
4
|
-
import { useRuntimeServerConfig } from "../server.js";
|
|
5
|
-
import { VisibleError } from "../../error.js";
|
|
6
|
-
import { isChild } from "../../util/fs.js";
|
|
7
|
-
import { execAsync } from "../../util/process.js";
|
|
8
|
-
import { useFunctions } from "../../constructs/Function.js";
|
|
9
|
-
export const useContainerHandler = () => {
|
|
10
|
-
const containers = new Map();
|
|
11
|
-
const sources = new Map();
|
|
12
|
-
async function dockerRun(input, opts, onExit) {
|
|
13
|
-
const workers = await useRuntimeWorkers();
|
|
14
|
-
const name = `sst-workerID-${input.workerID}-${Date.now()}`;
|
|
15
|
-
const proc = spawn("docker", [
|
|
16
|
-
"run",
|
|
17
|
-
"--rm",
|
|
18
|
-
"--network=host",
|
|
19
|
-
`--name=${name}`,
|
|
20
|
-
...Object.entries({
|
|
21
|
-
...input.environment,
|
|
22
|
-
...opts.envs,
|
|
23
|
-
IS_LOCAL: "true",
|
|
24
|
-
})
|
|
25
|
-
.map(([key, value]) => ["-e", `${key}=${value}`])
|
|
26
|
-
.flat(),
|
|
27
|
-
...(opts.entrypoint !== undefined
|
|
28
|
-
? ["--entrypoint", opts.entrypoint]
|
|
29
|
-
: []),
|
|
30
|
-
`sst-dev:${input.functionID}`,
|
|
31
|
-
...(opts.cmd ?? []),
|
|
32
|
-
], {
|
|
33
|
-
env: {
|
|
34
|
-
...process.env,
|
|
35
|
-
},
|
|
36
|
-
cwd: input.out,
|
|
37
|
-
});
|
|
38
|
-
proc.on("exit", (code) => {
|
|
39
|
-
onExit(code);
|
|
40
|
-
});
|
|
41
|
-
proc.stdout.on("data", (data) => {
|
|
42
|
-
workers.stdout(input.workerID, data.toString());
|
|
43
|
-
});
|
|
44
|
-
proc.stderr.on("data", (data) => {
|
|
45
|
-
workers.stdout(input.workerID, data.toString());
|
|
46
|
-
});
|
|
47
|
-
containers.set(input.workerID, name);
|
|
48
|
-
}
|
|
49
|
-
async function startLambdaWorker(input) {
|
|
50
|
-
const server = await useRuntimeServerConfig();
|
|
51
|
-
const workers = await useRuntimeWorkers();
|
|
52
|
-
const fn = useFunctions().fromID(input.functionID);
|
|
53
|
-
dockerRun(input, {
|
|
54
|
-
cmd: fn?.container?.cmd,
|
|
55
|
-
envs: {
|
|
56
|
-
AWS_LAMBDA_RUNTIME_API: `host.docker.internal:${server.port}/${input.workerID}`,
|
|
57
|
-
},
|
|
58
|
-
}, () => {
|
|
59
|
-
workers.exited(input.workerID);
|
|
60
|
-
});
|
|
61
|
-
}
|
|
62
|
-
async function startJobWorker(input) {
|
|
63
|
-
const workers = await useRuntimeWorkers();
|
|
64
|
-
// Job container is special:
|
|
65
|
-
// 1. Not capable of receiving the `event` payload
|
|
66
|
-
// - on `sst deploy`, the CodeBuild job is started with `SST_PAYLOAD` env var
|
|
67
|
-
// - on `sst dev`, set `SST_DEBUG_JOB` env var here
|
|
68
|
-
// 2. Worker exits at the end of the run.
|
|
69
|
-
// Fetch request
|
|
70
|
-
const result = await init();
|
|
71
|
-
const awsRequestId = result.headers["lambda-runtime-aws-request-id"];
|
|
72
|
-
const fn = useFunctions().fromID(input.functionID);
|
|
73
|
-
try {
|
|
74
|
-
await dockerRun(input, {
|
|
75
|
-
entrypoint: "",
|
|
76
|
-
cmd: fn?.container?.cmd,
|
|
77
|
-
envs: {
|
|
78
|
-
SST_PAYLOAD: result.body,
|
|
79
|
-
},
|
|
80
|
-
}, async (code) => {
|
|
81
|
-
code === 0 ? await success() : await error();
|
|
82
|
-
workers.exited(input.workerID);
|
|
83
|
-
});
|
|
84
|
-
}
|
|
85
|
-
catch (ex) {
|
|
86
|
-
await initError(ex);
|
|
87
|
-
workers.exited(input.workerID);
|
|
88
|
-
}
|
|
89
|
-
async function init() {
|
|
90
|
-
return await fetch({
|
|
91
|
-
path: `/runtime/invocation/next`,
|
|
92
|
-
method: "GET",
|
|
93
|
-
headers: {},
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
async function initError(ex) {
|
|
97
|
-
return await fetch({
|
|
98
|
-
path: `/runtime/init/error`,
|
|
99
|
-
method: "POST",
|
|
100
|
-
headers: {
|
|
101
|
-
"Content-Type": "application/json",
|
|
102
|
-
},
|
|
103
|
-
body: JSON.stringify({
|
|
104
|
-
errorType: "Error",
|
|
105
|
-
errorMessage: ex.message,
|
|
106
|
-
trace: ex.stack?.split("\n"),
|
|
107
|
-
}),
|
|
108
|
-
});
|
|
109
|
-
}
|
|
110
|
-
async function success() {
|
|
111
|
-
while (true) {
|
|
112
|
-
try {
|
|
113
|
-
await fetch({
|
|
114
|
-
path: `/runtime/invocation/${awsRequestId}/response`,
|
|
115
|
-
method: "POST",
|
|
116
|
-
headers: {
|
|
117
|
-
"Content-Type": "application/json",
|
|
118
|
-
},
|
|
119
|
-
body: JSON.stringify("Job completed successfully"),
|
|
120
|
-
});
|
|
121
|
-
break;
|
|
122
|
-
}
|
|
123
|
-
catch (ex) {
|
|
124
|
-
console.error(ex);
|
|
125
|
-
await new Promise((resolve) => setTimeout(resolve, 500));
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
async function error() {
|
|
130
|
-
return await fetch({
|
|
131
|
-
path: `/runtime/invocation/${awsRequestId}/error`,
|
|
132
|
-
method: "POST",
|
|
133
|
-
headers: {
|
|
134
|
-
"Content-Type": "application/json",
|
|
135
|
-
},
|
|
136
|
-
body: JSON.stringify({
|
|
137
|
-
errorType: "Error",
|
|
138
|
-
errorMessage: "Failed to run job",
|
|
139
|
-
trace: [],
|
|
140
|
-
}),
|
|
141
|
-
});
|
|
142
|
-
}
|
|
143
|
-
function fetch(req) {
|
|
144
|
-
return new Promise((resolve, reject) => {
|
|
145
|
-
const request = http.request(input.url + req.path, {
|
|
146
|
-
headers: req.headers,
|
|
147
|
-
method: req.method,
|
|
148
|
-
}, (res) => {
|
|
149
|
-
let body = "";
|
|
150
|
-
res.setEncoding("utf8");
|
|
151
|
-
res.on("data", (chunk) => {
|
|
152
|
-
body += chunk.toString();
|
|
153
|
-
});
|
|
154
|
-
res.on("end", () => {
|
|
155
|
-
resolve({
|
|
156
|
-
statusCode: res.statusCode,
|
|
157
|
-
headers: res.headers,
|
|
158
|
-
body,
|
|
159
|
-
});
|
|
160
|
-
});
|
|
161
|
-
});
|
|
162
|
-
request.on("error", reject);
|
|
163
|
-
if (req.body)
|
|
164
|
-
request.write(req.body);
|
|
165
|
-
request.end();
|
|
166
|
-
});
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
return {
|
|
170
|
-
shouldBuild: (input) => {
|
|
171
|
-
const parent = sources.get(input.functionID);
|
|
172
|
-
if (!parent)
|
|
173
|
-
return false;
|
|
174
|
-
return isChild(parent, input.file);
|
|
175
|
-
},
|
|
176
|
-
canHandle: (input) => input.startsWith("container"),
|
|
177
|
-
startWorker: async (input) => {
|
|
178
|
-
input.environment.SST_DEBUG_JOB
|
|
179
|
-
? await startJobWorker(input)
|
|
180
|
-
: await startLambdaWorker(input);
|
|
181
|
-
},
|
|
182
|
-
stopWorker: async (workerID) => {
|
|
183
|
-
const name = containers.get(workerID);
|
|
184
|
-
if (name) {
|
|
185
|
-
try {
|
|
186
|
-
// note:
|
|
187
|
-
// - calling `docker kill` kills the docker process much faster than `docker stop`
|
|
188
|
-
// - process.kill() does not work on docker processes
|
|
189
|
-
await execAsync(`docker kill ${name}`, {
|
|
190
|
-
env: {
|
|
191
|
-
...process.env,
|
|
192
|
-
},
|
|
193
|
-
});
|
|
194
|
-
}
|
|
195
|
-
catch (ex) {
|
|
196
|
-
console.error(ex);
|
|
197
|
-
throw new VisibleError(`Could not stop docker container ${name}`);
|
|
198
|
-
}
|
|
199
|
-
containers.delete(workerID);
|
|
200
|
-
}
|
|
201
|
-
},
|
|
202
|
-
build: async (input) => {
|
|
203
|
-
const project = input.props.handler;
|
|
204
|
-
sources.set(input.functionID, project);
|
|
205
|
-
if (input.mode === "start") {
|
|
206
|
-
try {
|
|
207
|
-
const result = await execAsync([
|
|
208
|
-
`docker build`,
|
|
209
|
-
`-t sst-dev:${input.functionID}`,
|
|
210
|
-
...(input.props.container?.file
|
|
211
|
-
? [`-f ${input.props.container.file}`]
|
|
212
|
-
: []),
|
|
213
|
-
...Object.entries(input.props.container?.buildArgs || {}).map(([k, v]) => `--build-arg ${k}=${v}`),
|
|
214
|
-
`.`,
|
|
215
|
-
].join(" "), {
|
|
216
|
-
cwd: project,
|
|
217
|
-
env: {
|
|
218
|
-
...process.env,
|
|
219
|
-
},
|
|
220
|
-
});
|
|
221
|
-
}
|
|
222
|
-
catch (ex) {
|
|
223
|
-
return {
|
|
224
|
-
type: "error",
|
|
225
|
-
errors: [String(ex)],
|
|
226
|
-
};
|
|
227
|
-
}
|
|
228
|
-
}
|
|
229
|
-
if (input.mode === "deploy") {
|
|
230
|
-
try {
|
|
231
|
-
const platform = input.props.architecture === "arm_64"
|
|
232
|
-
? "linux/arm64"
|
|
233
|
-
: "linux/amd64";
|
|
234
|
-
await execAsync([
|
|
235
|
-
`docker build`,
|
|
236
|
-
`-t sst-build:${input.functionID}`,
|
|
237
|
-
...(input.props.container?.file
|
|
238
|
-
? [`-f ${input.props.container.file}`]
|
|
239
|
-
: []),
|
|
240
|
-
...Object.entries(input.props.container?.buildArgs || {}).map(([k, v]) => `--build-arg ${k}=${v}`),
|
|
241
|
-
`--platform ${platform}`,
|
|
242
|
-
`.`,
|
|
243
|
-
].join(" "), {
|
|
244
|
-
cwd: project,
|
|
245
|
-
env: {
|
|
246
|
-
...process.env,
|
|
247
|
-
},
|
|
248
|
-
});
|
|
249
|
-
}
|
|
250
|
-
catch (ex) {
|
|
251
|
-
return {
|
|
252
|
-
type: "error",
|
|
253
|
-
errors: [String(ex)],
|
|
254
|
-
};
|
|
255
|
-
}
|
|
256
|
-
}
|
|
257
|
-
return {
|
|
258
|
-
type: "success",
|
|
259
|
-
handler: "not required for container",
|
|
260
|
-
};
|
|
261
|
-
},
|
|
262
|
-
};
|
|
263
|
-
};
|
|
@@ -1,115 +0,0 @@
|
|
|
1
|
-
import { useRuntimeWorkers } from "../workers.js";
|
|
2
|
-
import { spawn } from "child_process";
|
|
3
|
-
import { useRuntimeServerConfig } from "../server.js";
|
|
4
|
-
import { findBelow, isChild } from "../../util/fs.js";
|
|
5
|
-
import { useProject } from "../../project.js";
|
|
6
|
-
import { execAsync } from "../../util/process.js";
|
|
7
|
-
import url from "url";
|
|
8
|
-
const FRAMEWORK_MAP = {
|
|
9
|
-
"dotnetcore1.0": "netcoreapp3.1",
|
|
10
|
-
"dotnetcore2.0": "netcoreapp3.1",
|
|
11
|
-
"dotnetcore2.1": "netcoreapp3.1",
|
|
12
|
-
"dotnetcore3.1": "netcoreapp3.1",
|
|
13
|
-
dotnet6: "net6.0",
|
|
14
|
-
};
|
|
15
|
-
const BOOTSTRAP_MAP = {
|
|
16
|
-
"dotnetcore1.0": "dotnet31-bootstrap",
|
|
17
|
-
"dotnetcore2.0": "dotnet31-bootstrap",
|
|
18
|
-
"dotnetcore2.1": "dotnet31-bootstrap",
|
|
19
|
-
"dotnetcore3.1": "dotnet31-bootstrap",
|
|
20
|
-
dotnet6: "dotnet6-bootstrap",
|
|
21
|
-
};
|
|
22
|
-
export const useDotnetHandler = () => {
|
|
23
|
-
const processes = new Map();
|
|
24
|
-
const sources = new Map();
|
|
25
|
-
const handlerName = process.platform === "win32" ? `handler.exe` : `handler`;
|
|
26
|
-
return {
|
|
27
|
-
shouldBuild: (input) => {
|
|
28
|
-
if (!input.file.endsWith(".cs") && !input.file.endsWith(".fs"))
|
|
29
|
-
return false;
|
|
30
|
-
const parent = sources.get(input.functionID);
|
|
31
|
-
if (!parent)
|
|
32
|
-
return false;
|
|
33
|
-
return isChild(parent, input.file);
|
|
34
|
-
},
|
|
35
|
-
canHandle: (input) => input.startsWith("dotnet"),
|
|
36
|
-
startWorker: async (input) => {
|
|
37
|
-
const workers = await useRuntimeWorkers();
|
|
38
|
-
const server = await useRuntimeServerConfig();
|
|
39
|
-
const name = input.handler.split(":")[0];
|
|
40
|
-
const proc = spawn(`dotnet`, [
|
|
41
|
-
`exec`,
|
|
42
|
-
url.fileURLToPath(new URL(`../../support/${BOOTSTRAP_MAP[input.runtime]}/release/dotnet-bootstrap.dll`, import.meta.url)),
|
|
43
|
-
name + ".dll",
|
|
44
|
-
input.handler,
|
|
45
|
-
], {
|
|
46
|
-
env: {
|
|
47
|
-
...process.env,
|
|
48
|
-
...input.environment,
|
|
49
|
-
IS_LOCAL: "true",
|
|
50
|
-
AWS_LAMBDA_RUNTIME_API: `localhost:${server.port}/${input.workerID}`,
|
|
51
|
-
AWS_LAMBDA_DOTNET_DEBUG_RUN_ONCE: "true",
|
|
52
|
-
},
|
|
53
|
-
cwd: input.out,
|
|
54
|
-
});
|
|
55
|
-
proc.on("exit", () => workers.exited(input.workerID));
|
|
56
|
-
proc.stdout.on("data", (data) => {
|
|
57
|
-
workers.stdout(input.workerID, data.toString());
|
|
58
|
-
});
|
|
59
|
-
proc.stderr.on("data", (data) => {
|
|
60
|
-
workers.stdout(input.workerID, data.toString());
|
|
61
|
-
});
|
|
62
|
-
processes.set(input.workerID, proc);
|
|
63
|
-
},
|
|
64
|
-
stopWorker: async (workerID) => {
|
|
65
|
-
const proc = processes.get(workerID);
|
|
66
|
-
if (proc) {
|
|
67
|
-
proc.kill();
|
|
68
|
-
processes.delete(workerID);
|
|
69
|
-
}
|
|
70
|
-
},
|
|
71
|
-
build: async (input) => {
|
|
72
|
-
const project = useProject();
|
|
73
|
-
const name = input.props.handler.split(":")[0];
|
|
74
|
-
const srcPath = await findBelow(project.paths.root, `${name}.csproj`);
|
|
75
|
-
sources.set(input.functionID, srcPath);
|
|
76
|
-
try {
|
|
77
|
-
await execAsync([
|
|
78
|
-
"dotnet",
|
|
79
|
-
"publish",
|
|
80
|
-
"--output",
|
|
81
|
-
'"' + input.out + '"',
|
|
82
|
-
"--configuration",
|
|
83
|
-
"Release",
|
|
84
|
-
"--framework",
|
|
85
|
-
FRAMEWORK_MAP[input.props.runtime],
|
|
86
|
-
"/p:GenerateRuntimeConfigurationFiles=true",
|
|
87
|
-
"/clp:ForceConsoleColor",
|
|
88
|
-
// warnings are not reported for repeated builds by default and this flag
|
|
89
|
-
// does a clean before build. It takes a little longer to run, but the
|
|
90
|
-
// warnings are consistently printed on each build.
|
|
91
|
-
//"/target:Rebuild",
|
|
92
|
-
"--self-contained",
|
|
93
|
-
"false",
|
|
94
|
-
// do not print "Build Engine version"
|
|
95
|
-
"-nologo",
|
|
96
|
-
].join(" "),
|
|
97
|
-
// only print errors
|
|
98
|
-
{
|
|
99
|
-
cwd: srcPath,
|
|
100
|
-
});
|
|
101
|
-
return {
|
|
102
|
-
type: "success",
|
|
103
|
-
handler: input.props.handler,
|
|
104
|
-
runtime: input.props.runtime,
|
|
105
|
-
};
|
|
106
|
-
}
|
|
107
|
-
catch (ex) {
|
|
108
|
-
return {
|
|
109
|
-
type: "error",
|
|
110
|
-
errors: [ex.stderr],
|
|
111
|
-
};
|
|
112
|
-
}
|
|
113
|
-
},
|
|
114
|
-
};
|
|
115
|
-
};
|
package/runtime/handlers/go.d.ts
DELETED