-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathuser-mgr.yaml
364 lines (338 loc) · 10.4 KB
/
user-mgr.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
# SPDX-FileCopyrightText: 2022 Lars Geyer-Blaumeiser <lars@lgblaumeiser.de>
# SPDX-License-Identifier: MIT
openapi: 3.0.3
info:
title: User Manager API
description: Description of a user manager API
version: 1.0.0
contact:
name: lgblaumeiser
email: lars@lgblaumeiser.de
license:
name: MIT
servers:
- url: http://localhost:19749
description: User manager currently runs typically locally on the host machine
paths:
# Users API
/users:
post:
summary: Register a new user, needs no authentication, user will get usermanager_user role
operationId: registerUser
tags:
- users
requestBody:
description: Fields username and password are required, roles is optional
required: true
content:
application/json:
schema:
$ref: '#/components/schemas/NewUserData'
responses:
'201':
description: User successfully created
content:
application/json:
schema:
$ref: '#/components/schemas/UserId'
'400':
$ref: '#/components/responses/BadRequest'
'500':
$ref: '#/components/responses/InternalError'
put:
summary: Change the password of the user, authentication provided either by token of user or of an admin
operationId: changePassword
tags:
- users
security:
- BearerAuth: []
requestBody:
description: Fields username and password are required, password contains new password
required: true
content:
application/json:
schema:
$ref: '#/components/schemas/AuthData'
responses:
'200':
description: Password successfully changed
content:
application/json:
schema:
$ref: '#/components/schemas/UserId'
'400':
$ref: '#/components/responses/BadRequest'
'401':
$ref: '#/components/responses/Unauthorized'
'403':
$ref: '#/components/responses/AdminAccess'
'500':
$ref: '#/components/responses/InternalError'
patch:
summary: Change roles of user, admin roles can only be changed by an admin
operationId: changeRoles
security:
- BearerAuth: []
tags:
- users
requestBody:
description: Field username is optional, if not given, token id is used, newroles and obsroles are optional, but should in total contain at least one element
required: true
content:
application/json:
schema:
$ref: '#/components/schemas/ChangeRoleData'
responses:
'200':
description: Roles successfully changed
content:
application/json:
schema:
$ref: '#/components/schemas/UserId'
'400':
$ref: '#/components/responses/BadRequest'
'401':
$ref: '#/components/responses/Unauthorized'
'403':
$ref: '#/components/responses/AdminAccess'
'500':
$ref: '#/components/responses/InternalError'
delete:
summary: Delete a user from the database
operationId: deleteUser
security:
- BearerAuth: [ admin ]
tags:
- users
requestBody:
description: Field username is required
required: true
content:
application/json:
schema:
$ref: '#/components/schemas/SimpleUserData'
responses:
'204':
$ref: '#/components/responses/SuccessfullyDeleted'
'401':
$ref: '#/components/responses/Unauthorized'
'403':
$ref: '#/components/responses/AdminAccess'
'500':
$ref: '#/components/responses/InternalError'
/users/authenticate:
post:
summary: Authenticate a registered user by password, returns an access token valid for 30 minutes and a refresh token valid for 2 weeks
operationId: authenticateUser
tags:
- users
requestBody:
description: Field username and password are required, rest is ignored
required: true
content:
application/json:
schema:
$ref: '#/components/schemas/AuthData'
responses:
'200':
description: User authenticated, required access token and refresh token returned
content:
application/json:
schema:
$ref: '#/components/schemas/TokenResult'
'400':
$ref: '#/components/responses/BadRequest'
'401':
$ref: '#/components/responses/Unauthorized'
'500':
$ref: '#/components/responses/InternalError'
/users/token:
get:
summary: With the use of the refresh token aquire a new access token, refresh token will be restarted as well
operationId: refreshToken
security:
- BearerAuth: [ ]
tags:
- users
responses:
'200':
description: Refreshed access and refresh token
content:
application/json:
schema:
$ref: '#/components/schemas/TokenResult'
'401':
$ref: '#/components/responses/Unauthorized'
'500':
$ref: '#/components/responses/InternalError'
put:
summary: Invalidate refresh token, in case token has been leaked and the usage has to be prevented, uses no authentication, simply the username is needed
operationId: invalidateToken
tags:
- users
requestBody:
description: Field username is required, either password is given or the request has an access token from an admin
required: true
content:
application/json:
schema:
$ref: '#/components/schemas/AuthData'
responses:
'204':
description: The refresh token has been invalidated
'400':
$ref: '#/components/responses/BadRequest'
'500':
$ref: '#/components/responses/InternalError'
# Infrastructure API
/backup:
get:
summary: Create a backup of the database
operationId: backup
tags:
- infrastructure
security:
- BearerAuth: [ admin ]
responses:
'200':
description: A backup of the database data as zip byte stream
content:
application/zip:
schema:
type: string
format: binary
'401':
$ref: '#/components/responses/Unauthorized'
'403':
$ref: '#/components/responses/AdminAccess'
'500':
$ref: '#/components/responses/InternalError'
put:
summary: Restore a backup and replace existing database, old date will be deleted
operationId: restore
tags:
- infrastructure
security:
- BearerAuth: [ admin ]
requestBody:
description: The data to restore in the database
required: true
content:
application/zip:
schema:
type: string
format: binary
responses:
'204':
description: Database restored successfully, old data deleted
'400':
$ref: '#/components/responses/BadRequest'
'401':
$ref: '#/components/responses/Unauthorized'
'403':
$ref: '#/components/responses/AdminAccess'
'500':
$ref: '#/components/responses/InternalError'
/licenses:
get:
summary: Returns the attribution information on the used Open Source Software
operationId: license
tags:
- infrastructure
responses:
'200':
description: The attribution information as text
content:
text/plain; charset=utf-8:
schema:
type: string
'500':
$ref: '#/components/responses/InternalError'
components:
responses:
SuccessfullyDeleted:
description: Resource deleted successfully
Unauthorized:
description: User not authorized
BadRequest:
description: Bad data given to the request, returns an adequate error message
content:
text/plain; charset=utf-8:
schema:
type: string
example: "Request body did not contain valid data, request failed"
AdminAccess:
description: Admin access needed for this operation
InternalError:
description: The request resulted in an unexpected exception, returns an adequate error message
content:
text/plain; charset=utf-8:
schema:
type: string
example: "An io error occured, request failed"
schemas:
AuthData:
type: object
properties:
username:
$ref: "#/components/schemas/Username"
password:
$ref: "#/components/schemas/Password"
NewUserData:
properties:
username:
$ref: "#/components/schemas/Username"
password:
$ref: "#/components/schemas/Password"
addroles:
$ref: "#/components/schemas/RoleList"
SimpleUserData:
type: object
properties:
username:
$ref: "#/components/schemas/Username"
ChangeRoleData:
type: object
properties:
username:
$ref: "#/components/schemas/Username"
addroles:
$ref: "#/components/schemas/RoleList"
removeroles:
$ref: "#/components/schemas/RoleList"
UserId:
type: object
properties:
username:
$ref: "#/components/schemas/Username"
TokenResult:
type: object
properties:
access_token:
$ref: "#/components/schemas/Token"
refresh_token:
$ref: "#/components/schemas/Token"
Username:
type: string
description: An unique identifier for the user
example: "my_username"
Password:
type: string
description: The password for the user
format: password
example: "$0MeP@sswOrD"
Token:
type: string
description: A valid token
format: byte
example: "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c"
RoleList:
type: array
items:
type: string
example: [ "tool_user", "tool_admin" ]
securitySchemes:
BearerAuth:
type: http
scheme: bearer
bearerFormat: JWT