Skip to content

katallaxie/serverless-dart

Repository files navigation

⚡ 🎯

serverless-dart

A ⚡ Serverless framework ⚡ plugin for Dart applications


📦 Install

Install the plugin inside your serverless project with npm.

$ npm i -D serverless-dart

💡 The -D flag adds it to your development dependencies in npm speak

💡 This plugin assumes you are using Dart Runtime for AWS Lambda coding your applications.

Add the following to your serverless project's serverless.yml file

service: hello
provider:
  name: aws
  runtime: dart
plugins:
  # this registers the plugin
  # with serverless
  - serverless-dart
# creates one artifact for each function
package:
  individually: true
functions:
  hello:
    # the first part of the handler refers to the script lib/main.dart.
    # main.hello identifies the handler to execute in the Dart runtime.
    # The runtime supports multiple handlers
    # The plugin is smart to not rebuild those scripts with multiple handlers.
    handler: main.hello
    events:
      - http:
          path: /hello
          method: GET

💡 The Dart Runtime for AWS Lambda requires a binary named bootstrap. This plugin renames the binary that is generated to bootstrap for you and zips that file.

The default behavior is to build your Lambda inside a Docker container. Make sure you get Docker.

🤸 Usage

Every serverless workflow command should work out of the box.

package your Lambdas

$ npx serverless deploy

deploy your Lambdas

$ npx serverless deploy

👨‍💻 Development

Clone the repository

$ git clone https://github.com/katallaxie/serverless-dart

Link the package

$ npm link

Link the package to your testing environment

$ npm link serverless-dart

📃 License

Apache 2.0

We 💙 Dart.