-
Notifications
You must be signed in to change notification settings - Fork 0
/
apidoc.yml
340 lines (336 loc) · 7.65 KB
/
apidoc.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
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
swagger: "2.0"
info:
description: "service for registering foosball teams for the upcoming season.
\nFLow:
\n * User logs in
\n * First site is a list of teams, the user is in charge for
\n * On the team site the user can see the current lineup and create a lineup for the upcoming season
\n * On a player-profile site, the user can see all the necessary player-credentials
\n"
version: "0.0.1"
title: "league-registration"
host: yi.pi.yi.pi.yeah
basePath: /league-registration
schemes:
- https
consumes:
- application/json
produces:
- application/json
definitions:
# A simple username/password combo for logging in
login:
required: [username, password]
properties:
username:
type: string
minLength: 1
password:
type: string
minLength: 1
player:
properties:
id:
type: string
nationalPlayerNr:
type: string
internationalPlayerNr:
type: string
lastname:
type: string
firstname:
type: string
club:
type: string
gender:
type: string
birthdate:
type: string
emailAddress:
type: string
phone:
type: number
team:
properties:
id:
type: string
name:
type: string
club:
$ref: '#/definitions/club'
homeWeekday:
type: number
hometable:
$ref: '#/definitions/tableType'
homeLocation:
$ref: '#/definitions/location'
lineupList:
type: array
items:
$ref: '#/definitions/lineup'
club:
properties:
id:
type: string
name:
type: string
location:
properties:
id:
type: string
name:
type: string
street:
type: string
city:
type: string
zip:
type: string
tableType:
properties:
id:
type: string
name:
type: string
lineup:
properties:
id:
type: string
team:
$ref: '#/definitions/team'
season:
$ref: '#/definitions/season'
players:
type: array
items:
$ref: '#/definitions/player'
season:
properties:
id:
type: string
name:
type: string
# NOTE: This does NOT set global parameters for all operations.
# It just defines parameter templates that can be referenced by operations (i.e. it saves typing)
parameters:
sessionCookie: &sessionCookie
name: Cookie
in: header
required: true
type: string
description: The session cookie
# username: &username
# name: username
# in: path
# required: true
# type: string
# description: This is the {username} path parameter
offsetParam:
in: query
name: offset
required: false
type: integer
minimum: 0
description: The number of items to skip before starting to collect the result set.
limitParam:
in: query
name: limit
required: false
type: integer
minimum: 1
maximum: 50
default: 20
description: The numbers of items to return.
paths:
/login:
post:
summary: Logs in
description: |
Try logging in with username "jdoe" and password "jdoe".
Then try logging in with username "admin" and password "admin".
parameters:
- name: body
in: body
required: true
description: The login credentials
schema:
$ref: '#/definitions/login'
responses:
200:
description: Login was successful
headers:
Set-Cookie:
type: string
description: The session cookie
default: demo-session-id=123456789012345678901234567890
/logout:
post:
summary: Logs out the given user
description: >
Users can only log themselves out, not other users. Except the "admin" user, who can log-out anyone.
parameters:
- *sessionCookie
responses:
204:
description: Logout was successful
headers:
Set-Cookie:
type: string
description: Deletes the session cookie (by making expire in the past)
default: demo-session-id=deleted; Expires=Thu, 01-Jan-1970 00:00:01 GMT; Path=/
401:
description: You tried to log someone else out, and you're not the "admin" user.
404:
description: The {username} was not found
/team:
get:
summary: gets the teams the user is responsible for
description: todo
responses:
200:
description: OK
post:
responses:
200:
description: OK
patch:
responses:
200:
description: OK
delete:
responses:
200:
description: OK
/team/{teamId}:
get:
summary: gets a team with all informations and related players for the current and the upcoming season
description: todo
parameters:
- name: teamId
in: path
description: String input for echo service
required: true
type: string
responses:
200:
description: OK
post:
summary: post the lineup for the upcoming season
description: todo
responses:
200:
description: OK
patch:
summary: patches the lineup for the upcoming season with new information
responses:
200:
description: OK
delete:
summary: deletes the lineup for the upcoming season
responses:
200:
description: OK
/lineup/{lineupId}:
get:
summary: gets a lineup
description: todo
parameters:
- name: lineupId
in: path
description: String input for echo service
required: true
type: string
responses:
200:
description: OK
post:
summary: post the lineup for the upcoming season
description: todo
responses:
200:
description: OK
patch:
summary: patches the lineup for the upcoming season with new information
responses:
200:
description: OK
delete:
summary: deletes the lineup for the upcoming season
responses:
200:
description: OK
/player:
get:
description: todo
responses:
200:
description: OK
post:
responses:
200:
description: OK
patch:
responses:
200:
description: OK
delete:
responses:
200:
description: OK
/player/search:
get:
summary: searches for players to add to a lineup
parameters:
- name: forename
type: string
in: query
minLength: 1
required: true
- name: surname
type: string
in: query
minLength: 1
required: true
- $ref: '#/parameters/offsetParam'
- $ref: '#/parameters/limitParam'
responses:
200:
description: OK
schema:
type: array
items:
$ref: '#/definitions/player'
/club:
get:
responses:
200:
description: OK
post:
responses:
200:
description: OK
patch:
responses:
200:
description: OK
delete:
responses:
200:
description: OK
/location:
get:
responses:
200:
description: OK
post:
responses:
200:
description: OK
patch:
responses:
200:
description: OK
delete:
responses:
200:
description: OK