Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

aws-websocket-sam-helper

Package Overview
Dependencies
Maintainers
1
Versions
5
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

aws-websocket-sam-helper

Tools to allow websocket routes to be described in JSON to simplify SAM template assembly.

  • 1.1.0
  • latest
  • npm
  • Socket score

Version published
Weekly downloads
1
decreased by-90.91%
Maintainers
1
Weekly downloads
 
Created
Source

aws-websocket-sam-helper

This module will allow you to use json files to decorate your serverless code. Those json files will be used to generate out a valid SAM Template.

tldr; Check out the simple example here https://github.com/dsandor/ws-sam-helper-example

Place your function.json description file next to your code so it makes it simple to add a new function to your API Gateway and no more cutting and pasting large chunks of YAML in your sam template.

Here is an example of a Web Socket API Gateway route handler.

{
  "functionName": "GetUserFunction",
  "routeKey": "get-user",
  "apiId": "ApiBuiltBySamHelper",
  "handler": "user/index.getHandler",
  "codeUri": "./",
  "policies": ["AmazonAPIGatewayInvokeFullAccess", "AmazonAPIGatewayAdministrator"]
}

That little description will generate out all of this YAML for you:

  # Route
  #===========================
  #  Key: get-user route handler
  #  Handler: GetUserFunction
  #===========================
  GetUserFunctionRoute:
    Type: AWS::ApiGatewayV2::Route
    Properties:
      ApiId: !Ref ApiBuiltBySamHelper
      RouteKey: get-user
      AuthorizationType: NONE
      OperationName: GetUserFunctionRoute
      Target: !Join
        - '/'
        - - 'integrations'
          - !Ref GetUserFunctionInteg

  GetUserFunctionInteg:
    Type: AWS::ApiGatewayV2::Integration
    Properties:
      ApiId: !Ref ApiBuiltBySamHelper
      Description: GetUserFunction Integration
      IntegrationType: AWS_PROXY
      IntegrationUri:
        Fn::Sub:
          arn:aws:apigateway:${AWS::Region}:lambda:path/2015-03-31/functions/${ GetUserFunction.Arn }/invocations

  GetUserFunctionPermission:
    Type: AWS::Lambda::Permission
    DependsOn:
      - ApiBuiltBySamHelper
      - GetUserFunction
    Properties:
      Action: lambda:InvokeFunction
      FunctionName: !Ref GetUserFunction
      Principal: apigateway.amazonaws.com

  GetUserFunction:
    Type: AWS::Serverless::Function
    Properties:
      Handler: user/index.getHandler
      Timeout: 30
      Runtime: nodejs8.10
      CodeUri: ./
      Policies:
        - AmazonAPIGatewayInvokeFullAccess
        - AmazonAPIGatewayAdministrator

You can also define the API Gateway API in your package.json file with this simple little addition:

 "api": [
    {
      "apiId": "ApiBuiltBySamHelper",
      "apiName": "my-api-from-sam",
      "stageName": "v1",
      "stageDescription": "Version 1 of the api.",
      "routeSelectionExpression": "$request.body.action",
      "type": "websocket"
    }
  ]

The function.json and addition to the package.json file generates 82 lines of syntatcitcally correct SAM Template YaML.

Watch the video below to see the helper in action.

asciicast


Installation

Install the helper into your serverless application.

yarn add aws-websocket-sam-helper

Optionally, you may want to add to your package.json a scripts entry that lets you run the helper.

"scripts": {
    "generate-sam-template": "sam-helper"
}

This will allow you to regenerate your template.yaml file with the command:

yarn generate-sam-template

Usage

You need to describe your API Gateway and your Functions. Everything else will be handled for you.

Describe API Gateway

Add an api key to your package.json file to describe your API Gateway(s).

"api": [
    {
      "apiId": "ApiBuiltBySamHelper",
      "apiName": "my-api-from-sam",
      "stageName": "v1",
      "stageDescription": "Version 1 of the api.",
      "routeSelectionExpression": "$request.body.action",
      "type": "websocket"
    }
  ]
propertydescription
apiIdThis is the identifier for this API Gateway. When describing a Function you will refer to this ID. This ID is only used when creating relationships in your template.yaml file.
apiNameThis name will display in your AWS API Gateway Console. You must name the API so that it meeds the api name constraints.
stageNameWhen deploying, what is the name of the stage. This is the start of your API Gateway URL.
stageDescriptionDescribe the stage.
routeSelectionExpressionSee the API Gateway documentation for this. This expression describes where in the WebSocket message to look for a value which will contain your route key.
typewebsocket or rest, currently only websocket is supported at this time.

Describe a Function

Anywhere in your project folder structure you can define function.json files (or *.function.json). The contents of this file describe your Lambda function and relate it to an API Gateway Route or Endpoint.

{
  "functionName": "GetUserFunction",
  "routeKey": "get-user",
  "apiId": "ApiBuiltBySamHelper",
  "handler": "user/index.getHandler",
  "codeUri": "./",
  "policies": ["AmazonAPIGatewayInvokeFullAccess", "AmazonAPIGatewayAdministrator"]
}

For example, if you have a sub folder in your project named user and you have an index.js file that defines your Lambda with an export named getHandler the above json file will hook it up to your API Gateway named ApiBuildBySamHelper.

propertydescriptiondefaultrequired
functionNameA YAML compatible function name. This is used in the SAM Template to refer to your function. It is suggested to use a Proper or Camel case syntax of just upper and lower case letters.yes
routeKeyFor a web socket route handler this is the key that will route a message to this lambda.yes (for websocket)
apiIdThe api id you configured in your package.json to identify the api gateway. This connects this function to the APIGWyes
handlerThis is the location of the exported lambda function. Note the format is {relative_file_path}/{javascript_file_name}.{exported_function_name}index.handlerno
codeUriDefined the root of the deployed lambda code../no
policiesAny AWS Policies you want defined on your lambda.no
timeoutMax time in seconds that your Lambda can stay alive.30no
runtimeAny valid Lambda Runtime value.nodejs8.10no
environmentVariablesAn object representing key value pairs of Environment Variables you wish to add to the Lambda. ex: { name: 'NODE_ENV', value: 'dev' }no

Command Line Arguments

The way you use sam-helper is customizable. Executing sam-helper with no arguments uses a sane set of default values which should cover most situations. However, for the more advanced users you can also do things like use your own handlebars formatted YaML snippets to compose your template.yaml or output the rendered yaml to a file of your choosing.

argumentdescription
-VVersion. Display the version of the sam-helper.
-t or --template-pathThe directory containing your custom template files.
--no-write-fileOnly output the rendered template to the console.
--output-filenameThe name of the file to write the rendered template to. Default value is template.yaml
--starting-pathThe starting path to search for *function.json files in your project. Default value is . (your project root)
--api-definition-fileA file that contains your api definitions. If not specified, your package.json is inspected for an api property and tht is used.
Examples

Use your own template files:

sam-helper --template-path ./my-templates

Only write output to console:

sam-helper --no-write-file

Start looking for source code in a sub directory on your project:

sam-helper --starting-path ./src/lambdas

NOTE: by default the cli will search all folders in your project root and every sub directory included in them. Skipping node_modules

FAQs

Package last updated on 01 Apr 2019

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc