REST PATCH to DynamoDB via Lambda
npm install marchio-lambda-patchmarchio-lambda-patch
==
REST PATCH to DynamoDB via Lambda
--
$ npm init
$ npm install marchio-lambda-patch --save
*
*
* __marchio-lambda-post__
* __marchio-lambda-get__
* __marchio-lambda-put__
* __Create an API with Lambda Proxy Integration through a Proxy Resource__
* A Lambda Function in Node.js for Proxy Integration
* Build an API Gateway API Using Proxy Integration and a Proxy Resource
* Create and Test an API with HTTP Proxy Integration through a Proxy Resource
*
#### Create Test Role
* Browse to: https://console.aws.amazon.com/iam/
* Click: __Roles__ (from the left column)
* Click: __Create new role__
* __Step 1: Select role type__
* Expand Section: __AWS Service Role__
* For __AWS Lambda__, click: __Select__
* __Step 2__ is automatically skipped
* __Step 3: Attach policy__
Select both __AmazonDynamoDB__ policies
* Click: __Next Step__
* Create a name for the role (like __lambda-db-patch__)
* Click: __Create role__
#### Create Lambda Function
* Browse to: https://console.aws.amazon.com/lambda
* Click: __Create a Lambda Function__
* Select: __Blank Function__
* Click: __Next__
* Name: __marchio-patch__
* Description: __Marchio service__
* Runtime: __Node.js 4.3__
* Set the Role
* Role: __Choose an existing role__
Existing role: (name of role you created earlier*)
* Click: __Next__
* Click: __Create Function__
#### Setup API Gateway
* Browse to: https://console.aws.amazon.com/apigateway
* Click: __Create API__
* Select: __New API__
* API name: __marchio-patch__
* Description: __Marchio service__
* Click: __Create API__
* Click on the slash (__/__)
* Drop down: __Actions__
* Select: __Create Resource__
* Check: __Configure as proxy resource__
* (Optionally enabled __CORS__)
* Click: __Create Resource__
* For __Integration type__ select: __Lambda Function Proxy__
* Lambda Region: For example: __us-east-1__
* Lambda Function: __marchio-patch__
* Click: __Save__
* Add Permission to Lambda Function: __OK__
* Drop down: __Actions__
* Select: __Deploy API__
* Define a new stage (call it "test")
* Click: __Deploy__
* Save the __Invoke URL__
#### Create DynamoDB Table
* Browse to: https://console.aws.amazon.com/dynamodb/
* Click: __Create Table__
* Table name: __mldb__
* Primary key: __eid__
* The type should be the default (string)
* Click: __Create__
* After some churning, click the __Capacity__ tab
* Set the __Read / Write capacity units__ to __1__ to save money while testing
* Click: __Save__
#### Example and Deploy
See the deployment example located in the repo under:
* examples/deploy
It contains a deployment script and an example lambda source file.
* Install the dependencies by running:
```
$ npm install
To run the script you must first make it runnable:
``
$ chmod +x deploy-lambda.sh
To test:
* Deploy the API via API Gateway
* Create an environment variable called __AWS\_HOST\_MARCHIO\_PATCH__ which is set to the invocation url
* Test the deployment using __curl__:
``
$ curl -i -X PATCH -H "Content-Type: application/json" \
-d '[{"op":"replace","path":"/status","value":"PATCH"}]' \
$AWS_HOST_MARCHIO_PATCH/test/marchio-patch/ac7e281f-33f9-4872-9c06-5703999e2d42
* The response should contain a 204 status code.
* Browse the DynamoDB table to see the updated record.
*
Module
Factory module
Kind: static method of marchio-lambda-patch-factory
Returns: Promise - that resolves to {module:marchio-lambda-patch}
| Param | Type | Description |
| --- | --- | --- |
| spec | Object | Named parameters object |
| spec.event | Object | Lambda event |
| spec.context | Object | Lambda context |
| spec.callback | function | Lambda callback |
| spec.model | Object | Table model |
Example (Usage example)
`js
// Lambda root file
"use strict";
var mlFactory = require('marcio-lambda-patch');
exports.handler = function(event, context, callback) {
var model = {
name: 'mldb', // must match DynamoDB table name
partition: 'eid', // primary partition key - cannot be reserved word (like uuid)
// sort: 'gid',
fields: {
eid: { type: String },
// gid: { type: String },
email: { type: String, required: true },
status: { type: String, required: true, default: "NEW" },
// Password will be (fake) hashed by filter before being saved
password: { type: String, select: false }, // select: false, exclude from query results
}
};
mlFactory.create({
event: event,
context: context,
callback: callback,
model: model
})
.catch(function(err) {
callback(err);
});
};
``
*
To test, go to the root folder and type (sans __$__):
$ npm test
*
* bitbucket.org/mitchallen/marchio-lambda-patch.git
* github.com/mitchallen/marchio-lambda-patch.git
*
In lieu of a formal style guide, take care to maintain the existing coding style.
Add unit tests for any new or changed functionality. Lint and test your code.
*
#### Version 0.3.2
* updated test case
#### Version 0.3.1
* updated deploy example with latest build
#### Version 0.3.0
* removed model/table name from url
* updated example deployment url's
#### Version 0.2.1
* updated deploy example
#### Version 0.2.0
* model.primary is now model.partition
* now supports databases with a sort key
#### Version 0.1.1
* added description to package.json
#### Version 0.1.0
* initial release
*