Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/thebenforce/serverless-swagger-api
Simplifies the process of generating an API Gateway API from a swagger file.
https://github.com/thebenforce/serverless-swagger-api
aws aws-api-gateway aws-apigateway serverless serverless-framework swagger
Last synced: 4 months ago
JSON representation
Simplifies the process of generating an API Gateway API from a swagger file.
- Host: GitHub
- URL: https://github.com/thebenforce/serverless-swagger-api
- Owner: theBenForce
- Created: 2019-05-13T20:16:42.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2022-12-11T01:12:45.000Z (about 2 years ago)
- Last Synced: 2024-10-04T21:43:46.272Z (5 months ago)
- Topics: aws, aws-api-gateway, aws-apigateway, serverless, serverless-framework, swagger
- Language: TypeScript
- Homepage:
- Size: 1.4 MB
- Stars: 15
- Watchers: 1
- Forks: 7
- Open Issues: 25
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Serverless Swagger API
[data:image/s3,"s3://crabby-images/fe751/fe7519cd11cff1d0889eabb42a36174abac41d68" alt="Build Status"](https://travis-ci.org/drg-adaptive/serverless-swagger-api)
[data:image/s3,"s3://crabby-images/2aa79/2aa793ee83bd995285d11cb58455551a70889eb6" alt="Maintainability"](https://codeclimate.com/github/drg-adaptive/serverless-swagger-api/maintainability)
[data:image/s3,"s3://crabby-images/11c82/11c8282bd935aea81842b7139b3cf2e06c3c3bee" alt="npm version"](https://badge.fury.io/js/serverless-swagger-api)
[data:image/s3,"s3://crabby-images/15be8/15be860ca899e449d1d5c00e3cb7e4b3798009c6" alt="FOSSA Status"](https://app.fossa.io/projects/git%2Bgithub.com%2Fdrg-adaptive%2Fserverless-swagger-api?ref=badge_shield)This is a serverless plugin that simplifies the process of creating an AWS API Gateway from a swagger file.
## Installation
```bash
yarn add --dev serverless-swagger-api
```## Configuration
### Lambda Functions
You must manually create your own lambda functions in the serverless configuration. Once the methods are created, they will be referenced in the swagger file.
### Swagger File
Add a `x-lambda-name` property to every path method to bind a part of the api to a lambda. Values specified for `x-lambda-name` is AWS CloudFormation resource names, i.e., [values in the form of `{normalizedFunctionName}LambdaFunction`](https://www.serverless.com/framework/docs/providers/aws/guide/resources#aws-cloudformation-resource-reference). For more information about naming rules, please refer to the [description](https://www.serverless.com/framework/docs/providers/aws/guide/resources#override-aws-cloudformation-resource) in the Serverless Framework documentation.
```yaml
paths:
/testPath:
get:
x-lambda-name: TestPathLambdaFunction
...
```#### CORS Configuration
Add a `x-cors` property to the path you want to add CORS options responses to.
```yaml
paths:
/testPath:
x-cors: true
```If you want to specify a specific attribute, provide one of the following properties
| Property | Description | Default |
| -------- | ----------------------------------- | ------------------------------------------------------------- |
| origin | A string specifying allowed origins | \* |
| headers | An array of headers to be allowed | Constructed from the parameters property of every path method |
| methods | An array of methods to be allowed | Constructed by looking at all methods defined for a path |### Plugin Settings
Now you need to tell the swagger api plugin about your configuration file. Add a `swaggerApi` property to the custom section of your serverless configuration. You can add as many apis as you want by adding children to the `swaggerApi.apis` property.
#### updateDeployments
Will automatically update API gateway deployments if not set to `false`.
#### usePackageVersion
The `info.version` value in your OpenAPI file will be overwritten with the version in `package.json`.
#### apis
An object containing all of the APIs to be defined in this stack.
```yaml
custom:
swaggerApi:
updateDeployments: true
usePackageVersion: true
apis:
PrimaryApi:
Name: ${self:provider.stage}-${self:service}-PrimaryApi
Body: ${file(./some-swagger-file.yaml)}
Lambda: ExampleLambdaFunction
Stage: dev
```##### Properties
Each API object has the following properties
| Name | Required | Description |
| ------ | -------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| Name | Yes | Name of the API that will be used as the `Name` parameter when creating the `AWS::ApiGateway::RestApi` CloudFormation object |
| Body | Yes | The swagger/openapi file that defines the API |
| Stage | Yes | The name of the API Gateway stage that will be created |
| Lambda | No | Default lambda name that will be used if `x-lambda-name` isn't provided on a path (see the description of `x-lambda-name` for the value to be specified as the name) |## Created Resources
### IAM Roles
An IAM role is created for each API with the name `PrimaryApiServiceRole`## License
[data:image/s3,"s3://crabby-images/4dcd1/4dcd18c6161586bfb2b024c8b81a5e659e71fa14" alt="FOSSA Status"](https://app.fossa.io/projects/git%2Bgithub.com%2Fdrg-adaptive%2Fserverless-swagger-api?ref=badge_large)