From fb0508098940742855f6efd3ca85bff06eb6157d Mon Sep 17 00:00:00 2001 From: Kyle Laker Date: Mon, 12 Sep 2022 20:36:38 -0400 Subject: [PATCH] docs: improve Lambda import names In the `aws-lambda-nodejs`, `aws-lambda-python`, and `aws-lambda-go` package `README`s, the code examples use `lambda` as the name to import the package. This makes the code examples confusing because `rosetta/default.ts-fixture` masks the `import` statement from readers and may confuse them as to why their `lambda` import doesn't work when they use `lambda.NodejsFunction` (or similar). The imports are changed to `nodejs`, `python`, and `go`. While the last (`go`) is in fact a keyword in its own language, so too is `lambda` in Python. This matches the pattern used by other packages' examples (`aws-route53-patterns` for example uses `patterns` as the name for its import in docs). This change should make the docs more clear to new users, who likely started using Lambda using `lambda.Function` and already have a `lambda` import that won't do what they want. --- packages/@aws-cdk/aws-lambda-go/README.md | 12 +++---- .../aws-lambda-go/rosetta/default.ts-fixture | 2 +- packages/@aws-cdk/aws-lambda-nodejs/README.md | 32 +++++++++---------- .../rosetta/default.ts-fixture | 2 +- packages/@aws-cdk/aws-lambda-python/README.md | 16 +++++----- .../rosetta/default.ts-fixture | 2 +- 6 files changed, 33 insertions(+), 33 deletions(-) diff --git a/packages/@aws-cdk/aws-lambda-go/README.md b/packages/@aws-cdk/aws-lambda-go/README.md index d0d28f6ae83ad..aa805e336b7e0 100644 --- a/packages/@aws-cdk/aws-lambda-go/README.md +++ b/packages/@aws-cdk/aws-lambda-go/README.md @@ -28,7 +28,7 @@ using a Go version >= 1.11 and is using [Go modules](https://golang.org/ref/mod) Define a `GoFunction`: ```ts -new lambda.GoFunction(this, 'handler', { +new go.GoFunction(this, 'handler', { entry: 'app/cmd/api', }); ``` @@ -112,7 +112,7 @@ By default the following environment variables are set for you: Use the `environment` prop to define additional environment variables when go runs: ```ts -new lambda.GoFunction(this, 'handler', { +new go.GoFunction(this, 'handler', { entry: 'app/cmd/api', bundling: { environment: { @@ -138,7 +138,7 @@ To force bundling in a docker container even if `Go` is available in your enviro Use the `buildArgs` prop to pass build arguments when building the bundling image: ```ts -new lambda.GoFunction(this, 'handler', { +new go.GoFunction(this, 'handler', { entry: 'app/cmd/api', bundling: { buildArgs: { @@ -151,7 +151,7 @@ new lambda.GoFunction(this, 'handler', { Use the `bundling.dockerImage` prop to use a custom bundling image: ```ts -new lambda.GoFunction(this, 'handler', { +new go.GoFunction(this, 'handler', { entry: 'app/cmd/api', bundling: { dockerImage: DockerImage.fromBuild('/path/to/Dockerfile'), @@ -162,7 +162,7 @@ new lambda.GoFunction(this, 'handler', { Use the `bundling.goBuildFlags` prop to pass additional build flags to `go build`: ```ts -new lambda.GoFunction(this, 'handler', { +new go.GoFunction(this, 'handler', { entry: 'app/cmd/api', bundling: { goBuildFlags: ['-ldflags "-s -w"'], @@ -177,7 +177,7 @@ It is possible to run additional commands by specifying the `commandHooks` prop ```text // This example only available in TypeScript // Run additional commands on a GoFunction via `commandHooks` property -new lambda.GoFunction(this, 'handler', { +new go.GoFunction(this, 'handler', { bundling: { commandHooks: { // run tests diff --git a/packages/@aws-cdk/aws-lambda-go/rosetta/default.ts-fixture b/packages/@aws-cdk/aws-lambda-go/rosetta/default.ts-fixture index 96f3f6933780c..5daf6825a50ad 100644 --- a/packages/@aws-cdk/aws-lambda-go/rosetta/default.ts-fixture +++ b/packages/@aws-cdk/aws-lambda-go/rosetta/default.ts-fixture @@ -1,7 +1,7 @@ // Fixture with packages imported, but nothing else import { Construct } from 'constructs'; import { DockerImage, Stack } from '@aws-cdk/core'; -import * as lambda from '@aws-cdk/aws-lambda-go'; +import * as go from '@aws-cdk/aws-lambda-go'; class Fixture extends Stack { constructor(scope: Construct, id: string) { diff --git a/packages/@aws-cdk/aws-lambda-nodejs/README.md b/packages/@aws-cdk/aws-lambda-nodejs/README.md index c4eb9b6343b00..3953bd225aaca 100644 --- a/packages/@aws-cdk/aws-lambda-nodejs/README.md +++ b/packages/@aws-cdk/aws-lambda-nodejs/README.md @@ -40,14 +40,14 @@ id to look up the entry file. In `my-construct.ts` above we have: ```ts // automatic entry look up -const apiHandler = new lambda.NodejsFunction(this, 'api'); -const authHandler = new lambda.NodejsFunction(this, 'auth'); +const apiHandler = new nodejs.NodejsFunction(this, 'api'); +const authHandler = new nodejs.NodejsFunction(this, 'auth'); ``` Alternatively, an entry file and handler can be specified: ```ts -new lambda.NodejsFunction(this, 'MyFunction', { +new nodejs.NodejsFunction(this, 'MyFunction', { entry: '/path/to/my/file.ts', // accepts .js, .jsx, .ts, .tsx and .mjs files handler: 'myExportedFunc', // defaults to 'handler' }); @@ -134,7 +134,7 @@ By default, all node modules are bundled except for `aws-sdk`. This can be confi `bundling.externalModules`: ```ts -new lambda.NodejsFunction(this, 'my-handler', { +new nodejs.NodejsFunction(this, 'my-handler', { bundling: { externalModules: [ 'aws-sdk', // Use the 'aws-sdk' available in the Lambda runtime @@ -152,7 +152,7 @@ bundled but instead included in the `node_modules` folder of the Lambda package. when working with native dependencies or when `esbuild` fails to bundle a module. ```ts -new lambda.NodejsFunction(this, 'my-handler', { +new nodejs.NodejsFunction(this, 'my-handler', { bundling: { nodeModules: ['native-module', 'other-module'], }, @@ -174,11 +174,11 @@ The `NodejsFunction` construct exposes [esbuild options](https://esbuild.github. via properties under `bundling`: ```ts -new lambda.NodejsFunction(this, 'my-handler', { +new nodejs.NodejsFunction(this, 'my-handler', { bundling: { minify: true, // minify code, defaults to false sourceMap: true, // include source map, defaults to false - sourceMapMode: lambda.SourceMapMode.INLINE, // defaults to SourceMapMode.DEFAULT + sourceMapMode: nodejs.SourceMapMode.INLINE, // defaults to SourceMapMode.DEFAULT sourcesContent: false, // do not include original source into source map, defaults to true target: 'es2020', // target environment for the generated JavaScript code loader: { // Use the 'dataurl' loader for '.png' files @@ -189,14 +189,14 @@ new lambda.NodejsFunction(this, 'my-handler', { 'process.env.PRODUCTION': JSON.stringify(true), 'process.env.NUMBER': JSON.stringify(123), }, - logLevel: lambda.LogLevel.SILENT, // defaults to LogLevel.WARNING + logLevel: nodejs.LogLevel.SILENT, // defaults to LogLevel.WARNING keepNames: true, // defaults to false tsconfig: 'custom-tsconfig.json', // use custom-tsconfig.json instead of default, metafile: true, // include meta file, defaults to false banner: '/* comments */', // requires esbuild >= 0.9.0, defaults to none footer: '/* comments */', // requires esbuild >= 0.9.0, defaults to none - charset: lambda.Charset.UTF8, // do not escape non-ASCII characters, defaults to Charset.ASCII - format: lambda.OutputFormat.ESM, // ECMAScript module output format, defaults to OutputFormat.CJS (OutputFormat.ESM requires Node.js 14.x) + charset: nodejs.Charset.UTF8, // do not escape non-ASCII characters, defaults to Charset.ASCII + format: nodejs.OutputFormat.ESM, // ECMAScript module output format, defaults to OutputFormat.CJS (OutputFormat.ESM requires Node.js 14.x) mainFields: ['module', 'main'], // prefer ECMAScript versions of dependencies inject: ['./my-shim.js', './other-shim.js'], // allows to automatically replace a global variable with an import from another file esbuildArgs: { // Pass additional arguments to esbuild @@ -214,7 +214,7 @@ It is possible to run additional commands by specifying the `commandHooks` prop: ```text // This example only available in TypeScript // Run additional props via `commandHooks` -new lambda.NodejsFunction(this, 'my-handler-with-commands', { +new nodejs.NodejsFunction(this, 'my-handler-with-commands', { bundling: { commandHooks: { beforeBundling(inputDir: string, outputDir: string): string[] { @@ -256,7 +256,7 @@ In some cases, `esbuild` may not yet support some newer features of the typescri In such cases, it is possible to run pre-compilation using `tsc` by setting the `preCompilation` flag. ```ts -new lambda.NodejsFunction(this, 'my-handler', { +new nodejs.NodejsFunction(this, 'my-handler', { bundling: { preCompilation: true, }, @@ -270,7 +270,7 @@ Note: A [`tsconfig.json` file](https://www.typescriptlang.org/docs/handbook/tsco Use `bundling.environment` to define environments variables when `esbuild` runs: ```ts -new lambda.NodejsFunction(this, 'my-handler', { +new nodejs.NodejsFunction(this, 'my-handler', { bundling: { environment: { NODE_ENV: 'production', @@ -282,7 +282,7 @@ new lambda.NodejsFunction(this, 'my-handler', { Use `bundling.buildArgs` to pass build arguments when building the Docker bundling image: ```ts -new lambda.NodejsFunction(this, 'my-handler', { +new nodejs.NodejsFunction(this, 'my-handler', { bundling: { buildArgs: { HTTPS_PROXY: 'https://127.0.0.1:3001', @@ -294,7 +294,7 @@ new lambda.NodejsFunction(this, 'my-handler', { Use `bundling.dockerImage` to use a custom Docker bundling image: ```ts -new lambda.NodejsFunction(this, 'my-handler', { +new nodejs.NodejsFunction(this, 'my-handler', { bundling: { dockerImage: DockerImage.fromBuild('/path/to/Dockerfile'), }, @@ -314,7 +314,7 @@ By default the asset hash will be calculated based on the bundled output (`Asset Use the `assetHash` prop to pass a custom hash: ```ts -new lambda.NodejsFunction(this, 'my-handler', { +new nodejs.NodejsFunction(this, 'my-handler', { bundling: { assetHash: 'my-custom-hash', }, diff --git a/packages/@aws-cdk/aws-lambda-nodejs/rosetta/default.ts-fixture b/packages/@aws-cdk/aws-lambda-nodejs/rosetta/default.ts-fixture index d1ec43165548e..0414866994604 100644 --- a/packages/@aws-cdk/aws-lambda-nodejs/rosetta/default.ts-fixture +++ b/packages/@aws-cdk/aws-lambda-nodejs/rosetta/default.ts-fixture @@ -1,7 +1,7 @@ // Fixture with packages imported, but nothing else import { Construct } from 'constructs'; import { DockerImage, Stack } from '@aws-cdk/core'; -import * as lambda from '@aws-cdk/aws-lambda-nodejs'; +import * as nodejs from '@aws-cdk/aws-lambda-nodejs'; class Fixture extends Stack { constructor(scope: Construct, id: string) { diff --git a/packages/@aws-cdk/aws-lambda-python/README.md b/packages/@aws-cdk/aws-lambda-python/README.md index 52087e9654f8f..fc68cbce9d837 100644 --- a/packages/@aws-cdk/aws-lambda-python/README.md +++ b/packages/@aws-cdk/aws-lambda-python/README.md @@ -25,7 +25,7 @@ To use this module, you will need to have Docker installed. Define a `PythonFunction`: ```ts -new lambda.PythonFunction(this, 'MyFunction', { +new python.PythonFunction(this, 'MyFunction', { entry: '/path/to/my/function', // required runtime: Runtime.PYTHON_3_8, // required index: 'my_index.py', // optional, defaults to 'index.py' @@ -44,7 +44,7 @@ layer. Define a `PythonLayerVersion`: ```ts -new lambda.PythonLayerVersion(this, 'MyLayer', { +new python.PythonLayerVersion(this, 'MyLayer', { entry: '/path/to/my/layer', // point this to your library's directory }) ``` @@ -52,11 +52,11 @@ new lambda.PythonLayerVersion(this, 'MyLayer', { A layer can also be used as a part of a `PythonFunction`: ```ts -new lambda.PythonFunction(this, 'MyFunction', { +new python.PythonFunction(this, 'MyFunction', { entry: '/path/to/my/function', runtime: Runtime.PYTHON_3_8, layers: [ - new lambda.PythonLayerVersion(this, 'MyLayer', { + new python.PythonLayerVersion(this, 'MyLayer', { entry: '/path/to/my/layer', // point this to your library's directory }), ], @@ -123,7 +123,7 @@ Additional build args for bundling that refer to PyPI indexes can be specified a const entry = '/path/to/function'; const image = DockerImage.fromBuild(entry); -new lambda.PythonFunction(this, 'function', { +new python.PythonFunction(this, 'function', { entry, runtime: Runtime.PYTHON_3_8, bundling: { @@ -138,7 +138,7 @@ If using a custom Docker image for bundling, the dependencies are installed with const entry = '/path/to/function'; const image = DockerImage.fromBuild(entry); -new lambda.PythonFunction(this, 'function', { +new python.PythonFunction(this, 'function', { entry, runtime: Runtime.PYTHON_3_8, bundling: { image }, @@ -163,7 +163,7 @@ const codeArtifactAuthToken = execSync(`aws codeartifact get-authorization-token const indexUrl = `https://aws:${codeArtifactAuthToken}@${domain}-${domainOwner}.d.codeartifact.${region}.amazonaws.com/pypi/${repoName}/simple/`; -new lambda.PythonFunction(this, 'function', { +new python.PythonFunction(this, 'function', { entry, runtime: Runtime.PYTHON_3_8, bundling: { @@ -190,7 +190,7 @@ const codeArtifactAuthToken = execSync(`aws codeartifact get-authorization-token const indexUrl = `https://aws:${codeArtifactAuthToken}@${domain}-${domainOwner}.d.codeartifact.${region}.amazonaws.com/pypi/${repoName}/simple/`; -new lambda.PythonFunction(this, 'function', { +new python.PythonFunction(this, 'function', { entry, runtime: Runtime.PYTHON_3_8, bundling: { diff --git a/packages/@aws-cdk/aws-lambda-python/rosetta/default.ts-fixture b/packages/@aws-cdk/aws-lambda-python/rosetta/default.ts-fixture index 44f98d42e9d09..45e67ca866edc 100644 --- a/packages/@aws-cdk/aws-lambda-python/rosetta/default.ts-fixture +++ b/packages/@aws-cdk/aws-lambda-python/rosetta/default.ts-fixture @@ -2,7 +2,7 @@ import { Construct } from 'constructs'; import { DockerImage, Stack } from '@aws-cdk/core'; import { Runtime } from '@aws-cdk/aws-lambda'; -import * as lambda from '@aws-cdk/aws-lambda-python'; +import * as python from '@aws-cdk/aws-lambda-python'; class Fixture extends Stack { constructor(scope: Construct, id: string) {