swagger-manage-extensions
v1.0.4
Published
Swagger Manage Extensions - merge/split API Description and AWS API Gateway Integration
Downloads
4
Readme
Swagger Manage Extensions
This tool help have separate definition API and AWS API Gateway into 2 files and merge them for usage in AWS API Gateway.
Installation
npm install swagger-manage-extensions
Usage
We have separate API in Swagger format and definition for AWS Gateway Integration in another file:
Swagger file
---
swagger: "2.0"
info:
version: "2016-04-29T09:09:33Z"
title: "api-client"
host: "api-behind-aws-gateway.example.com"
schemes:
- "https"
paths:
/get/{vanity}:
get:
produces:
- "application/json"
parameters:
- name: "authentication"
in: "header"
required: true
type: "string"
- name: "vanity"
in: "path"
required: true
type: "string"
responses:
200:
description: "200 response"
schema:
$ref: "#/definitions/apiClientReponse"
/publish/{vanity}:
post:
produces:
- "application/json"
parameters:
- name: "content_type"
in: "header"
required: false
type: "string"
- name: "authentication"
in: "header"
required: true
type: "string"
- name: "accept"
in: "header"
required: false
type: "string"
- name: "vanity"
in: "path"
required: true
type: "string"
- name: "user_agent"
in: "header"
required: false
type: "string"
responses:
200:
description: "200 response"
schema:
$ref: "#/definitions/apiClientReponse"
definitions:
apiClientReponse:
type: "object"
required:
- "code"
- "error"
- "message"
properties:
error:
type: "boolean"
message:
type: "string"
code:
type: "string"
Extensions definitions file
---
paths:
/get/{vanity}:
get:
x-amazon-apigateway-integration:
responses:
default:
statusCode: "200"
requestParameters:
integration.request.path.vanity: "method.request.path.vanity"
integration.request.header.authentication: "method.request.header.authentication"
httpMethod: "GET"
uri: "https://api.example.com/get/{vanity}"
type: "http"
/publish/{vanity}:
post:
x-amazon-apigateway-integration:
responses:
default:
statusCode: "200"
requestParameters:
integration.request.path.vanity: "method.request.path.vanity"
integration.request.header.authentication: "method.request.header.authentication"
httpMethod: "POST"
uri: "https://api.example.com/publish/{vanity}"
type: "http"
We don't need integration details in generated documentation (for example: apiary.io).
Import to AWS API Gateway
Out scripts merge files together and after than import them into AWS API Gateway.
var sme = require('swagger-manage-extensions');
var fs = require('fs');
var apiPath = "./test/fixtures/api.yml";
var extensionsPath = "./test/fixtures/extensions.yml";
fs.writeFileSync('api-full.yml', sme.merge( apiPath, extensionsPath));
Import to AWS API Gateway using awscli.
aws apigateway put-rest-api --rest-api-id $1 --mode overwrite --parameters {\"extensions\":\"integrations\"} --body file://./api.json
Export from AWS API Gateway
Export swagger file from AWS API Gateway using awscli.
aws apigateway get-export --parameters {\"extensions\":\"integrations\"} --rest-api-id $1 --stage-name $2 --export-type swagger --accepts application/yml api.yml
You can use tool to split files:
var sme = require('swagger-manage-extensions');
var fs = require('fs');
var apiPath = "./test/fixtures/expected.yml";
var output = sme.split(apiPath);
fs.writeFileSync('extensions.yml', output.extensions);
fs.writeFileSync('api.yml', output.api);
CLI
bin/sme split api-full.yml api.yml extensions.yml
bin/sme merge api.yml extensions.yml api-full.yml