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

hops-lambda

Package Overview
Dependencies
Maintainers
1
Versions
192
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

hops-lambda

Quick and easy deployment of Hops applications to AWS Lambda

  • 10.0.1
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
20
increased by81.82%
Maintainers
1
Weekly downloads
 
Created
Source

Hops Lambda

npm

Hops Lambda allows you to quickly deploy your hops application to AWS Lambda.

Quick Start

This is the minimal configuration required to get started with hops-lambda:

package.json

--- a/package.json
+++ b/package.json
@@ -6,5 +6,8 @@
   "config": {
     "hops": {
+      "assetPath": "prod",
+      "basePath": "prod",
       "browsers": "last 1 Chrome versions",
+      "node": "6.10.3",
       "locations": [
         "/",
@@ -22,4 +25,5 @@
   "dependencies": {
     "hops-express": "^9.0.0",
+    "hops-lambda": "^9.0.0",
     "hops-react": "^9.0.0",
     "hops-redux": "^9.0.0",

And then you need to provide your AWS credentials and region config (for example by exporting them in your terminal):

export AWS_ACCESS_KEY_ID=key
export AWS_SECRET_ACCESS_KEY=geheim
export AWS_REGION=eu-central-1

After that you can deploy by executing:

hops lambda deploy

In your terminal.

Installation

In order to use hops-lambda, you need to add it to your project dependencies.

npm install --save hops-lambda

or

yarn add hops-lambda

Also note, that hops-lambda has a peer dependency to hops-express which needs to be installed in your project too.

Configuration

In order to use hops-lambda you need to define the Node.js target version for which babel should transpile your code. Because the most recent Node.js version on AWS Lambda is v6.10.3 you need to set your node target in hops-config to 6.10.3.

{
  "config": {
    "hops": {
      "node": "6.10.3"
    }
  }
}

Available options through Hops npm config

The following options are supported in a hops-config aws object.

{
  "name": "foo",
  "version": "1.0.0",
  "config": {
    "hops": {
      "aws": {
        ...
      }
    }
  }
}
FieldTypeDescription
region*StringThe AWS Region in which the resources should be created. Defaults to us-east-1
uniqueNameStringA unique name, used as CloudFormation stack name and S3 bucket name. Defaults to hops-lambda-${packageJson.name}
memorySizeNumberThe memory allocated to your Lambda function. Defaults to 128. Valid values: (128 - 1536)
stageNameStringThe name of your API Gateway stage. Defaults to prod
domainNameStringA custom domain name. Defaults to ''
certificateArnStringIf you use a custom domain you need to specify the ARN of a SSL certificate in ACM. Defaults to ''
cloudformationTemplateFileStringPath to a custom CloudFormation template. Defaults to node_modules/hops-lambda/cloudformation.yaml
  • If the region is not set via hops config, it will try AWS_REGION and AWS_DEFAULT_REGION in your environment first, before defaulting to us-east-1.

If you use hops-lambda without a custom domain, you need to set your hops-config basePath and assetPath to the same value as your stageName (see above).

AWS Configuration

After you have configured your package.json (as described above), you also need to configure your AWS credentials.

To set-up your credentials in a ~/.aws/credentials file, please follow this article.

To set-up your credentials via environment variables, you can define the following variables:

  • AWS_ACCESS_KEY_ID
  • AWS_SECRET_ACCESS_KEY
  • AWS_SESSION_TOKEN (optional, only required for MFA)

Usage

Hops Lambda allows you to quickly deploy (and remove) your hops applications on AWS Lambda.

CLI

The hops-lambda package, when installed, adds a new hops lambda command, which contains two sub-commands:

  • hops lambda deploy
  • hops lambda destroy [--yes] [--keep-files] [--keep-bucket]

You can use the integrated help in the CLI to get more information on the available options.

Simple deployment

To quickly deploy a Hops application to AWS Lambda you need to have your AWS credentials set up (see AWS Configuration above). And you also need to have basePath and assetPath set to prod (or your configured stageName, if you have a differently named stage).

Then execute:

hops lambda deploy

To update your application, simply do your code changes and execute hops lambda deploy again and it will only update the parts that have changed since your last deployment.

Custom Domain

If you want your application to be available on a custom domain, you need to have your AWS credentials set up (see AWS Configuration above). And you also need to configure domainName and certificateArn. Optionally you can set a custom basePath and assetPath if you want your application to be available on a different path.

Create / Upload Certificate in AWS Certificate Manager (ACM)

In order to use a custom domain name for your Hops application, you need to create or import an SSL certificate in the AWS Certificate Manager.

Check out the documentation of ACM, especially the sections about importing or requesting a certificate.

Important: Even if you deploy your application in a different region, you need to import or request the certificate in the region us-east-1 (see the section about CloudFront and ACM here).

Set-up DNS records

Once you have imported or requested a certificate in ACM, you need to configure its ARN and your custom domain name in your package.json config (see the config section above).

Then, after you execute hops lambda deploy you will get an output with a CloudFront distribution address, which you need to configure with your DNS provider as an A-record or CNAME. Read more about it here.

Advanced configuration

Multi-Stage deployment

At the moment it is not possible to do a multi-stage deployment with a single CloudFormation stack.
If you want to do it however, you need to create multiple stacks, for example by changing the package.jsons name field or the AWS configs uniqueName value and then execute hops lambda deploy again.

Custom CloudFormation template

In case you need additional resources in your CloudFormation template, you can specify the cloudformationTemplateFile value in your AWS config to overwrite the built-in CloudFormation template.

It will get executed with the default parameter values, but you can overwrite these or specify additional parameters by using the deploy(options, parametersOverrides) API (see next section).

API

The hops-lambda package exports two methods: deploy() and destroy():

deploy(options, parametersOverrides)

deploy(options, parametersOverrides) can be called programmatically to deploy an Hops application to AWS Lambda.

It accepts two arguments options and parametersOverrides - right now options is unused, but reserved for future options coming through CLI arguments.

parametersOverrides is an object, where the key is the name of the Parameters defined in the CloudFormation template and the value is its corresponding value. These get merged with the default parameters and can be used to overwrite specific parameters or implement new ones in case you overwrite the entire CloudFormation template (see Advanced configuration above).

The deploy() method returns a Promise-chain that returns the Outputs of the CloudFormation stack and could be used to schedule further work, if needed.

destroy(options)

destroy(options) can be called programmatically to delete the CloudFormation stack and the associated S3 bucket that has been created by deploy().

Its options argument is an object with the parsed CLI parameters (currently keepBucket: boolean, keepFiles: boolean and yes: boolean. All of them default to false).

It returns a Promise-chain that can be used to schedule further work after successfully deleting the stack and/or S3 buckets.

Keywords

FAQs

Package last updated on 09 Feb 2018

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