Show More
@@ -74,15 +74,47 b' INPUT::' | |||
|
74 | 74 | api_key : "<api_key>" |
|
75 | 75 | method : "pull" |
|
76 | 76 | args : { |
|
77 |
"repo" : "<repo |
|
|
77 | "repo_name" : "<reponame>" | |
|
78 | 78 | } |
|
79 | 79 | |
|
80 | 80 | OUTPUT:: |
|
81 | 81 | |
|
82 |
result : "Pulled from <repo |
|
|
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 |
|
|
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" : |
|
|
199 | "active": "<bool>", | |
|
194 | "id" : "<id>", | |
|
195 | "group_name" : "<groupname>", | |
|
196 | "active": "<bool>", | |
|
200 | 197 | "members" : [ |
|
201 |
|
|
|
202 |
|
|
|
203 |
|
|
|
204 |
|
|
|
205 |
|
|
|
206 |
|
|
|
207 |
|
|
|
208 |
|
|
|
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" : |
|
|
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" : |
|
|
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: |
|
|
421 | result: { | |
|
422 | "id": "<newrepoid>", | |
|
423 | "msg": "Created new repository <reponame>", | |
|
424 | } | |
|
387 | 425 |
|
|
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: |
|
|
446 | result: { | |
|
447 | "msg" : "Added perm: <perm> for <username> in repo: <reponame>" | |
|
448 | } | |
|
409 | 449 |
|
|
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" : |
|
|
464 | "group_name" : "<groupname>", | |
|
425 | 465 | "perm" : "(None|repository.(read|write|admin))", |
|
426 |
|
|
|
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( |
|
|
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 |
|
|
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