##// END OF EJS Templates
api review...
marcink -
r1843:0771f0f5 beta
parent child Browse files
Show More
@@ -74,15 +74,47 b' INPUT::'
74 74 api_key : "<api_key>"
75 75 method : "pull"
76 76 args : {
77 "repo" : "<repo_name>"
77 "repo_name" : "<reponame>"
78 78 }
79 79
80 80 OUTPUT::
81 81
82 result : "Pulled from <repo_name>"
82 result : "Pulled from <reponame>"
83 83 error : null
84 84
85 85
86 get_user
87 --------
88
89 Get's an user by username, Returns empty result if user is not found.
90 This command can be executed only using api_key belonging to user with admin
91 rights.
92
93 INPUT::
94
95 api_key : "<api_key>"
96 method : "get_user"
97 args : {
98 "username" : "<username>"
99 }
100
101 OUTPUT::
102
103 result: None if user does not exist or
104 {
105 "id" : "<id>",
106 "username" : "<username>",
107 "firstname": "<firstname>",
108 "lastname" : "<lastname>",
109 "email" : "<email>",
110 "active" : "<bool>",
111 "admin" :Β  "<bool>",
112 "ldap" : "<ldap_dn>"
113 }
114
115 error: null
116
117
86 118 get_users
87 119 ---------
88 120
@@ -136,46 +168,11 b' INPUT::'
136 168 OUTPUT::
137 169
138 170 result: {
171 "id" : "<new_user_id>",
139 172 "msg" : "created new user <username>"
140 173 }
141 174 error: null
142 175
143 get_users_groups
144 ----------------
145
146 Lists all existing users groups. This command can be executed only using api_key
147 belonging to user with admin rights.
148
149 INPUT::
150
151 api_key : "<api_key>"
152 method : "get_users_groups"
153 args : { }
154
155 OUTPUT::
156
157 result : [
158 {
159 "id" : "<id>",
160 "name" : "<name>",
161 "active": "<bool>",
162 "members" : [
163 {
164 "id" : "<userid>",
165 "username" : "<username>",
166 "firstname": "<firstname>",
167 "lastname" : "<lastname>",
168 "email" : "<email>",
169 "active" : "<bool>",
170 "admin" :Β  "<bool>",
171 "ldap" : "<ldap_dn>"
172 },
173 …
174 ]
175 }
176 ]
177 error : null
178
179 176 get_users_group
180 177 ---------------
181 178
@@ -194,24 +191,61 b' OUTPUT::'
194 191
195 192 result : None if group not exist
196 193 {
197 "id" : "<id>",
198 "name" : "<name>",
199 "active": "<bool>",
194 "id" : "<id>",
195 "group_name" : "<groupname>",
196 "active": "<bool>",
200 197 "members" : [
201 { "id" : "<userid>",
202 "username" : "<username>",
203 "firstname": "<firstname>",
204 "lastname" : "<lastname>",
205 "email" : "<email>",
206 "active" : "<bool>",
207 "admin" :Β  "<bool>",
208 "ldap" : "<ldap_dn>"
209 },
210 …
211 ]
198 { "id" : "<userid>",
199 "username" : "<username>",
200 "firstname": "<firstname>",
201 "lastname" : "<lastname>",
202 "email" : "<email>",
203 "active" : "<bool>",
204 "admin" :Β  "<bool>",
205 "ldap" : "<ldap_dn>"
206 },
207 …
208 ]
212 209 }
213 210 error : null
214 211
212 get_users_groups
213 ----------------
214
215 Lists all existing users groups. This command can be executed only using
216 api_key belonging to user with admin rights.
217
218 INPUT::
219
220 api_key : "<api_key>"
221 method : "get_users_groups"
222 args : { }
223
224 OUTPUT::
225
226 result : [
227 {
228 "id" : "<id>",
229 "group_name" : "<groupname>",
230 "active": "<bool>",
231 "members" : [
232 {
233 "id" : "<userid>",
234 "username" : "<username>",
235 "firstname": "<firstname>",
236 "lastname" : "<lastname>",
237 "email" : "<email>",
238 "active" : "<bool>",
239 "admin" :Β  "<bool>",
240 "ldap" : "<ldap_dn>"
241 },
242 …
243 ]
244 }
245 ]
246 error : null
247
248
215 249 create_users_group
216 250 ------------------
217 251
@@ -223,7 +257,7 b' INPUT::'
223 257 api_key : "<api_key>"
224 258 method : "create_users_group"
225 259 args: {
226 "name": "<name>",
260 "group_name": "<groupname>",
227 261 "active":"<bool> = True"
228 262 }
229 263
@@ -231,7 +265,7 b' OUTPUT::'
231 265
232 266 result: {
233 267 "id": "<newusersgroupid>",
234 "msg": "created new users group <name>"
268 "msg": "created new users group <groupname>"
235 269 }
236 270 error: null
237 271
@@ -258,6 +292,51 b' OUTPUT::'
258 292 }
259 293 error: null
260 294
295 get_repo
296 --------
297
298 Gets an existing repository. This command can be executed only using api_key
299 belonging to user with admin rights
300
301 INPUT::
302
303 api_key : "<api_key>"
304 method : "get_repo"
305 args: {
306 "repo_name" : "<reponame>"
307 }
308
309 OUTPUT::
310
311 result: None if repository does not exist or
312 {
313 "id" : "<id>",
314 "repo_name" : "<reponame>"
315 "type" : "<type>",
316 "description" : "<description>",
317 "members" : [
318 { "id" : "<userid>",
319 "username" : "<username>",
320 "firstname": "<firstname>",
321 "lastname" : "<lastname>",
322 "email" : "<email>",
323 "active" : "<bool>",
324 "admin" :Β  "<bool>",
325 "ldap" : "<ldap_dn>",
326 "permission" : "repository.(read|write|admin)"
327 },
328 …
329 {
330 "id" : "<usersgroupid>",
331 "name" : "<usersgroupname>",
332 "active": "<bool>",
333 "permission" : "repository.(read|write|admin)"
334 },
335 …
336 ]
337 }
338 error: null
339
261 340 get_repos
262 341 ---------
263 342
@@ -275,7 +354,7 b' OUTPUT::'
275 354 result: [
276 355 {
277 356 "id" : "<id>",
278 "name" : "<name>"
357 "repo_name" : "<reponame>"
279 358 "type" : "<type>",
280 359 "description" : "<description>"
281 360 },
@@ -283,57 +362,13 b' OUTPUT::'
283 362 ]
284 363 error: null
285 364
286 get_repo
287 --------
288
289 Gets an existing repository. This command can be executed only using api_key
290 belonging to user with admin rights
291
292 INPUT::
293
294 api_key : "<api_key>"
295 method : "get_repo"
296 args: {
297 "name" : "<name>"
298 }
299
300 OUTPUT::
301
302 result: None if repository not exist
303 {
304 "id" : "<id>",
305 "name" : "<name>"
306 "type" : "<type>",
307 "description" : "<description>",
308 "members" : [
309 { "id" : "<userid>",
310 "username" : "<username>",
311 "firstname": "<firstname>",
312 "lastname" : "<lastname>",
313 "email" : "<email>",
314 "active" : "<bool>",
315 "admin" :Β  "<bool>",
316 "ldap" : "<ldap_dn>",
317 "permission" : "repository.(read|write|admin)"
318 },
319 …
320 {
321 "id" : "<usersgroupid>",
322 "name" : "<usersgroupname>",
323 "active": "<bool>",
324 "permission" : "repository.(read|write|admin)"
325 },
326 …
327 ]
328 }
329 error: null
330 365
331 366 get_repo_nodes
332 367 --------------
333 368
334 369 returns a list of nodes and it's children in a flat list for a given path
335 at given revision. It's possible to specify ret_type to show only files or
336 dirs. This command can be executed only using api_key belonging to user
370 at given revision. It's possible to specify ret_type to show only `files` or
371 `dirs`. This command can be executed only using api_key belonging to user
337 372 with admin rights
338 373
339 374 INPUT::
@@ -341,7 +376,7 b' INPUT::'
341 376 api_key : "<api_key>"
342 377 method : "get_repo_nodes"
343 378 args: {
344 "repo_name" : "<name>",
379 "repo_name" : "<reponame>",
345 380 "revision" : "<revision>",
346 381 "root_path" : "<root_path>",
347 382 "ret_type" : "<ret_type>" = 'all'
@@ -374,7 +409,7 b' INPUT::'
374 409 api_key : "<api_key>"
375 410 method : "create_repo"
376 411 args: {
377 "name" : "<name>",
412 "repo_name" : "<reponame>",
378 413 "owner_name" : "<ownername>",
379 414 "description" : "<description> = ''",
380 415 "repo_type" : "<type> = 'hg'",
@@ -383,7 +418,10 b' INPUT::'
383 418
384 419 OUTPUT::
385 420
386 result: None
421 result: {
422 "id": "<newrepoid>",
423 "msg": "Created new repository <reponame>",
424 }
387 425 error: null
388 426
389 427 add_user_to_repo
@@ -399,13 +437,15 b' INPUT::'
399 437 method : "add_user_to_repo"
400 438 args: {
401 439 "repo_name" : "<reponame>",
402 "username" : "<username>",
440 "username" : "<username>",
403 441 "perm" : "(None|repository.(read|write|admin))",
404 442 }
405 443
406 444 OUTPUT::
407 445
408 result: None
446 result: {
447 "msg" : "Added perm: <perm> for <username> in repo: <reponame>"
448 }
409 449 error: null
410 450
411 451 add_users_group_to_repo
@@ -421,6 +461,12 b' INPUT::'
421 461 method : "add_users_group_to_repo"
422 462 args: {
423 463 "repo_name" : "<reponame>",
424 "group_name" : "<groupname>",
464 "group_name" : "<groupname>",
425 465 "perm" : "(None|repository.(read|write|admin))",
426 } No newline at end of file
466 }
467 OUTPUT::
468
469 result: {
470 "msg" : Added perm: <perm> for <groupname> in repo: <reponame>"
471 }
472
@@ -64,23 +64,23 b' class ApiController(JSONRPCController):'
64 64 """
65 65
66 66 @HasPermissionAllDecorator('hg.admin')
67 def pull(self, apiuser, repo):
67 def pull(self, apiuser, repo_name):
68 68 """
69 69 Dispatch pull action on given repo
70 70
71 71
72 72 :param user:
73 :param repo:
73 :param repo_name:
74 74 """
75 75
76 if Repository.is_valid(repo) is False:
77 raise JSONRPCError('Unknown repo "%s"' % repo)
76 if Repository.is_valid(repo_name) is False:
77 raise JSONRPCError('Unknown repo "%s"' % repo_name)
78 78
79 79 try:
80 ScmModel().pull_changes(repo, self.rhodecode_user.username)
81 return 'Pulled from %s' % repo
80 ScmModel().pull_changes(repo_name, self.rhodecode_user.username)
81 return 'Pulled from %s' % repo_name
82 82 except Exception:
83 raise JSONRPCError('Unable to pull changes from "%s"' % repo)
83 raise JSONRPCError('Unable to pull changes from "%s"' % repo_name)
84 84
85 85 @HasPermissionAllDecorator('hg.admin')
86 86 def get_user(self, apiuser, username):
@@ -151,10 +151,15 b' class ApiController(JSONRPCController):'
151 151 raise JSONRPCError("user %s already exist" % username)
152 152
153 153 try:
154 UserModel().create_or_update(username, password, email, firstname,
155 lastname, active, admin, ldap_dn)
154 usr = UserModel().create_or_update(
155 username, password, email, firstname,
156 lastname, active, admin, ldap_dn
157 )
156 158 Session.commit()
157 return dict(msg='created new user %s' % username)
159 return dict(
160 id=usr.user_id,
161 msg='created new user %s' % username
162 )
158 163 except Exception:
159 164 log.error(traceback.format_exc())
160 165 raise JSONRPCError('failed to create user %s' % username)
@@ -185,7 +190,7 b' class ApiController(JSONRPCController):'
185 190 ldap=user.ldap_dn))
186 191
187 192 return dict(id=users_group.users_group_id,
188 name=users_group.users_group_name,
193 group_name=users_group.users_group_name,
189 194 active=users_group.users_group_active,
190 195 members=members)
191 196
@@ -212,31 +217,31 b' class ApiController(JSONRPCController):'
212 217 ldap=user.ldap_dn))
213 218
214 219 result.append(dict(id=users_group.users_group_id,
215 name=users_group.users_group_name,
220 group_name=users_group.users_group_name,
216 221 active=users_group.users_group_active,
217 222 members=members))
218 223 return result
219 224
220 225 @HasPermissionAllDecorator('hg.admin')
221 def create_users_group(self, apiuser, name, active=True):
226 def create_users_group(self, apiuser, group_name, active=True):
222 227 """
223 228 Creates an new usergroup
224 229
225 :param name:
230 :param group_name:
226 231 :param active:
227 232 """
228 233
229 if self.get_users_group(apiuser, name):
230 raise JSONRPCError("users group %s already exist" % name)
234 if self.get_users_group(apiuser, group_name):
235 raise JSONRPCError("users group %s already exist" % group_name)
231 236
232 237 try:
233 ug = UsersGroupModel().create(name=name, active=active)
238 ug = UsersGroupModel().create(name=group_name, active=active)
234 239 Session.commit()
235 240 return dict(id=ug.users_group_id,
236 msg='created new users group %s' % name)
241 msg='created new users group %s' % group_name)
237 242 except Exception:
238 243 log.error(traceback.format_exc())
239 raise JSONRPCError('failed to create group %s' % name)
244 raise JSONRPCError('failed to create group %s' % group_name)
240 245
241 246 @HasPermissionAllDecorator('hg.admin')
242 247 def add_user_to_users_group(self, apiuser, group_name, username):
@@ -312,7 +317,7 b' class ApiController(JSONRPCController):'
312 317
313 318 return dict(
314 319 id=repo.repo_id,
315 name=repo.repo_name,
320 repo_name=repo.repo_name,
316 321 type=repo.repo_type,
317 322 description=repo.description,
318 323 members=members
@@ -331,7 +336,7 b' class ApiController(JSONRPCController):'
331 336 result.append(
332 337 dict(
333 338 id=repository.repo_id,
334 name=repository.repo_name,
339 repo_name=repository.repo_name,
335 340 type=repository.repo_type,
336 341 description=repository.description
337 342 )
@@ -367,13 +372,13 b' class ApiController(JSONRPCController):'
367 372 raise JSONRPCError(e)
368 373
369 374 @HasPermissionAnyDecorator('hg.admin', 'hg.create.repository')
370 def create_repo(self, apiuser, name, owner_name, description='',
375 def create_repo(self, apiuser, repo_name, owner_name, description='',
371 376 repo_type='hg', private=False):
372 377 """
373 378 Create a repository
374 379
375 380 :param apiuser:
376 :param name:
381 :param repo_name:
377 382 :param description:
378 383 :param type:
379 384 :param private:
@@ -386,10 +391,10 b' class ApiController(JSONRPCController):'
386 391 except NoResultFound:
387 392 raise JSONRPCError('unknown user %s' % owner)
388 393
389 if self.get_repo(apiuser, name):
390 raise JSONRPCError("repo %s already exist" % name)
394 if Repository.get_by_repo_name(repo_name):
395 raise JSONRPCError("repo %s already exist" % repo_name)
391 396
392 groups = name.split('/')
397 groups = repo_name.split('/')
393 398 real_name = groups[-1]
394 399 groups = groups[:-1]
395 400 parent_id = None
@@ -405,10 +410,10 b' class ApiController(JSONRPCController):'
405 410 )
406 411 parent_id = group.group_id
407 412
408 RepoModel().create(
413 repo = RepoModel().create(
409 414 dict(
410 415 repo_name=real_name,
411 repo_name_full=name,
416 repo_name_full=repo_name,
412 417 description=description,
413 418 private=private,
414 419 repo_type=repo_type,
@@ -418,9 +423,15 b' class ApiController(JSONRPCController):'
418 423 owner
419 424 )
420 425 Session.commit()
426
427 return dict(
428 id=repo.repo_id,
429 msg="Created new repository %s" % repo.repo_name
430 )
431
421 432 except Exception:
422 433 log.error(traceback.format_exc())
423 raise JSONRPCError('failed to create repository %s' % name)
434 raise JSONRPCError('failed to create repository %s' % repo_name)
424 435
425 436 @HasPermissionAnyDecorator('hg.admin')
426 437 def add_user_to_repo(self, apiuser, repo_name, username, perm):
General Comments 0
You need to be logged in to leave comments. Login now