##// END OF EJS Templates
git: exit early if Git is found but too old (Issue #342)...
git: exit early if Git is found but too old (Issue #342) The warning in the logs were too easy to miss. It is still OK if git isn't found at all... for example if git_path configuration doesn't point at something that looks like git. The git_path configuration already had no default, so just make the code path for that case more clean. (An easy next/alternative step could be to remove git from BACKENDS if it isn't configured ...) The system exit is similar to what is done in 0e33880b2897 ... even though exiting from from a library might be a bit worse ...

File last commit:

r7598:0e3e0864 default
r7773:df275f70 default
Show More
api.rst
1251 lines | 38.4 KiB | text/x-rst | RstLexer
API docs
r1446 .. _api:
docs
r2095 ===
API docs
r1446 API
===
Michael V. DePalatis
docs: English and consistency corrections
r4955 Kallithea has a simple JSON RPC API with a single schema for calling all API
Mads Kiilerich
docs: improve the API documentation
r4879 methods. Everything is available by sending JSON encoded http(s) requests to
Søren Løvborg
docs: spelling, grammar, content and typography
r5425 ``<your_server>/_admin/api``.
Mads Kiilerich
docs: improve the API documentation
r4879
API docs
r1446
Søren Løvborg
auth: improve API key documentation for users...
r6500 API keys
--------
update docs about the API access whitelist option
r3769
Søren Løvborg
auth: improve API key documentation for users...
r6500 Every Kallithea user automatically receives an API key, which they can
view under "My Account". On this page, API keys can also be revoked, and
additional API keys can be generated.
Added instruction on enabling the API access to web views
r1812
Mads Kiilerich
docs: rework stuff...
r4902 API access
Mads Kiilerich
docs: use consistent style for section titles
r5568 ----------
docs update
r1839
Mads Kiilerich
docs: improve the API documentation
r4879 Clients must send JSON encoded JSON-RPC requests::
API docs
r1446
whitespace cleanup
r3224 {
Mads Kiilerich
docs: improve the API documentation
r4879 "id: "<id>",
"api_key": "<api_key>",
"method": "<method_name>",
"args": {"<arg_key>": "<arg_val>"}
API docs
r1446 }
Mads Kiilerich
docs: improve the API documentation
r4879 For example, to pull to a local "CPython" mirror using curl::
Søren Løvborg
cleanup: use example.com for tests and examples...
r5497 curl https://kallithea.example.com/_admin/api -X POST -H 'content-type:text/plain' \
Søren Løvborg
docs: spelling, grammar, content and typography
r5425 --data-binary '{"id":1,"api_key":"xe7cdb2v278e4evbdf5vs04v832v0efvcbcve4a3","method":"pull","args":{"repo":"CPython"}}'
Extended API...
r1500
Mads Kiilerich
docs: improve the API documentation
r4879 In general, provide
- *id*, a value of any type, can be used to match the response with the request that it is replying to.
- *api_key*, for authentication and permission validation.
Søren Løvborg
docs: spelling, grammar, content and typography
r5425 - *method*, the name of the method to call -- a list of available methods can be found below.
Mads Kiilerich
docs: improve the API documentation
r4879 - *args*, the arguments to pass to the method.
Nicolas VINOT
[API] Update doc
r1592
API docs
r1446 .. note::
Nicolas VINOT
[API] Update doc
r1592
Søren Løvborg
docs: spelling, grammar, content and typography
r5425 api_key can be found or set on the user account page.
Nicolas VINOT
[API] Update doc
r1592
Mads Kiilerich
docs: improve the API documentation
r4879 The response to the JSON-RPC API call will always be a JSON structure::
Nicolas VINOT
[API] Update doc
r1592
whitespace cleanup
r3224 {
Søren Løvborg
docs: spelling, grammar, content and typography
r5425 "id": <id>, # the id that was used in the request
"result": <result>|null, # JSON formatted result (null on error)
"error": null|<error_message> # JSON formatted error (null on success)
API docs
r1446 }
Søren Løvborg
docs: spelling, grammar, content and typography
r5425 All responses from the API will be ``HTTP/1.0 200 OK``. If an error occurs,
Mads Kiilerich
docs: improve the API documentation
r4879 the reponse will have a failure description in *error* and
*result* will be null.
API docs
r1446
created rhodecode-api binary script for working with api via cli...
r2379
Mads Kiilerich
docs: rework stuff...
r4902 API client
Mads Kiilerich
docs: use consistent style for section titles
r5568 ----------
created rhodecode-api binary script for working with api via cli...
r2379
Søren Løvborg
docs: spelling, grammar, content and typography
r5425 Kallithea comes with a ``kallithea-api`` command line tool, providing a convenient
Mads Kiilerich
docs: improve the API documentation
r4879 way to call the JSON-RPC API.
whitespace cleanup
r3224
Michael V. DePalatis
docs: English and consistency corrections
r4955 For example, to call ``get_repo``::
created rhodecode-api binary script for working with api via cli...
r2379
Søren Løvborg
docs: update example output and example server configs...
r5496 kallithea-api --apihost=<Kallithea URL> --apikey=<API key> get_repo
created rhodecode-api binary script for working with api via cli...
r2379
Søren Løvborg
docs: update example output and example server configs...
r5496 Calling method get_repo => <Kallithea URL>
Server response
ERROR:"Missing non optional `repoid` arg in JSON DATA"
created rhodecode-api binary script for working with api via cli...
r2379
Michael V. DePalatis
docs: English and consistency corrections
r4955 Oops, looks like we forgot to add an argument. Let's try again, now
providing the ``repoid`` as a parameter::
created rhodecode-api binary script for working with api via cli...
r2379
Søren Løvborg
docs: update example output and example server configs...
r5496 kallithea-api --apihost=<Kallithea URL> --apikey=<API key> get_repo repoid:myrepo
whitespace cleanup
r3224
Søren Løvborg
docs: update example output and example server configs...
r5496 Calling method get_repo => <Kallithea URL>
Server response
{
"clone_uri": null,
"created_on": "2015-08-31T14:55:19.042",
...
created rhodecode-api binary script for working with api via cli...
r2379
Michael V. DePalatis
docs: English and consistency corrections
r4955 To avoid specifying ``apihost`` and ``apikey`` every time, run::
Mads Kiilerich
docs: improve the API documentation
r4879
Søren Løvborg
docs: update example output and example server configs...
r5496 kallithea-api --save-config --apihost=<Kallithea URL> --apikey=<API key>
Mads Kiilerich
docs: improve the API documentation
r4879
Søren Løvborg
docs: update example output and example server configs...
r5496 This will create a ``~/.config/kallithea`` with the specified URL and API key
Mads Kiilerich
docs: improve the API documentation
r4879 so you don't have to specify them every time.
created rhodecode-api binary script for working with api via cli...
r2379
Mads Kiilerich
docs: rework stuff...
r4902 API methods
Mads Kiilerich
docs: use consistent style for section titles
r5568 -----------
API docs
r1446
Nicolas VINOT
[API] Update doc
r1592
API docs
r1446 pull
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^
API docs
r1446
Mads Kiilerich
docs: improve the API documentation
r4879 Pull the given repo from remote location. Can be used to automatically keep
remote repos up to date.
This command can only be executed using the api_key of a user with admin rights.
Extended API...
r1500
INPUT::
API docs improvement....
r2143 id : <id_for_response>
Nicolas VINOT
[API] Update doc
r1592 api_key : "<api_key>"
method : "pull"
args : {
return proper id from users_group...
r2531 "repoid" : "<reponame or repo_id>"
Nicolas VINOT
[API] Update doc
r1592 }
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
result : "Pulled from `<reponame>`"
Nicolas VINOT
[API] Update doc
r1592 error : null
API: Added option to rescann repositories via api call
r2697 rescan_repos
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^^^^
API: Added option to rescann repositories via api call
r2697
Michael V. DePalatis
docs: English and consistency corrections
r4955 Rescan repositories. If ``remove_obsolete`` is set,
Kallithea will delete repos that are in the database but not in the filesystem.
Mads Kiilerich
docs: improve the API documentation
r4879 This command can only be executed using the api_key of a user with admin rights.
API: Added option to rescann repositories via api call
r2697
INPUT::
id : <id_for_response>
api_key : "<api_key>"
method : "rescan_repos"
args : {
"remove_obsolete" : "<boolean = Optional(False)>"
}
OUTPUT::
id : <id_given_in_input>
whitespace cleanup
r3224 result : "{'added': [<list of names of added repos>],
API: Added option to rescann repositories via api call
r2697 'removed': [<list of names of removed repos>]}"
error : null
API invalidate_cache function ref #733
r3235 invalidate_cache
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^^^^^^^^
API invalidate_cache function ref #733
r3235
Michael V. DePalatis
docs: English and consistency corrections
r4955 Invalidate the cache for a repository.
Mads Kiilerich
docs: improve the API documentation
r4879 This command can only be executed using the api_key of a user with admin rights,
or that of a regular user with admin or write access to the repository.
API invalidate_cache function ref #733
r3235
INPUT::
id : <id_for_response>
api_key : "<api_key>"
method : "invalidate_cache"
args : {
"repoid" : "<reponame or repo_id>"
}
OUTPUT::
id : <id_given_in_input>
Mads Kiilerich
api: don't report invalidated cache_keys after invalidating a repo...
r3759 result : "Caches of repository `<reponame>`"
API invalidate_cache function ref #733
r3235 error : null
Rasmus Selsmark
Corrected method names in documentation, to match API
r4493 get_ip
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^
added API method for checking IP
r3126
Mads Kiilerich
docs: improve the API documentation
r4879 Return IP address as seen from Kallithea server, together with all
added API method for checking IP
r3126 defined IP addresses for given user.
Mads Kiilerich
docs: improve the API documentation
r4879 This command can only be executed using the api_key of a user with admin rights.
added API method for checking IP
r3126
INPUT::
id : <id_for_response>
api_key : "<api_key>"
Rasmus Selsmark
Corrected method names in documentation, to match API
r4493 method : "get_ip"
added API method for checking IP
r3126 args : {
"userid" : "<user_id or username>",
}
OUTPUT::
id : <id_given_in_input>
result : {
"ip_addr_server": <ip_from_clien>",
"user_ips": [
{
"ip_addr": "<ip_with_mask>",
"ip_range": ["<start_ip>", "<end_ip>"],
},
...
]
}
whitespace cleanup
r3224
added API method for checking IP
r3126 error : null
api review...
r1843 get_user
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^
api review...
r1843
Mads Kiilerich
docs: improve the API documentation
r4879 Get a user by username or userid. The result is empty if user can't be found.
If userid param is skipped, it is set to id of user who is calling this method.
Any userid can be specified when the command is executed using the api_key of a user with admin rights.
timeless@gmail.com
spelling: specify
r5829 Regular users can only specify their own userid.
api review...
r1843
INPUT::
API docs improvement....
r2143 id : <id_for_response>
api review...
r1843 api_key : "<api_key>"
method : "get_user"
whitespace cleanup
r3224 args : {
API method get_user can be executed by non-admin users ref #539
r3162 "userid" : "<username or user_id Optional(=apiuser)>"
api review...
r1843 }
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
whitespace cleanup
r3224 result: None if user does not exist or
api review...
r1843 {
add ipaddresses to repo data on API calls
r3127 "user_id" : "<user_id>",
updated api docs
r3213 "api_key" : "<api_key>",
add ipaddresses to repo data on API calls
r3127 "username" : "<username>",
"firstname": "<firstname>",
"lastname" : "<lastname>",
"email" : "<email>",
"emails": "<list_of_all_additional_emails>",
"ip_addresses": "<list_of_ip_addresses_for_user>",
"active" : "<bool>",
"admin" :  "<bool>",
"ldap_dn" : "<ldap_dn>",
"last_login": "<last_login>",
#404 API extensions for showing permission for users...
r2151 "permissions": {
"global": ["hg.create.repository",
"repository.read",
"hg.register.manual_activate"],
"repositories": {"repo1": "repository.none"},
"repositories_groups": {"Group1": "group.read"}
},
api review...
r1843 }
error: null
Nicolas VINOT
[API] Update doc
r1592 get_users
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^
Nicolas VINOT
[API] Update doc
r1592
Mads Kiilerich
docs: improve the API documentation
r4879 List all existing users.
This command can only be executed using the api_key of a user with admin rights.
Nicolas VINOT
[API] Update doc
r1592
INPUT::
API docs improvement....
r2143 id : <id_for_response>
Nicolas VINOT
[API] Update doc
r1592 api_key : "<api_key>"
method : "get_users"
args : { }
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
Nicolas VINOT
[API] Update doc
r1592 result: [
{
add ipaddresses to repo data on API calls
r3127 "user_id" : "<user_id>",
Ton Plomp
api.rst edited online with Bitbucket...
r3940 "api_key" : "<api_key>",
add ipaddresses to repo data on API calls
r3127 "username" : "<username>",
"firstname": "<firstname>",
"lastname" : "<lastname>",
"email" : "<email>",
"emails": "<list_of_all_additional_emails>",
"ip_addresses": "<list_of_ip_addresses_for_user>",
"active" : "<bool>",
"admin" :  "<bool>",
"ldap_dn" : "<ldap_dn>",
"last_login": "<last_login>",
Nicolas VINOT
[API] Update doc
r1592 },
Mads Kiilerich
coding style: fix trailing and leading spaces and tabs
r3267
Nicolas VINOT
[API] Update doc
r1592 ]
error: null
Søren Løvborg
docs: spelling, grammar, content and typography
r5425 .. _create-user:
Nicolas VINOT
[API] Update doc
r1592 create_user
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^^^
Nicolas VINOT
[API] Update doc
r1592
Mads Kiilerich
docs: improve the API documentation
r4879 Create new user.
This command can only be executed using the api_key of a user with admin rights.
Nicolas VINOT
[API] Update doc
r1592
INPUT::
API docs improvement....
r2143 id : <id_for_response>
Nicolas VINOT
[API] Update doc
r1592 api_key : "<api_key>"
method : "create_user"
args : {
"username" : "<username>",
return proper id from users_group...
r2531 "email" : "<useremail>",
make the password optional in API calls
r3809 "password" : "<password = Optional(None)>",
return proper id from users_group...
r2531 "firstname" : "<firstname> = Optional(None)",
"lastname" : "<lastname> = Optional(None)",
"active" : "<bool> = Optional(True)",
"admin" : "<bool> = Optional(False)",
"ldap_dn" : "<ldap_dn> = Optional(None)"
Nicolas VINOT
[API] Update doc
r1592 }
Extended API...
r1500
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
Nicolas VINOT
[API] Update doc
r1592 result: {
return proper id from users_group...
r2531 "msg" : "created new user `<username>`",
API, added delete_user method....
r2365 "user": {
return proper id from users_group...
r2531 "user_id" : "<user_id>",
API, added delete_user method....
r2365 "username" : "<username>",
"firstname": "<firstname>",
"lastname" : "<lastname>",
"email" : "<email>",
return proper id from users_group...
r2531 "emails": "<list_of_all_additional_emails>",
API, added delete_user method....
r2365 "active" : "<bool>",
"admin" :  "<bool>",
"ldap_dn" : "<ldap_dn>",
"last_login": "<last_login>",
},
Nicolas VINOT
[API] Update doc
r1592 }
error: null
Søren Løvborg
docs: spelling, grammar, content and typography
r5425 Example::
kallithea-api create_user username:bent email:bent@example.com firstname:Bent lastname:Bentsen extern_type:ldap extern_name:uid=bent,dc=example,dc=com
API added explicit method for updating user account
r2002 update_user
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^^^
API added explicit method for updating user account
r2002
Mads Kiilerich
docs: improve the API documentation
r4879 Update the given user if such user exists.
This command can only be executed using the api_key of a user with admin rights.
API added explicit method for updating user account
r2002
INPUT::
API docs improvement....
r2143 id : <id_for_response>
API added explicit method for updating user account
r2002 api_key : "<api_key>"
method : "update_user"
args : {
API updates...
r2009 "userid" : "<user_id or username>",
API method get_user can be executed by non-admin users ref #539
r3162 "username" : "<username> = Optional(None)",
"email" : "<useremail> = Optional(None)",
"password" : "<password> = Optional(None)",
"firstname" : "<firstname> = Optional(None)",
"lastname" : "<lastname> = Optional(None)",
"active" : "<bool> = Optional(None)",
"admin" : "<bool> = Optional(None)",
"ldap_dn" : "<ldap_dn> = Optional(None)"
API added explicit method for updating user account
r2002 }
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
API added explicit method for updating user account
r2002 result: {
API: update_user returns new updated user data
r2507 "msg" : "updated user ID:<userid> <username>",
"user": {
return proper id from users_group...
r2531 "user_id" : "<user_id>",
Ton Plomp
api.rst edited online with Bitbucket...
r3940 "api_key" : "<api_key>",
API: update_user returns new updated user data
r2507 "username" : "<username>",
"firstname": "<firstname>",
"lastname" : "<lastname>",
"email" : "<email>",
return proper id from users_group...
r2531 "emails": "<list_of_all_additional_emails>",
API: update_user returns new updated user data
r2507 "active" : "<bool>",
"admin" :  "<bool>",
"ldap_dn" : "<ldap_dn>",
"last_login": "<last_login>",
whitespace cleanup
r3224 },
API, added delete_user method....
r2365 }
error: null
delete_user
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^^^
API, added delete_user method....
r2365
Michael V. DePalatis
docs: English and consistency corrections
r4955 Delete the given user if such a user exists.
Mads Kiilerich
docs: improve the API documentation
r4879 This command can only be executed using the api_key of a user with admin rights.
API, added delete_user method....
r2365
INPUT::
id : <id_for_response>
api_key : "<api_key>"
method : "delete_user"
args : {
"userid" : "<user_id or username>",
}
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
API, added delete_user method....
r2365 result: {
return proper id from users_group...
r2531 "msg" : "deleted user ID:<userid> <username>",
"user": null
API added explicit method for updating user account
r2002 }
error: null
Rasmus Selsmark
Corrected method names in documentation, to match API
r4493 get_user_group
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^^^^^^
Nicolas VINOT
[API] Update doc
r1592
Mads Kiilerich
docs: improve the API documentation
r4879 Get an existing user group.
This command can only be executed using the api_key of a user with admin rights.
Nicolas VINOT
[API] Update doc
r1592
INPUT::
API docs improvement....
r2143 id : <id_for_response>
Nicolas VINOT
[API] Update doc
r1592 api_key : "<api_key>"
Rasmus Selsmark
Corrected method names in documentation, to match API
r4493 method : "get_user_group"
Nicolas VINOT
[API] Update doc
r1592 args : {
Rasmus Selsmark
Corrected method names in documentation, to match API
r4493 "usergroupid" : "<user group id or name>"
Nicolas VINOT
[API] Update doc
r1592 }
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
Nicolas VINOT
[API] Update doc
r1592 result : None if group not exist
{
return proper id from users_group...
r2531 "users_group_id" : "<id>",
"group_name" : "<groupname>",
"active": "<bool>",
Nicolas VINOT
[API] Update doc
r1592 "members" : [
whitespace cleanup
r3224 {
return proper id from users_group...
r2531 "user_id" : "<user_id>",
Ton Plomp
api.rst edited online with Bitbucket...
r3940 "api_key" : "<api_key>",
api review...
r1843 "username" : "<username>",
"firstname": "<firstname>",
"lastname" : "<lastname>",
"email" : "<email>",
return proper id from users_group...
r2531 "emails": "<list_of_all_additional_emails>",
api review...
r1843 "active" : "<bool>",
"admin" :  "<bool>",
return proper id from users_group...
r2531 "ldap_dn" : "<ldap_dn>",
"last_login": "<last_login>",
api review...
r1843 },
]
Nicolas VINOT
[API] Update doc
r1592 }
error : null
Rasmus Selsmark
Corrected method names in documentation, to match API
r4493 get_user_groups
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^^^^^^^
api review...
r1843
Mads Kiilerich
docs: improve the API documentation
r4879 List all existing user groups.
This command can only be executed using the api_key of a user with admin rights.
api review...
r1843
INPUT::
API docs improvement....
r2143 id : <id_for_response>
api review...
r1843 api_key : "<api_key>"
Rasmus Selsmark
Corrected method names in documentation, to match API
r4493 method : "get_user_groups"
api review...
r1843 args : { }
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
api review...
r1843 result : [
{
return proper id from users_group...
r2531 "users_group_id" : "<id>",
"group_name" : "<groupname>",
"active": "<bool>",
},
api review...
r1843 ]
error : null
Rasmus Selsmark
Corrected method names in documentation, to match API
r4493 create_user_group
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^^^^^^^^^
Extended API...
r1500
Mads Kiilerich
docs: improve the API documentation
r4879 Create a new user group.
This command can only be executed using the api_key of a user with admin rights.
Extended API...
r1500
INPUT::
API docs improvement....
r2143 id : <id_for_response>
Nicolas VINOT
[API] Update doc
r1592 api_key : "<api_key>"
Rasmus Selsmark
Corrected method names in documentation, to match API
r4493 method : "create_user_group"
Nicolas VINOT
[API] Update doc
r1592 args: {
- Manage User’s Groups: create, delete, rename, add/remove users inside....
r3714 "group_name": "<groupname>",
Mads Kiilerich
docs: add documentation for update_repo API
r5274 "owner" : "<owner_name_or_id = Optional(=apiuser)>",
- Manage User’s Groups: create, delete, rename, add/remove users inside....
r3714 "active": "<bool> = Optional(True)"
Nicolas VINOT
[API] Update doc
r1592 }
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
Nicolas VINOT
[API] Update doc
r1592 result: {
Mads Kiilerich
"Users groups" is grammatically incorrect English - rename to "user groups"...
r3410 "msg": "created new user group `<groupname>`",
return proper id from users_group...
r2531 "users_group": {
"users_group_id" : "<id>",
"group_name" : "<groupname>",
"active": "<bool>",
},
Nicolas VINOT
[API] Update doc
r1592 }
error: null
Rasmus Selsmark
Corrected method names in documentation, to match API
r4493 add_user_to_user_group
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^^^^^^^^^^^^^^
Nicolas VINOT
[API] Update doc
r1592
Michael V. DePalatis
docs: English and consistency corrections
r4955 Adds a user to a user group. If the user already is in that group, success will be
``false``.
Mads Kiilerich
docs: improve the API documentation
r4879 This command can only be executed using the api_key of a user with admin rights.
Nicolas VINOT
[API] Update doc
r1592
INPUT::
API docs improvement....
r2143 id : <id_for_response>
Nicolas VINOT
[API] Update doc
r1592 api_key : "<api_key>"
Rasmus Selsmark
Corrected method names in documentation, to match API
r4493 method : "add_user_user_group"
Nicolas VINOT
[API] Update doc
r1592 args: {
Mads Kiilerich
"Users groups" is grammatically incorrect English - rename to "user groups"...
r3410 "usersgroupid" : "<user group id or name>",
return proper id from users_group...
r2531 "userid" : "<user_id or username>",
Nicolas VINOT
[API] Update doc
r1592 }
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
Nicolas VINOT
[API] Update doc
r1592 result: {
API changes...
r1989 "success": True|False # depends on if member is in group
Mads Kiilerich
docs: improve the API documentation
r4879 "msg": "added member `<username>` to a user group `<groupname>` |
API changes...
r1989 User is already in that group"
}
error: null
Rasmus Selsmark
Corrected method names in documentation, to match API
r4493 remove_user_from_user_group
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
API changes...
r1989
Mads Kiilerich
docs: improve the API documentation
r4879 Remove a user from a user group. If the user isn't in the given group, success will
Michael V. DePalatis
docs: English and consistency corrections
r4955 be ``false``.
Mads Kiilerich
docs: improve the API documentation
r4879 This command can only be executed using the api_key of a user with admin rights.
API changes...
r1989
INPUT::
API docs improvement....
r2143 id : <id_for_response>
API changes...
r1989 api_key : "<api_key>"
Rasmus Selsmark
Corrected method names in documentation, to match API
r4493 method : "remove_user_from_user_group"
API changes...
r1989 args: {
Mads Kiilerich
"Users groups" is grammatically incorrect English - rename to "user groups"...
r3410 "usersgroupid" : "<user group id or name>",
return proper id from users_group...
r2531 "userid" : "<user_id or username>",
API changes...
r1989 }
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
API changes...
r1989 result: {
"success": True|False, # depends on if member is in group
Mads Kiilerich
"Users groups" is grammatically incorrect English - rename to "user groups"...
r3410 "msg": "removed member <username> from user group <groupname> |
API changes...
r1989 User wasn't in group"
Nicolas VINOT
[API] Update doc
r1592 }
error: null
api review...
r1843 get_repo
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^
api review...
r1843
Mads Kiilerich
docs: improve the API documentation
r4879 Get an existing repository by its name or repository_id. Members will contain
Michael V. DePalatis
docs: English and consistency corrections
r4955 either users_group or users associated to that repository.
Mads Kiilerich
docs: improve the API documentation
r4879 This command can only be executed using the api_key of a user with admin rights,
or that of a regular user with at least read access to the repository.
#227 Initial version of repository groups permissions system...
r1982
api review...
r1843 INPUT::
API docs improvement....
r2143 id : <id_for_response>
api review...
r1843 api_key : "<api_key>"
method : "get_repo"
args: {
domruf
api: add optional branches, tags and bookmarks information to get_repo API data...
r6593 "repoid" : "<reponame or repo_id>",
"with_revision_names": "<bool> = Optional(False)",
domruf
api: add option to get pullrequests for get_repo
r6594 "with_pullrequests": "<bool> = Optional(False)",
api review...
r1843 }
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
api review...
r1843 result: None if repository does not exist or
{
Default parameters are now also used for creating repos using API calls, and initial repo scanner...
r3115 "repo_id" : "<repo_id>",
"repo_name" : "<reponame>"
"repo_type" : "<repo_type>",
"clone_uri" : "<clone_uri>",
"enable_downloads": "<bool>",
whitespace cleanup
r3224 "enable_statistics": "<bool>",
Default parameters are now also used for creating repos using API calls, and initial repo scanner...
r3115 "private": "<bool>",
whitespace cleanup
r3224 "created_on" : "<date_time_created>",
Default parameters are now also used for creating repos using API calls, and initial repo scanner...
r3115 "description" : "<description>",
"landing_rev": "<landing_rev>",
added last_changeset information in get_repo API function
r3174 "last_changeset": {
"author": "<full_author>",
"date": "<date_time_of_commit>",
"message": "<commit_message>",
"raw_id": "<raw_id>",
"revision": "<numeric_revision>",
"short_id": "<short_id>"
domruf
api: add optional branches, tags and bookmarks information to get_repo API data...
r6593 },
Default parameters are now also used for creating repos using API calls, and initial repo scanner...
r3115 "owner": "<repo_owner>",
"fork_of": "<name_of_fork_parent>",
api review...
r1843 "members" : [
whitespace cleanup
r3224 {
updated api docs
r3213 "type": "user",
added last_changeset information in get_repo API function
r3174 "user_id" : "<user_id>",
Ton Plomp
api.rst edited online with Bitbucket...
r3940 "api_key" : "<api_key>",
added last_changeset information in get_repo API function
r3174 "username" : "<username>",
"firstname": "<firstname>",
"lastname" : "<lastname>",
"email" : "<email>",
"emails": "<list_of_all_additional_emails>",
"active" : "<bool>",
"admin" :  "<bool>",
"ldap_dn" : "<ldap_dn>",
"last_login": "<last_login>",
api review...
r1843 "permission" : "repository.(read|write|admin)"
},
whitespace cleanup
r3224 {
updated api docs
r3213 "type": "users_group",
api review...
r1843 "id" : "<usersgroupid>",
"name" : "<usersgroupname>",
"active": "<bool>",
"permission" : "repository.(read|write|admin)"
},
domruf
api: add optional branches, tags and bookmarks information to get_repo API data...
r6593 ],
updated api docs
r3213 "followers": [
{
"user_id" : "<user_id>",
"username" : "<username>",
Ton Plomp
api.rst edited online with Bitbucket...
r3940 "api_key" : "<api_key>",
updated api docs
r3213 "firstname": "<firstname>",
"lastname" : "<lastname>",
"email" : "<email>",
"emails": "<list_of_all_additional_emails>",
"ip_addresses": "<list_of_ip_addresses_for_user>",
"active" : "<bool>",
"admin" :  "<bool>",
"ldap_dn" : "<ldap_dn>",
whitespace cleanup
r3224 "last_login": "<last_login>",
updated api docs
r3213 },
whitespace cleanup
r3224
domruf
api: add optional branches, tags and bookmarks information to get_repo API data...
r6593 ],
<if with_revision_names == True>
"tags": {
"<tagname>": "<raw_id>",
...
},
"branches": {
"<branchname>": "<raw_id>",
...
},
"bookmarks": {
"<bookmarkname>": "<raw_id>",
...
},
domruf
api: add option to get pullrequests for get_repo
r6594 <if with_pullrequests == True>
"pull_requests": [
{
"status": "<pull_request_status>",
"pull_request_id": <pull_request_id>,
"description": "<pull_request_description>",
"title": "<pull_request_title>",
"url": "<pull_request_url>",
"reviewers": [
{
"username": "<user_id>",
},
...
],
"org_repo_url": "<repo_url>",
"org_ref_parts": [
"<ref_type>",
"<ref_name>",
"<raw_id>"
],
"other_ref_parts": [
"<ref_type>",
"<ref_name>",
"<raw_id>"
],
"comments": [
{
"username": "<user_id>",
"text": "<comment text>",
"comment_id": "<comment_id>",
},
...
],
"owner": "<username>",
"statuses": [
{
"status": "<status_of_review>", # "under_review", "approved" or "rejected"
"reviewer": "<user_id>",
"modified_at": "<date_time_of_review>" # iso 8601 date, server's timezone
},
...
],
"revisions": [
"<raw_id>",
...
]
},
...
]
api review...
r1843 }
error: null
Nicolas VINOT
[API] Update doc
r1592 get_repos
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^
Nicolas VINOT
[API] Update doc
r1592
Mads Kiilerich
docs: improve the API documentation
r4879 List all existing repositories.
This command can only be executed using the api_key of a user with admin rights,
or that of a regular user with at least read access to the repository.
Nicolas VINOT
[API] Update doc
r1592
INPUT::
API docs improvement....
r2143 id : <id_for_response>
Nicolas VINOT
[API] Update doc
r1592 api_key : "<api_key>"
method : "get_repos"
args: { }
Extended API...
r1500
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
Nicolas VINOT
[API] Update doc
r1592 result: [
{
Default parameters are now also used for creating repos using API calls, and initial repo scanner...
r3115 "repo_id" : "<repo_id>",
"repo_name" : "<reponame>"
"repo_type" : "<repo_type>",
"clone_uri" : "<clone_uri>",
Mads Kiilerich
docs: add documentation for update_repo API
r5274 "private" : "<bool>",
whitespace cleanup
r3224 "created_on" : "<datetimecreated>",
Default parameters are now also used for creating repos using API calls, and initial repo scanner...
r3115 "description" : "<description>",
"landing_rev": "<landing_rev>",
"owner": "<repo_owner>",
"fork_of": "<name_of_fork_parent>",
"enable_downloads": "<bool>",
whitespace cleanup
r3224 "enable_statistics": "<bool>",
Nicolas VINOT
[API] Update doc
r1592 },
]
error: null
implements #330 api method for listing nodes at particular revision...
r1810 get_repo_nodes
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^^^^^^
implements #330 api method for listing nodes at particular revision...
r1810
Mads Kiilerich
docs: improve the API documentation
r4879 Return a list of files and directories for a given path at the given revision.
Michael V. DePalatis
docs: English and consistency corrections
r4955 It is possible to specify ret_type to show only ``files`` or ``dirs``.
Mads Kiilerich
docs: improve the API documentation
r4879 This command can only be executed using the api_key of a user with admin rights.
implements #330 api method for listing nodes at particular revision...
r1810
INPUT::
API docs improvement....
r2143 id : <id_for_response>
implements #330 api method for listing nodes at particular revision...
r1810 api_key : "<api_key>"
method : "get_repo_nodes"
args: {
return proper id from users_group...
r2531 "repoid" : "<reponame or repo_id>"
implements #330 api method for listing nodes at particular revision...
r1810 "revision" : "<revision>",
"root_path" : "<root_path>",
return proper id from users_group...
r2531 "ret_type" : "<ret_type> = Optional('all')"
implements #330 api method for listing nodes at particular revision...
r1810 }
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
implements #330 api method for listing nodes at particular revision...
r1810 result: [
{
"name" : "<name>"
"type" : "<type>",
},
]
error: null
Nicolas VINOT
[API] Update doc
r1592 create_repo
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^^^
Nicolas VINOT
[API] Update doc
r1592
Mads Kiilerich
repos: only allow api repo creation in existing groups...
r7225 Create a repository. If the repository name contains "/", the repository will be
created in the repository group indicated by that path. Any such repository
groups need to exist before calling this method, or the call will fail.
For example "foo/bar/baz" will create a repository "baz" inside the repository
group "bar" which itself is in a repository group "foo", but both "foo" and
"bar" already need to exist before calling this method.
Mads Kiilerich
docs: improve the API documentation
r4879 This command can only be executed using the api_key of a user with admin rights,
or that of a regular user with create repository permission.
Regular users cannot specify owner parameter.
Nicolas VINOT
[API] Update doc
r1592
INPUT::
API docs improvement....
r2143 id : <id_for_response>
Nicolas VINOT
[API] Update doc
r1592 api_key : "<api_key>"
method : "create_repo"
args: {
Default parameters are now also used for creating repos using API calls, and initial repo scanner...
r3115 "repo_name" : "<reponame>",
Mads Kiilerich
docs: add documentation for update_repo API
r5274 "owner" : "<owner_name_or_id = Optional(=apiuser)>",
Default parameters are now also used for creating repos using API calls, and initial repo scanner...
r3115 "repo_type" : "<repo_type> = Optional('hg')",
"description" : "<description> = Optional('')",
"private" : "<bool> = Optional(False)",
"clone_uri" : "<clone_uri> = Optional(None)",
"landing_rev" : "<landing_rev> = Optional('tip')",
"enable_downloads": "<bool> = Optional(False)",
"enable_statistics": "<bool> = Optional(False)",
Nicolas VINOT
[API] Update doc
r1592 }
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
api review...
r1843 result: {
return proper id from users_group...
r2531 "msg": "Created new repository `<reponame>`",
API: create_repo returns now repo object after creation
r2378 "repo": {
Default parameters are now also used for creating repos using API calls, and initial repo scanner...
r3115 "repo_id" : "<repo_id>",
"repo_name" : "<reponame>"
"repo_type" : "<repo_type>",
"clone_uri" : "<clone_uri>",
Mads Kiilerich
docs: add documentation for update_repo API
r5274 "private" : "<bool>",
whitespace cleanup
r3224 "created_on" : "<datetimecreated>",
Default parameters are now also used for creating repos using API calls, and initial repo scanner...
r3115 "description" : "<description>",
"landing_rev": "<landing_rev>",
#699: fix missing fork docs for API
r3122 "owner": "<username or user_id>",
Default parameters are now also used for creating repos using API calls, and initial repo scanner...
r3115 "fork_of": "<name_of_fork_parent>",
"enable_downloads": "<bool>",
whitespace cleanup
r3224 "enable_statistics": "<bool>",
API: create_repo returns now repo object after creation
r2378 },
api review...
r1843 }
Nicolas VINOT
[API] Update doc
r1592 error: null
Mads Kiilerich
docs: add documentation for update_repo API
r5274 update_repo
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^^^
Mads Kiilerich
docs: add documentation for update_repo API
r5274
Update a repository.
This command can only be executed using the api_key of a user with admin rights,
or that of a regular user with create repository permission.
Regular users cannot specify owner parameter.
INPUT::
id : <id_for_response>
api_key : "<api_key>"
method : "update_repo"
args: {
"repoid" : "<reponame or repo_id>"
"name" : "<reponame> = Optional('')",
"group" : "<group_id> = Optional(None)",
"owner" : "<owner_name_or_id = Optional(=apiuser)>",
"description" : "<description> = Optional('')",
"private" : "<bool> = Optional(False)",
"clone_uri" : "<clone_uri> = Optional(None)",
"landing_rev" : "<landing_rev> = Optional('tip')",
"enable_downloads": "<bool> = Optional(False)",
"enable_statistics": "<bool> = Optional(False)",
}
OUTPUT::
id : <id_given_in_input>
result: {
"msg": "updated repo ID:repo_id `<reponame>`",
"repository": {
"repo_id" : "<repo_id>",
"repo_name" : "<reponame>"
"repo_type" : "<repo_type>",
"clone_uri" : "<clone_uri>",
"private": "<bool>",
"created_on" : "<datetimecreated>",
"description" : "<description>",
"landing_rev": "<landing_rev>",
"owner": "<username or user_id>",
"fork_of": "<name_of_fork_parent>",
"enable_downloads": "<bool>",
"enable_statistics": "<bool>",
"last_changeset": {
"author": "<full_author>",
"date": "<date_time_of_commit>",
"message": "<commit_message>",
"raw_id": "<raw_id>",
"revision": "<numeric_revision>",
"short_id": "<short_id>"
}
},
}
error: null
#699: fix missing fork docs for API
r3122 fork_repo
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^
#699: fix missing fork docs for API
r3122
Michael V. DePalatis
docs: English and consistency corrections
r4955 Create a fork of the given repo. If using Celery, this will
return success message immediately and a fork will be created
Mads Kiilerich
docs: improve the API documentation
r4879 asynchronously.
Mads Kiilerich
api: check repo create permissions for update_repo and fork_repo as for create-repo...
r5222 This command can only be executed using the api_key of a user with admin
rights, or with the global fork permission, by a regular user with create
repository permission and at least read access to the repository.
Mads Kiilerich
docs: improve the API documentation
r4879 Regular users cannot specify owner parameter.
#699: fix missing fork docs for API
r3122
INPUT::
id : <id_for_response>
api_key : "<api_key>"
method : "fork_repo"
args: {
"repoid" : "<reponame or repo_id>",
"fork_name": "<forkname>",
API methods create_repo, fork_repo, delete_repo, get_repo, get_repos...
r3163 "owner": "<username or user_id = Optional(=apiuser)>",
#699: fix missing fork docs for API
r3122 "description": "<description>",
"copy_permissions": "<bool>",
"private": "<bool>",
"landing_rev": "<landing_rev>"
whitespace cleanup
r3224
#699: fix missing fork docs for API
r3122 }
OUTPUT::
id : <id_given_in_input>
result: {
"msg": "Created fork of `<reponame>` as `<forkname>`",
"success": true
}
error: null
implements #361 API method for deleting repositories
r2003 delete_repo
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^^^
implements #361 API method for deleting repositories
r2003
Mads Kiilerich
docs: improve the API documentation
r4879 Delete a repository.
This command can only be executed using the api_key of a user with admin rights,
or that of a regular user with admin access to the repository.
Michael V. DePalatis
docs: English and consistency corrections
r4955 When ``forks`` param is set it is possible to detach or delete forks of the deleted repository.
implements #361 API method for deleting repositories
r2003
INPUT::
API docs improvement....
r2143 id : <id_for_response>
implements #361 API method for deleting repositories
r2003 api_key : "<api_key>"
method : "delete_repo"
args: {
recursive forks detach...
r3641 "repoid" : "<reponame or repo_id>",
"forks" : "`delete` or `detach` = Optional(None)"
implements #361 API method for deleting repositories
r2003 }
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
implements #361 API method for deleting repositories
r2003 result: {
return proper id from users_group...
r2531 "msg": "Deleted repository `<reponame>`",
"success": true
implements #361 API method for deleting repositories
r2003 }
error: null
#227 Initial version of repository groups permissions system...
r1982 grant_user_permission
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^^^^^^^^^^^^^
Nicolas VINOT
[API] Update doc
r1592
Michael V. DePalatis
docs: English and consistency corrections
r4955 Grant permission for a user on the given repository, or update the existing one if found.
Mads Kiilerich
docs: improve the API documentation
r4879 This command can only be executed using the api_key of a user with admin rights.
#227 Initial version of repository groups permissions system...
r1982
Nicolas VINOT
[API] Update doc
r1592 INPUT::
API docs improvement....
r2143 id : <id_for_response>
Nicolas VINOT
[API] Update doc
r1592 api_key : "<api_key>"
#227 Initial version of repository groups permissions system...
r1982 method : "grant_user_permission"
Nicolas VINOT
[API] Update doc
r1592 args: {
return proper id from users_group...
r2531 "repoid" : "<reponame or repo_id>"
"userid" : "<username or user_id>"
#227 Initial version of repository groups permissions system...
r1982 "perm" : "(repository.(none|read|write|admin))",
}
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
#227 Initial version of repository groups permissions system...
r1982 result: {
return proper id from users_group...
r2531 "msg" : "Granted perm: `<perm>` for user: `<username>` in repo: `<reponame>`",
"success": true
#227 Initial version of repository groups permissions system...
r1982 }
error: null
revoke_user_permission
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^^^^^^^^^^^^^^
#227 Initial version of repository groups permissions system...
r1982
Michael V. DePalatis
docs: English and consistency corrections
r4955 Revoke permission for a user on the given repository.
Mads Kiilerich
docs: improve the API documentation
r4879 This command can only be executed using the api_key of a user with admin rights.
#227 Initial version of repository groups permissions system...
r1982
INPUT::
API docs improvement....
r2143 id : <id_for_response>
#227 Initial version of repository groups permissions system...
r1982 api_key : "<api_key>"
method : "revoke_user_permission"
args: {
return proper id from users_group...
r2531 "repoid" : "<reponame or repo_id>"
"userid" : "<username or user_id>"
Nicolas VINOT
[API] Update doc
r1592 }
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
api review...
r1843 result: {
return proper id from users_group...
r2531 "msg" : "Revoked perm for user: `<username>` in repo: `<reponame>`",
"success": true
api review...
r1843 }
Nicolas VINOT
[API] Update doc
r1592 error: null
implements #329...
r1793
Rasmus Selsmark
Corrected method names in documentation, to match API
r4493 grant_user_group_permission
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
implements #329...
r1793
Michael V. DePalatis
docs: English and consistency corrections
r4955 Grant permission for a user group on the given repository, or update the
Mads Kiilerich
docs: improve the API documentation
r4879 existing one if found.
This command can only be executed using the api_key of a user with admin rights.
#227 Initial version of repository groups permissions system...
r1982
implements #329...
r1793 INPUT::
API docs improvement....
r2143 id : <id_for_response>
implements #329...
r1793 api_key : "<api_key>"
Rasmus Selsmark
Corrected method names in documentation, to match API
r4493 method : "grant_user_group_permission"
#227 Initial version of repository groups permissions system...
r1982 args: {
return proper id from users_group...
r2531 "repoid" : "<reponame or repo_id>"
Mads Kiilerich
"Users groups" is grammatically incorrect English - rename to "user groups"...
r3410 "usersgroupid" : "<user group id or name>"
#227 Initial version of repository groups permissions system...
r1982 "perm" : "(repository.(none|read|write|admin))",
}
OUTPUT::
return proper id from users_group...
r2531 id : <id_given_in_input>
#227 Initial version of repository groups permissions system...
r1982 result: {
return proper id from users_group...
r2531 "msg" : "Granted perm: `<perm>` for group: `<usersgroupname>` in repo: `<reponame>`",
"success": true
#227 Initial version of repository groups permissions system...
r1982 }
error: null
whitespace cleanup
r3224
Rasmus Selsmark
Corrected method names in documentation, to match API
r4493 revoke_user_group_permission
Mads Kiilerich
docs: use consistent style for section titles
r5568 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
#227 Initial version of repository groups permissions system...
r1982
Michael V. DePalatis
docs: English and consistency corrections
r4955 Revoke permission for a user group on the given repository.
Mads Kiilerich
docs: improve the API documentation
r4879 This command can only be executed using the api_key of a user with admin rights.
#227 Initial version of repository groups permissions system...
r1982
INPUT::
API docs improvement....
r2143 id : <id_for_response>
#227 Initial version of repository groups permissions system...
r1982 api_key : "<api_key>"
Rasmus Selsmark
Corrected method names in documentation, to match API
r4493 method : "revoke_user_group_permission"
implements #329...
r1793 args: {
return proper id from users_group...
r2531 "repoid" : "<reponame or repo_id>"
Mads Kiilerich
"Users groups" is grammatically incorrect English - rename to "user groups"...
r3410 "usersgroupid" : "<user group id or name>"
api review...
r1843 }
#227 Initial version of repository groups permissions system...
r1982
api review...
r1843 OUTPUT::
#227 Initial version of repository groups permissions system...
r1982
return proper id from users_group...
r2531 id : <id_given_in_input>
api review...
r1843 result: {
return proper id from users_group...
r2531 "msg" : "Revoked perm for group: `<usersgroupname>` in repo: `<reponame>`",
"success": true
api review...
r1843 }
whitespace cleanup
r3224 error: null
Mads Kiilerich
docs: make 'API access for web views' less prominent - the official API should come first
r5748
domruf
api: add get_changesets
r6619 get_changesets
^^^^^^^^^^^^^^
Get changesets of a given repository. This command can only be executed using the api_key
of a user with read permissions to the repository.
INPUT::
id : <id_for_response>
api_key : "<api_key>"
method : "get_changesets"
args: {
"repoid" : "<reponame or repo_id>",
"start": "<revision number> = Optional(None)",
"end": "<revision number> = Optional(None)",
"start_date": "<date> = Optional(None)", # in "%Y-%m-%dT%H:%M:%S" format
"end_date": "<date> = Optional(None)", # in "%Y-%m-%dT%H:%M:%S" format
"branch_name": "<branch name filter> = Optional(None)",
"reverse": "<bool> = Optional(False)",
"with_file_list": "<bool> = Optional(False)"
}
OUTPUT::
id : <id_given_in_input>
result: [
{
"raw_id": "<raw_id>",
"short_id": "short_id": "<short_id>",
"author": "<full_author>",
"date": "<date_time_of_commit>",
"message": "<commit_message>",
"revision": "<numeric_revision>",
<if with_file_list == True>
"added": [<list of added files>],
"changed": [<list of changed files>],
"removed": [<list of removed files>]
},
...
]
error: null
Eivind Tagseth
Add JSON-RPC API for reading changeset status...
r6592 get_changeset
^^^^^^^^^^^^^
Get information and review status for a given changeset. This command can only
be executed using the api_key of a user with read permissions to the
repository.
INPUT::
id : <id_for_response>
api_key : "<api_key>"
method : "get_changeset"
args: {
"repoid" : "<reponame or repo_id>",
"raw_id" : "<raw_id>",
"with_reviews": "<bool> = Optional(False)"
}
OUTPUT::
id : <id_given_in_input>
result: {
"author": "<full_author>",
"date": "<date_time_of_commit>",
"message": "<commit_message>",
"raw_id": "<raw_id>",
"revision": "<numeric_revision>",
"short_id": "<short_id>",
"reviews": [{
"reviewer": "<username>",
"modified_at": "<date_time_of_review>", # iso 8601 date, server's timezone
"status": "<status_of_review>", # "under_review", "approved" or "rejected"
},
...
]
}
error: null
Example output::
{
"id" : 1,
"error" : null,
"result" : {
"author" : {
"email" : "user@example.com",
"name" : "Kallithea Admin"
},
"changed" : [],
"short_id" : "e1022d3d28df",
"date" : "2017-03-28T09:09:03",
"added" : [
"README.rst"
],
"removed" : [],
"revision" : 0,
"raw_id" : "e1022d3d28dfba02f626cde65dbe08f4ceb0e4e7",
"message" : "Added file via Kallithea",
"id" : "e1022d3d28dfba02f626cde65dbe08f4ceb0e4e7",
"reviews" : [
{
"status" : "under_review",
"modified_at" : "2017-03-28T09:17:08.618",
"reviewer" : "user"
}
]
}
}
domruf
api: add get_pullrequest and comment_pullrequest methods...
r6595 get_pullrequest
^^^^^^^^^^^^^^^
Get information and review status for a given pull request. This command can only be executed
using the api_key of a user with read permissions to the original repository.
INPUT::
id : <id_for_response>
api_key : "<api_key>"
method : "get_pullrequest"
args: {
"pullrequest_id" : "<pullrequest_id>",
}
OUTPUT::
id : <id_given_in_input>
result: {
"status": "<pull_request_status>",
"pull_request_id": <pull_request_id>,
"description": "<pull_request_description>",
"title": "<pull_request_title>",
"url": "<pull_request_url>",
"reviewers": [
{
"username": "<user_name>",
},
...
],
"org_repo_url": "<repo_url>",
"org_ref_parts": [
"<ref_type>",
"<ref_name>",
"<raw_id>"
],
"other_ref_parts": [
"<ref_type>",
"<ref_name>",
"<raw_id>"
],
"comments": [
{
"username": "<user_name>",
"text": "<comment text>",
"comment_id": "<comment_id>",
},
...
],
"owner": "<username>",
"statuses": [
{
"status": "<status_of_review>", # "under_review", "approved" or "rejected"
"reviewer": "<user_name>",
"modified_at": "<date_time_of_review>" # iso 8601 date, server's timezone
},
...
],
"revisions": [
"<raw_id>",
...
]
},
error: null
comment_pullrequest
^^^^^^^^^^^^^^^^^^^
Add comment, change status or close a given pull request. This command can only be executed
using the api_key of a user with read permissions to the original repository.
INPUT::
id : <id_for_response>
api_key : "<api_key>"
method : "comment_pullrequest"
args: {
"pull_request_id": "<pull_request_id>",
"comment_msg": Optional(''),
"status": Optional(None), # "under_review", "approved" or "rejected"
"close_pr": Optional(False)",
}
OUTPUT::
id : <id_given_in_input>
result: True
error: null
Mads Kiilerich
docs: make 'API access for web views' less prominent - the official API should come first
r5748
API access for web views
------------------------
Mads Kiilerich
auth: drop api_access_controllers_whitelist and give API key auth same access as other kinds of auth...
r7598 Kallithea HTTP entry points can also be accessed without login using bearer
authentication by including this header with the request::
Søren Løvborg
auth: add support for "Bearer" auth scheme (API key variant)...
r6347
Authentication: Bearer <api_key>
Alternatively, the API key can be passed in the URL query string using
``?api_key=<api_key>``, though this is not recommended due to the increased
risk of API key leaks, and support will likely be removed in the future.
Mads Kiilerich
docs: make 'API access for web views' less prominent - the official API should come first
r5748
Exposing raw diffs is a good way to integrate with
third-party services like code review, or build farms that can download archives.