forked from Hatch-Team/serverless-openapi-documentation
-
Notifications
You must be signed in to change notification settings - Fork 8
/
serverless.yml
91 lines (86 loc) · 2.72 KB
/
serverless.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
service: serverless-openapi-doc-demo
frameworkVersion: ">=1.1.0 < 2.0.0"
provider:
name: aws
runtime: nodejs6.10
plugins:
- serverless-openapi-documentation
functions:
createUser:
handler: handler.create
events:
- http:
path: create
method: post
authorizer:
name: customAuth
documentation:
summary: Create User
description: Creates a user and then sends a generated password email
requestBody:
description: A user information object
requestModels:
application/json: PutDocumentRequest
pathParams:
- name: username
description: The username for a user to create
schema:
type: string
pattern: "^[-a-z0-9_]+$"
queryParams:
- name: membershipType
description: The user's Membership Type
schema:
type: string
enum:
- premium
- standard
cookieParams:
- name: SessionId
description: A Session ID variable
schema:
type: string
methodResponses:
- statusCode: 201
responseBody:
description: A user object along with generated API Keys
responseModels:
application/json: PutDocumentResponse
- statusCode: 500
responseBody:
description: An error message when creating a new user
responseModels:
application/json: ErrorResponse
custom:
documentation:
title: "a title"
version: "1.2"
description: "a description"
servers:
- url: "https://example.com"
description: "Dev server"
security:
- name: auth
authorizerName: customAuth
type: http
scheme: bearer
models:
- name: ErrorResponse
description: This is an error
contentType: application/json
schema: ${file(models/ErrorResponse.json)}
- name: PutDocumentResponse
description: PUT Document response model (external reference example)
contentType: application/json
schema: ${file(models/PutDocumentResponse.json)}
- name: PutDocumentRequest
description: PUT Document request model (inline example)
contentType: application/json
schema:
$schema: http://json-schema.org/draft-04/schema#
properties:
SomeObject:
type: object
properties:
SomeAttribute:
type: string