This repo demonstrates an API built with the Serverless framework. Serverless facilitates the building of APIs and apps using AWS Lambdas and the AWS API Gateway. It also allows for the creation and configuration of related AWS infrastructure, such as DynamoDB tables.
This demo is an API to let team membes give daily status reports, similar to what you would do in an agile stand up meeting, but for distributed teams. It was inspired by the excellent Serverless demo over at Serverless Stack. Thanks guys!
- Clone the repo into a local directory:
git clone git@github.com:john/typeup-api-serverless.git
cd typeup-api-serverless
- The app has been tested to work with node 8.4.0 and Serverless 1.21
- If you haven't already, install node and npm. Guide for installation on Mac here
- Install packages:
- npm init -y
- npm install serverless -g
- npm install serverless-webpack --save-dev
- npm install aws-sdk --save-dev
- npm install amazon-cognito-identity-js --save
- npm install uuid --save
- npm install --save-dev
babel-core
babel-loader
babel-plugin-transform-runtime
babel-preset-es2015
babel-preset-stage-3
serverless-webpack
glob
webpack
webpack-node-externals
- npm install --save babel-runtime
- Make sure you have an active AWS account with valid credentials set up. For more info see the AWS Quick Configuration guide.
Deployment of the API creates an API Gateway endpoint, two DynamoDB tables, and an S3 bucket. When installing and configuring the TypeUp client to use the API, you'll need to enter the endpoint into the client configuration.
-
Make sure credentials are set up. If you have a ~/.aws/credentials file, make sure it has a default value. To create that file, run:
serverless config credentials --provider aws --key your-key-here --secret your-secret-here
-
In working directory, run:
- For test env:
serverless deploy --stage test --tag {some_unique_value}
- For prod env:
serverless deploy --stage prod --tag {some_unique_value}
Set "some_unique_value" to a... unique value. This is to ensure unique names for S3 buckets created.
- For test env:
-
For more info see: http://serverless-stack.com/chapters/deploy-the-apis.html
- Deploy test env:
serverless deploy --stage test --tag {some_unique_value}
- To run test independently:
serverless webpack invoke --function status-create --path mocks/status-create-event.json --stage test
serverless webpack invoke --function status-get --path mocks/status-get-event.json --stage test
serverless webpack invoke --function user-create --path mocks/user-create-event.json --stage test
serverless webpack invoke --function user-get --path mocks/user-get-event.json --stage test
serverless webpack invoke --function user-statuses --path mocks/user-get-event.json --stage test
To remove the app (deletes all tables, lambdas, and buckets, forever):
serverless remove --stage prod
-
The client is doing the authing right now. How to protect the API? Actually maybe already done
-
https://aws.amazon.com/blogs/mobile/integrating-amazon-cognito-user-pools-with-api-gateway/
-
serverless.yml should create the S3 bucket for uploads
-
Parameterize region used in serverless.yml, create.js, dynamodb-lib.js
-
Add Groups support
-
Add SES emails to ask users who haven't sent a status yet to do so.
- Run weekdays at 11
-
Another notification to everyone when all statuses are collected
-
Give users a profile page, let them:
- Turn notifications off (set themselves to inactive)
- See groups they belong to
- See past statuses
- For new deploy, remember you need to edit the Cognito policy document: http://serverless-stack.com/chapters/create-a-cognito-identity-pool.html