forked from openedx/course-discovery
-
Notifications
You must be signed in to change notification settings - Fork 0
/
api-compact.yaml
125 lines (112 loc) · 3.2 KB
/
api-compact.yaml
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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
# Discovery IDA: upstream API definitions, including vendor extensions.
# Note, while this document is not strictly to Swagger spec, each HTTP method"s
# definition _must_ be to spec or the downstream ref will fail.
apigateway_responses: &apigateway_responses
default:
statusCode: "400"
200:
statusCode: "200"
401:
statusCode: "401"
403:
statusCode: "403"
404:
statusCode: "404"
429:
statusCode: "429"
500:
statusCode: "500"
produces: &produces
- "application/json"
- "application/csv"
responses: &responses
200:
description: "OK"
400:
description: "Bad Request"
401:
description: "Unauthorized"
403:
description: "Forbidden"
404:
description: "Not Found"
429:
description: "Too Many Requests"
500:
description: "Internal Server Error"
id_parameter: &id_parameter
name: "id"
in: "path"
required: true
type: "number"
auth_header: &auth_header
name: "Authorization"
in: "header"
required: true
type: "string"
limit_qs_parameter: &limit_qs_parameter
in: querystring
name: limit
required: false
type: number
offset_qs_parameter: &offset_qs_parameter
in: querystring
name: offset
required: false
type: number
# AWS API Gateway vendor extension point. This information is used
# by https://github.com/awslabs/aws-apigateway-importer.
x-amazon-apigateway-integration: &apigateway_integration
responses: *apigateway_responses
httpMethod: "GET"
type: "http"
requestParameters:
integration.request.header.Authorization: "method.request.header.Authorization"
x-amazon-apigateway-integration-with-id: &apigateway_integration_with_id_parameter
responses: *apigateway_responses
httpMethod: "GET"
type: "http"
requestParameters:
integration.request.header.Authorization: "method.request.header.Authorization"
integration.request.path.id: "method.request.path.id"
endpoints:
v1:
# /v1/catalogs
catalogs:
get:
produces: *produces
parameters:
- *auth_header
- *limit_qs_parameter
- *offset_qs_parameter
operationId: "get_catalogs"
responses: *responses
x-amazon-apigateway-integration:
<<: *apigateway_integration
uri: "https://${stageVariables.discovery_host}/v1/catalogs/"
# /v1/catalogs/{id}
catalogById:
get:
produces: *produces
parameters:
- *auth_header
- *id_parameter
operationId: "get_catalog_by_id"
responses: *responses
x-amazon-apigateway-integration:
<<: *apigateway_integration_with_id_parameter
uri: "https://${stageVariables.discovery_host}/v1/catalogs/{id}/"
# /v1/catalogs/{id}/courses
catalogCourses:
get:
produces: *produces
parameters:
- *auth_header
- *id_parameter
- *limit_qs_parameter
- *offset_qs_parameter
operationId: "get_catalog_courses"
responses: *responses
x-amazon-apigateway-integration:
<<: *apigateway_integration_with_id_parameter
uri: "https://${stageVariables.discovery_host}/v1/catalogs/{id}/courses/"