Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ahrefs/bs-aws-lambda
aws lambda bucklescript bindings
https://github.com/ahrefs/bs-aws-lambda
Last synced: 3 months ago
JSON representation
aws lambda bucklescript bindings
- Host: GitHub
- URL: https://github.com/ahrefs/bs-aws-lambda
- Owner: ahrefs
- License: mit
- Created: 2018-02-20T23:28:41.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2021-12-03T16:27:38.000Z (about 3 years ago)
- Last Synced: 2024-10-01T15:05:22.247Z (3 months ago)
- Language: Reason
- Size: 72.3 KB
- Stars: 38
- Watchers: 32
- Forks: 8
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# bs-aws-lambda
`bs-aws-lambda` is a set of types to use when creating [AWS
lambda](http://docs.aws.amazon.com/lambda) handlers.Those types are inspired by the
[`@types/aws-lambda`](https://www.npmjs.com/package/@types/aws-lambda)
package with typescript types.## Installation
```
yarn add @ahrefs/bs-aws-lambda
```or to follow the master version:
```
yarn add https://github.com/ahrefs/bs-aws-lambda.git
```## Usage
Add `@ahrefs/bs-aws-lambda` to the `bs-dependencies` of `bsconfig.json`.
Then when you create a function handler for a lambda, you can annotate
it with one of `AwsLambda.Scheduled.handler`,
`AwsLambda.Dynamodb.streamHandler`, `AwsLambda.Sns.handler`, etc. This
way you are sure to expose a function which respect the signature
expected by Lambda and you get types information for all the
parameters this function will receive.## Example
A full example is documented
[here](https://tech.ahrefs.com/create-aws-lambda-using-reasonml-and-bucklescript-15a0820ff55b). It
is using the sources from the [`example`](example) directory.Simple echo function for the API Gateway. This might seem a little
verbose compare to a typescript version. But using this package, you
are sure to handle all the possible cases where a value is actually
null or base64 encoded. Plus the returned object given to the callback
will always have the expected fields and types.```reason
let handler: AwsLambda.APIGatewayProxy.handler =
(event, _context) => {
open AwsLambda.APIGatewayProxy;let parameter =
event
->Event.queryStringParametersGet
->Js.Nullable.toOption
->Belt.Option.flatMap(params => Js.Dict.get(params, "userid"));switch (parameter) {
| Some(userid) => Js.log2("executing lambda for", userid)
| None => Js.log("executing lambda for anonymous user")
};let result =
switch (event->Event.bodyGet->Js.Nullable.toOption) {
| None =>
Js.log("error: no body available in the request");
result(
~body=`Plain({|{"status": "no body available in the request"}|}),
~statusCode=400,
(),
);
| Some(body) =>
Result.make(
~statusCode=200,
~body,
~isBase64Encoded=event->Event.isBase64EncodedGet,
(),
)
};Js.Promise.resolve(result);
};
```The typescript equivalent of the type annotation is actually more verbose:
```typescript
export const handle: Lambda.APIGatewayProxyHandler = async (
event: Lambda.APIGatewayEvent,
context: Lambda.Context,
cb: Lambda.APIGatewayProxyCallback) => {
}
```