Make setting up Lambda microservices easier than ever. alanajs is a free, open-source npm package that consolidates functionality provided by AWS SDK and AWS CLI, automating deployment and configuration tasks by making intelligent assumptions about the deployment sequence according to best practices. alanajs makes it easy to deploy Lambda functions with dependencies and layers, and it also simplifies creating routes, APIs, and integrations with Lambda on AWS API Gateway.
Here is a Medium article describing the story behind alanajs.
You can also visit us here.
Table of Contents
This section describes the instructions for end users who would like to download the package and connect their AWS account. For developers who would like to contribute to the open-source project, follow these instructions.
-
Install alanajs as a package dependency.
npm install alanajs
-
Update the
.env
file in the project root directory with the necessary credentials OR see Step 3 to init through the command line.AWS_ACCESS_KEY_ID= AWS_SECRET_ACCESS_KEY= AWS_REGION= ROLENAME= S3BUCKETNAME= AWS_ACCOUNT= FOLDER=
-
Run the follow through the command line to update .env file or create one if it does not exist. Replace the parameters with user's details. Refer to documentation for more details. The DIRECTORY is the main folder to store files, dependencies, and directories as Lambda functions and layers.
alana init <AWS_ACCESS_KEY_ID> <AWS_SECRET_ACCESS_KEY> [AWS_ACCOUNT] [AWS_REGION] -r [ROLENAME] -b [S3BUCKETNAME] -d [DIRECTORY]
-
Import the package to start using alana methods.
import 'alana' from 'alanajs';
-
That's it! You are ready to start running code through the command line or by running node [fileName] to execute the functions.
Figure 1: Create and Update Lambda Function
Figure 2: Create and Update Lambda Layers
Figure 3: Create, Update and Delete Alias
Figure 4: Create, Update and Delete API Gateway
Figure 5: Create, Update and Delete Routes
This section describes the instructions for developers who would like to contribute to the open-source project. For users who would like to download the package and connect their AWS account, follow these instructions instead.
The alanajs application was built using the following:
-
Fork the project.
-
Create a feature branch.
git checkout -b feature/featureName
-
Install package dependencies.
npm install
-
Update the
.env
file in the project root directory with the necessary credentials OR init through the command line.AWS_ACCESS_KEY_ID= AWS_SECRET_ACCESS_KEY= AWS_REGION= ROLENAME= S3BUCKETNAME= AWS_ACCOUNT= FOLDER=
alana init <AWS_ACCESS_KEY_ID> <AWS_SECRET_ACCESS_KEY> [AWS_ACCOUNT] [AWS_REGION] -r [ROLENAME] -b [S3BUCKETNAME] -d [DIRECTORY]
-
Add and commit your changes.
git add ... git commit -m 'Add some feature functionality'
-
Push to the branch.
git push origin feature/featureName
-
Open a Pull Request here.
Bugs are tracked through GitHub issues. Create an issue on our repository and provide the following information based on this template:
- Descriptive title: Provide a descriptive title for your issue.
- Describe the issue: Describe the steps you took leading up to the issue. Try to provide code or screenshots.
- Expected behavior: Describe the expected behavior.
Project Links: Github | Linkedin | Medium | Visit Us
Distributed under the MIT License. See the LICENSE for details