Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/floydspace/aws-lambda-nodejs-esbuild
λ💨 AWS CDK Construct to bundle JavaScript and TypeScript AWS lambdas using extremely fast esbuild.
https://github.com/floydspace/aws-lambda-nodejs-esbuild
aws aws-cdk aws-lambda aws-lambda-node builder bundler cdk-construct construct esbuild lambda typescript
Last synced: 2 months ago
JSON representation
λ💨 AWS CDK Construct to bundle JavaScript and TypeScript AWS lambdas using extremely fast esbuild.
- Host: GitHub
- URL: https://github.com/floydspace/aws-lambda-nodejs-esbuild
- Owner: floydspace
- License: mit
- Created: 2020-10-24T23:37:39.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2021-07-19T10:57:57.000Z (over 3 years ago)
- Last Synced: 2024-10-29T22:45:11.273Z (3 months ago)
- Topics: aws, aws-cdk, aws-lambda, aws-lambda-node, builder, bundler, cdk-construct, construct, esbuild, lambda, typescript
- Language: TypeScript
- Homepage: https://floydspace.github.io/aws-lambda-nodejs-esbuild/
- Size: 73.2 KB
- Stars: 68
- Watchers: 6
- Forks: 3
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome-cdk - aws-lambda-nodejs-esbuild - Alternative Node.js lambda CDK construct, using [esbuild](https://github.com/evanw/esbuild). (Language Support / Multi-accounts setup)
- awesome-esbuild - aws-lambda-nodejs-esbuild
README
λ💨 aws-lambda-nodejs-esbuild
==============[AWS CDK](https://aws.amazon.com/cdk/) Construct to build Node.js AWS lambdas using [esbuild](https://esbuild.github.io).
![CDK Construct NodeJS](https://img.shields.io/badge/cdk--construct-node.js-blue?logo=amazon-aws&color=43853d)
[![Build Status](https://img.shields.io/github/workflow/status/floydspace/aws-lambda-nodejs-esbuild/release)](https://github.com/floydspace/aws-lambda-nodejs-esbuild/actions)
[![Coverage Status](https://coveralls.io/repos/github/floydspace/aws-lambda-nodejs-esbuild/badge.svg?branch=master)](https://coveralls.io/github/floydspace/aws-lambda-nodejs-esbuild?branch=master)
[![npm version](https://badge.fury.io/js/aws-lambda-nodejs-esbuild.svg)](https://badge.fury.io/js/aws-lambda-nodejs-esbuild)
[![semantic-release](https://img.shields.io/badge/%20%20%F0%9F%93%A6%F0%9F%9A%80-semantic--release-e10079.svg)](https://github.com/semantic-release/semantic-release)
[![Mentioned in Awesome CDK](https://awesome.re/mentioned-badge.svg)](https://github.com/kolomied/awesome-cdk)Table of Contents
-----------------
- [Features](#features)
- [Installation](#installation)
- [Configure](#configure)
- [Usage](#usage)
- [Author](#author)Features
--------* Zero-config: Works out of the box without the need to install any other packages
* Supports ESNext and TypeScript syntax with transforming limitations (See *Note*)*Note*: The default JavaScript syntax target is set to [`ES2017`](https://node.green/#ES2017), so the final bundle will be supported by all [AWS Lambda Node.js runtimes](https://docs.aws.amazon.com/lambda/latest/dg/lambda-runtimes.html). If you still using an old lambda runtime and have to respect it you can play with esbuild `target` option, see [JavaScript syntax support](https://esbuild.github.io/content-types/#javascript) for more details about syntax transform limitations.
Installation
------------```sh
yarn add --dev @aws-cdk/aws-lambda aws-lambda-nodejs-esbuild
# or
npm install -D @aws-cdk/aws-lambda aws-lambda-nodejs-esbuild
```Configure
---------By default, no configuration required, but you can change esbuild behavior:
```ts
import * as cdk from '@aws-cdk/core';
import { NodejsFunction } from 'aws-lambda-nodejs-esbuild';class NewStack extends cdk.Stack {
constructor(scope, id, props) {
super(scope, id, props);new NodejsFunction(this, 'NewFunction', {
esbuildOptions: {
minify: false, // default
target: 'ES2017',
}
});
}
}
```Check [esbuild](https://esbuild.github.io/api/#simple-options) documentation for the full list of available options. Note that some options like `entryPoints` or `outdir` cannot be overwritten.
The package specified in the `exclude` option is passed to esbuild as `external`, but it is not included in the function bundle either. The default value for this option is `['aws-sdk']`.Usage
-----The normal AWS CDK deploy procedure will automatically compile with `esbuild`:
- Create the AWS CDK project with `cdk init app --language=typescript`
- Install `aws-lambda-nodejs-esbuild` as above
- Deploy with `cdk deploy`See examples: [minimal](examples/minimal/README.md) and [complete](examples/complete/README.md)
Author
------[Victor Korzunin](https://floydspace.github.io/)