-
Notifications
You must be signed in to change notification settings - Fork 5
/
an-api-of-ice-and-fire.yaml
417 lines (411 loc) · 11.8 KB
/
an-api-of-ice-and-fire.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
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
openapi: 3.0.0
info:
title: A Song of Ice and Fire API
version: 1.0.0
description: |
ABOUT AN API OF ICE AND FIRE
An API of Ice And Fire is the world's greatest source for quantified and structured data from the universe of Ice and Fire (and the HBO series Game of Thrones). We give you access to data about all the Books, Characters and Houses in an easy to use JSON format.
Page numbering is 1-based
You can specify how many items you want to receive per page, the maximum is 50
servers:
- url: https://www.anapioficeandfire.com/api
paths:
/books:
get:
summary: Get a list of all books
description: Get a list of all books
operationId: getBooks
responses:
"200":
description: A list of books
content:
application/json:
schema:
type: array
items:
$ref: "#/components/schemas/Book"
parameters:
- name: name
in: query
description: Filter books by name
schema:
type: string
- name: page
in: query
description: page number
schema:
type: integer
- name: pageSize
in: query
description: number of items per page
schema:
type: integer
- name: fromReleaseDate
in: query
description: Filter books by release date (after or on)
schema:
type: string
format: date
- name: toReleaseDate
in: query
description: Filter books by release date (before or on)
schema:
type: string
format: date
/books/{bookId}:
get:
summary: Get a specific book by ID
description: Get a specific book by ID
operationId: getBookById
parameters:
- name: bookId
in: path
description: ID of the book to retrieve
required: true
schema:
type: integer
responses:
"200":
description: The book resource
content:
application/json:
schema:
$ref: "#/components/schemas/Book"
/characters:
get:
summary: Get a list of all characters
description: Get a list of all characters
operationId: getCharacters
responses:
"200":
description: A list of characters
content:
application/json:
schema:
type: array
items:
$ref: "#/components/schemas/Character"
parameters:
- name: name
in: query
description: Filter characters by name
schema:
type: string
- name: page
in: query
description: page number
schema:
type: integer
- name: pageSize
in: query
description: number of items per page
schema:
type: integer
- name: gender
in: query
description: Filter characters by gender
schema:
type: string
- name: culture
in: query
description: Filter characters by culture
schema:
type: string
- name: born
in: query
description: Filter characters by birth year
schema:
type: string
- name: died
in: query
description: Filter characters by death year
schema:
type: string
- name: isAlive
in: query
description: Filter characters by whether they are alive or dead
schema:
type: boolean
/characters/{characterId}:
get:
summary: Get a specific character by ID
description: Get a specific character by ID
operationId: getCharacterById
parameters:
- name: characterId
in: path
description: ID of the character to retrieve
required: true
schema:
type: integer
responses:
"200":
description: The character resource
content:
application/json:
schema:
$ref: "#/components/schemas/Character"
/houses:
get:
summary: List all houses
description: List all houses
operationId: getHouses
parameters:
- name: page
in: query
description: page number
schema:
type: integer
- name: pageSize
in: query
description: number of items per page
schema:
type: integer
- name: name
in: query
description: Filter houses by name
schema:
type: string
- name: region
in: query
description: Filter houses by region
schema:
type: string
- name: words
in: query
description: Filter houses by words
schema:
type: string
- name: hasWords
in: query
description: Filter houses by whether or not they have words
schema:
type: boolean
- name: hasTitles
in: query
description: Filter houses by whether or not they have titles
schema:
type: boolean
- name: hasSeats
in: query
description: Filter houses by whether or not they have seats
schema:
type: boolean
- name: hasDiedOut
in: query
description: Filter houses by whether or not they have died out
schema:
type: boolean
- name: hasAncestralWeapons
in: query
description: Filter houses by whether or not they have ancestral weapons
schema:
type: boolean
- name: page
in: query
description: page number
schema:
type: integer
- name: pageSize
in: query
description: number of items per page
schema:
type: integer
responses:
"200":
description: OK
content:
application/json:
schema:
type: array
items:
$ref: "#/components/schemas/House"
"400":
description: Bad Request
"404":
description: Not Found
/houses/{id}:
get:
summary: Get specific house
description: Get specific house
operationId: getHouseById
parameters:
- name: id
in: path
description: The ID of the house to retrieve
required: true
schema:
type: integer
minimum: 1
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/House"
"400":
description: Bad Request
"404":
description: Not Found
components:
schemas:
House:
type: object
properties:
url:
type: string
format: uri
description: The hypermedia URL of this resource
name:
type: string
description: The name of this house
region:
type: string
description: The region that this house resides in
coatOfArms:
type: string
description: Text describing the coat of arms of this house
words:
type: string
description: The words of this house
titles:
type: array
items:
type: string
description: The titles that this house holds
seats:
type: array
items:
type: string
description: The seats that this house holds
currentLord:
type: string
format: uri
description: The Character resource URL of this house's current lord
heir:
type: string
format: uri
description: The Character resource URL of this house's heir
overlord:
type: string
format: uri
description: The House resource URL that this house answers to
Book:
type: object
properties:
url:
type: string
format: uri
description: The URL of the book resource
name:
type: string
description: The name of the book
isbn:
type: string
description: The book's ISBN
authors:
type: array
items:
type: string
description: The author(s) of the book
numberOfPages:
type: integer
description: The number of pages in the book
publisher:
type: string
description: The book's publisher
country:
type: string
description: The country where the book was published
mediaType:
type: string
description: The book's media type (e.g. Hardcover)
released:
type: string
format: date-time
description: The date the book was released
characters:
type: array
items:
type: string
format: uri
description: The character(s) that appear in the book
povCharacters:
type: array
items:
type: string
format: uri
description: The character(s) who narrate the book
Character:
type: object
properties:
url:
type: string
format: uri
description: The hypermedia URL of this resource
name:
type: string
description: The name of this character
gender:
type: string
description: The gender of this character
culture:
type: string
description: The culture that this character belongs to
born:
type: string
description: Textual representation of when and where this character was born
died:
type: string
description: Textual representation of when and where this character died
titles:
type: array
items:
type: string
description: The titles that this character holds
aliases:
type: array
items:
type: string
description: The aliases that this character goes by
father:
type: string
format: uri
description: The character resource URL of this character's father
mother:
type: string
format: uri
description: The character resource URL of this character's mother
spouse:
type: string
format: uri
description: An array of Character resource URLs that has had a POV-chapter in this book
allegiances:
type: array
items:
type: string
format: uri
description: An array of House resource URLs that this character is loyal to
books:
type: array
items:
type: string
format: uri
description: An array of Book resource URLs that this character has been in
povBooks:
type: array
items:
type: string
format: uri
description: An array of Book resource URLs that this character has had a POV-chapter in
tvSeries:
type: array
items:
type: string
description: An array of names of the seasons of Game of Thrones that this character has been in
playedBy:
type: array
items:
type: string
description: An array of actor names that has played this character in the TV show Game Of Thrones