api.rst
1251 lines
| 38.4 KiB
| text/x-rst
|
RstLexer
r1446 | .. _api: | |||
r2095 | === | |||
r1446 | API | |||
=== | ||||
Michael V. DePalatis
|
r4955 | Kallithea has a simple JSON RPC API with a single schema for calling all API | ||
Mads Kiilerich
|
r4879 | methods. Everything is available by sending JSON encoded http(s) requests to | ||
Søren Løvborg
|
r5425 | ``<your_server>/_admin/api``. | ||
Mads Kiilerich
|
r4879 | |||
r1446 | ||||
Søren Løvborg
|
r6500 | API keys | ||
-------- | ||||
r3769 | ||||
Søren Løvborg
|
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. | ||||
r1812 | ||||
Mads Kiilerich
|
r4902 | API access | ||
Mads Kiilerich
|
r5568 | ---------- | ||
r1839 | ||||
Mads Kiilerich
|
r4879 | Clients must send JSON encoded JSON-RPC requests:: | ||
r1446 | ||||
r3224 | { | |||
Mads Kiilerich
|
r4879 | "id: "<id>", | ||
"api_key": "<api_key>", | ||||
"method": "<method_name>", | ||||
"args": {"<arg_key>": "<arg_val>"} | ||||
r1446 | } | |||
Mads Kiilerich
|
r4879 | For example, to pull to a local "CPython" mirror using curl:: | ||
Søren Løvborg
|
r5497 | curl https://kallithea.example.com/_admin/api -X POST -H 'content-type:text/plain' \ | ||
Søren Løvborg
|
r5425 | --data-binary '{"id":1,"api_key":"xe7cdb2v278e4evbdf5vs04v832v0efvcbcve4a3","method":"pull","args":{"repo":"CPython"}}' | ||
r1500 | ||||
Mads Kiilerich
|
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
|
r5425 | - *method*, the name of the method to call -- a list of available methods can be found below. | ||
Mads Kiilerich
|
r4879 | - *args*, the arguments to pass to the method. | ||
Nicolas VINOT
|
r1592 | |||
r1446 | .. note:: | |||
Nicolas VINOT
|
r1592 | |||
Søren Løvborg
|
r5425 | api_key can be found or set on the user account page. | ||
Nicolas VINOT
|
r1592 | |||
Mads Kiilerich
|
r4879 | The response to the JSON-RPC API call will always be a JSON structure:: | ||
Nicolas VINOT
|
r1592 | |||
r3224 | { | |||
Søren Løvborg
|
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) | ||||
r1446 | } | |||
Søren Løvborg
|
r5425 | All responses from the API will be ``HTTP/1.0 200 OK``. If an error occurs, | ||
Mads Kiilerich
|
r4879 | the reponse will have a failure description in *error* and | ||
*result* will be null. | ||||
r1446 | ||||
r2379 | ||||
Mads Kiilerich
|
r4902 | API client | ||
Mads Kiilerich
|
r5568 | ---------- | ||
r2379 | ||||
Søren Løvborg
|
r5425 | Kallithea comes with a ``kallithea-api`` command line tool, providing a convenient | ||
Mads Kiilerich
|
r4879 | way to call the JSON-RPC API. | ||
r3224 | ||||
Michael V. DePalatis
|
r4955 | For example, to call ``get_repo``:: | ||
r2379 | ||||
Søren Løvborg
|
r5496 | kallithea-api --apihost=<Kallithea URL> --apikey=<API key> get_repo | ||
r2379 | ||||
Søren Løvborg
|
r5496 | Calling method get_repo => <Kallithea URL> | ||
Server response | ||||
ERROR:"Missing non optional `repoid` arg in JSON DATA" | ||||
r2379 | ||||
Michael V. DePalatis
|
r4955 | Oops, looks like we forgot to add an argument. Let's try again, now | ||
providing the ``repoid`` as a parameter:: | ||||
r2379 | ||||
Søren Løvborg
|
r5496 | kallithea-api --apihost=<Kallithea URL> --apikey=<API key> get_repo repoid:myrepo | ||
r3224 | ||||
Søren Løvborg
|
r5496 | Calling method get_repo => <Kallithea URL> | ||
Server response | ||||
{ | ||||
"clone_uri": null, | ||||
"created_on": "2015-08-31T14:55:19.042", | ||||
... | ||||
r2379 | ||||
Michael V. DePalatis
|
r4955 | To avoid specifying ``apihost`` and ``apikey`` every time, run:: | ||
Mads Kiilerich
|
r4879 | |||
Søren Løvborg
|
r5496 | kallithea-api --save-config --apihost=<Kallithea URL> --apikey=<API key> | ||
Mads Kiilerich
|
r4879 | |||
Søren Løvborg
|
r5496 | This will create a ``~/.config/kallithea`` with the specified URL and API key | ||
Mads Kiilerich
|
r4879 | so you don't have to specify them every time. | ||
r2379 | ||||
Mads Kiilerich
|
r4902 | API methods | ||
Mads Kiilerich
|
r5568 | ----------- | ||
r1446 | ||||
Nicolas VINOT
|
r1592 | |||
r1446 | pull | |||
Mads Kiilerich
|
r5568 | ^^^^ | ||
r1446 | ||||
Mads Kiilerich
|
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. | ||||
r1500 | ||||
INPUT:: | ||||
r2143 | id : <id_for_response> | |||
Nicolas VINOT
|
r1592 | api_key : "<api_key>" | ||
method : "pull" | ||||
args : { | ||||
r2531 | "repoid" : "<reponame or repo_id>" | |||
Nicolas VINOT
|
r1592 | } | ||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
result : "Pulled from `<reponame>`" | ||||
Nicolas VINOT
|
r1592 | error : null | ||
r2697 | rescan_repos | |||
Mads Kiilerich
|
r5568 | ^^^^^^^^^^^^ | ||
r2697 | ||||
Michael V. DePalatis
|
r4955 | Rescan repositories. If ``remove_obsolete`` is set, | ||
Kallithea will delete repos that are in the database but not in the filesystem. | ||||
Mads Kiilerich
|
r4879 | This command can only be executed using the api_key of a user with admin rights. | ||
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> | ||||
r3224 | result : "{'added': [<list of names of added repos>], | |||
r2697 | 'removed': [<list of names of removed repos>]}" | |||
error : null | ||||
r3235 | invalidate_cache | |||
Mads Kiilerich
|
r5568 | ^^^^^^^^^^^^^^^^ | ||
r3235 | ||||
Michael V. DePalatis
|
r4955 | Invalidate the cache for a repository. | ||
Mads Kiilerich
|
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. | ||||
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
|
r3759 | result : "Caches of repository `<reponame>`" | ||
r3235 | error : null | |||
Rasmus Selsmark
|
r4493 | get_ip | ||
Mads Kiilerich
|
r5568 | ^^^^^^ | ||
r3126 | ||||
Mads Kiilerich
|
r4879 | Return IP address as seen from Kallithea server, together with all | ||
r3126 | defined IP addresses for given user. | |||
Mads Kiilerich
|
r4879 | This command can only be executed using the api_key of a user with admin rights. | ||
r3126 | ||||
INPUT:: | ||||
id : <id_for_response> | ||||
api_key : "<api_key>" | ||||
Rasmus Selsmark
|
r4493 | method : "get_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>"], | ||||
}, | ||||
... | ||||
] | ||||
} | ||||
r3224 | ||||
r3126 | error : null | |||
r1843 | get_user | |||
Mads Kiilerich
|
r5568 | ^^^^^^^^ | ||
r1843 | ||||
Mads Kiilerich
|
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
|
r5829 | Regular users can only specify their own userid. | ||
r1843 | ||||
INPUT:: | ||||
r2143 | id : <id_for_response> | |||
r1843 | api_key : "<api_key>" | |||
method : "get_user" | ||||
r3224 | args : { | |||
r3162 | "userid" : "<username or user_id Optional(=apiuser)>" | |||
r1843 | } | |||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
r3224 | result: None if user does not exist or | |||
r1843 | { | |||
r3127 | "user_id" : "<user_id>", | |||
r3213 | "api_key" : "<api_key>", | |||
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>", | ||||
r2151 | "permissions": { | |||
"global": ["hg.create.repository", | ||||
"repository.read", | ||||
"hg.register.manual_activate"], | ||||
"repositories": {"repo1": "repository.none"}, | ||||
"repositories_groups": {"Group1": "group.read"} | ||||
}, | ||||
r1843 | } | |||
error: null | ||||
Nicolas VINOT
|
r1592 | get_users | ||
Mads Kiilerich
|
r5568 | ^^^^^^^^^ | ||
Nicolas VINOT
|
r1592 | |||
Mads Kiilerich
|
r4879 | List all existing users. | ||
This command can only be executed using the api_key of a user with admin rights. | ||||
Nicolas VINOT
|
r1592 | |||
INPUT:: | ||||
r2143 | id : <id_for_response> | |||
Nicolas VINOT
|
r1592 | api_key : "<api_key>" | ||
method : "get_users" | ||||
args : { } | ||||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
Nicolas VINOT
|
r1592 | result: [ | ||
{ | ||||
r3127 | "user_id" : "<user_id>", | |||
Ton Plomp
|
r3940 | "api_key" : "<api_key>", | ||
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
|
r1592 | }, | ||
Mads Kiilerich
|
r3267 | … | ||
Nicolas VINOT
|
r1592 | ] | ||
error: null | ||||
Søren Løvborg
|
r5425 | .. _create-user: | ||
Nicolas VINOT
|
r1592 | create_user | ||
Mads Kiilerich
|
r5568 | ^^^^^^^^^^^ | ||
Nicolas VINOT
|
r1592 | |||
Mads Kiilerich
|
r4879 | Create new user. | ||
This command can only be executed using the api_key of a user with admin rights. | ||||
Nicolas VINOT
|
r1592 | |||
INPUT:: | ||||
r2143 | id : <id_for_response> | |||
Nicolas VINOT
|
r1592 | api_key : "<api_key>" | ||
method : "create_user" | ||||
args : { | ||||
"username" : "<username>", | ||||
r2531 | "email" : "<useremail>", | |||
r3809 | "password" : "<password = Optional(None)>", | |||
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
|
r1592 | } | ||
r1500 | ||||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
Nicolas VINOT
|
r1592 | result: { | ||
r2531 | "msg" : "created new user `<username>`", | |||
r2365 | "user": { | |||
r2531 | "user_id" : "<user_id>", | |||
r2365 | "username" : "<username>", | |||
"firstname": "<firstname>", | ||||
"lastname" : "<lastname>", | ||||
"email" : "<email>", | ||||
r2531 | "emails": "<list_of_all_additional_emails>", | |||
r2365 | "active" : "<bool>", | |||
"admin" : "<bool>", | ||||
"ldap_dn" : "<ldap_dn>", | ||||
"last_login": "<last_login>", | ||||
}, | ||||
Nicolas VINOT
|
r1592 | } | ||
error: null | ||||
Søren Løvborg
|
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 | ||||
r2002 | update_user | |||
Mads Kiilerich
|
r5568 | ^^^^^^^^^^^ | ||
r2002 | ||||
Mads Kiilerich
|
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. | ||||
r2002 | ||||
INPUT:: | ||||
r2143 | id : <id_for_response> | |||
r2002 | api_key : "<api_key>" | |||
method : "update_user" | ||||
args : { | ||||
r2009 | "userid" : "<user_id or username>", | |||
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)" | ||||
r2002 | } | |||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
r2002 | result: { | |||
r2507 | "msg" : "updated user ID:<userid> <username>", | |||
"user": { | ||||
r2531 | "user_id" : "<user_id>", | |||
Ton Plomp
|
r3940 | "api_key" : "<api_key>", | ||
r2507 | "username" : "<username>", | |||
"firstname": "<firstname>", | ||||
"lastname" : "<lastname>", | ||||
"email" : "<email>", | ||||
r2531 | "emails": "<list_of_all_additional_emails>", | |||
r2507 | "active" : "<bool>", | |||
"admin" : "<bool>", | ||||
"ldap_dn" : "<ldap_dn>", | ||||
"last_login": "<last_login>", | ||||
r3224 | }, | |||
r2365 | } | |||
error: null | ||||
delete_user | ||||
Mads Kiilerich
|
r5568 | ^^^^^^^^^^^ | ||
r2365 | ||||
Michael V. DePalatis
|
r4955 | Delete the given user if such a user exists. | ||
Mads Kiilerich
|
r4879 | This command can only be executed using the api_key of a user with admin rights. | ||
r2365 | ||||
INPUT:: | ||||
id : <id_for_response> | ||||
api_key : "<api_key>" | ||||
method : "delete_user" | ||||
args : { | ||||
"userid" : "<user_id or username>", | ||||
} | ||||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
r2365 | result: { | |||
r2531 | "msg" : "deleted user ID:<userid> <username>", | |||
"user": null | ||||
r2002 | } | |||
error: null | ||||
Rasmus Selsmark
|
r4493 | get_user_group | ||
Mads Kiilerich
|
r5568 | ^^^^^^^^^^^^^^ | ||
Nicolas VINOT
|
r1592 | |||
Mads Kiilerich
|
r4879 | Get an existing user group. | ||
This command can only be executed using the api_key of a user with admin rights. | ||||
Nicolas VINOT
|
r1592 | |||
INPUT:: | ||||
r2143 | id : <id_for_response> | |||
Nicolas VINOT
|
r1592 | api_key : "<api_key>" | ||
Rasmus Selsmark
|
r4493 | method : "get_user_group" | ||
Nicolas VINOT
|
r1592 | args : { | ||
Rasmus Selsmark
|
r4493 | "usergroupid" : "<user group id or name>" | ||
Nicolas VINOT
|
r1592 | } | ||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
Nicolas VINOT
|
r1592 | result : None if group not exist | ||
{ | ||||
r2531 | "users_group_id" : "<id>", | |||
"group_name" : "<groupname>", | ||||
"active": "<bool>", | ||||
Nicolas VINOT
|
r1592 | "members" : [ | ||
r3224 | { | |||
r2531 | "user_id" : "<user_id>", | |||
Ton Plomp
|
r3940 | "api_key" : "<api_key>", | ||
r1843 | "username" : "<username>", | |||
"firstname": "<firstname>", | ||||
"lastname" : "<lastname>", | ||||
"email" : "<email>", | ||||
r2531 | "emails": "<list_of_all_additional_emails>", | |||
r1843 | "active" : "<bool>", | |||
"admin" : "<bool>", | ||||
r2531 | "ldap_dn" : "<ldap_dn>", | |||
"last_login": "<last_login>", | ||||
r1843 | }, | |||
… | ||||
] | ||||
Nicolas VINOT
|
r1592 | } | ||
error : null | ||||
Rasmus Selsmark
|
r4493 | get_user_groups | ||
Mads Kiilerich
|
r5568 | ^^^^^^^^^^^^^^^ | ||
r1843 | ||||
Mads Kiilerich
|
r4879 | List all existing user groups. | ||
This command can only be executed using the api_key of a user with admin rights. | ||||
r1843 | ||||
INPUT:: | ||||
r2143 | id : <id_for_response> | |||
r1843 | api_key : "<api_key>" | |||
Rasmus Selsmark
|
r4493 | method : "get_user_groups" | ||
r1843 | args : { } | |||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
r1843 | result : [ | |||
{ | ||||
r2531 | "users_group_id" : "<id>", | |||
"group_name" : "<groupname>", | ||||
"active": "<bool>", | ||||
}, | ||||
… | ||||
r1843 | ] | |||
error : null | ||||
Rasmus Selsmark
|
r4493 | create_user_group | ||
Mads Kiilerich
|
r5568 | ^^^^^^^^^^^^^^^^^ | ||
r1500 | ||||
Mads Kiilerich
|
r4879 | Create a new user group. | ||
This command can only be executed using the api_key of a user with admin rights. | ||||
r1500 | ||||
INPUT:: | ||||
r2143 | id : <id_for_response> | |||
Nicolas VINOT
|
r1592 | api_key : "<api_key>" | ||
Rasmus Selsmark
|
r4493 | method : "create_user_group" | ||
Nicolas VINOT
|
r1592 | args: { | ||
r3714 | "group_name": "<groupname>", | |||
Mads Kiilerich
|
r5274 | "owner" : "<owner_name_or_id = Optional(=apiuser)>", | ||
r3714 | "active": "<bool> = Optional(True)" | |||
Nicolas VINOT
|
r1592 | } | ||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
Nicolas VINOT
|
r1592 | result: { | ||
Mads Kiilerich
|
r3410 | "msg": "created new user group `<groupname>`", | ||
r2531 | "users_group": { | |||
"users_group_id" : "<id>", | ||||
"group_name" : "<groupname>", | ||||
"active": "<bool>", | ||||
}, | ||||
Nicolas VINOT
|
r1592 | } | ||
error: null | ||||
Rasmus Selsmark
|
r4493 | add_user_to_user_group | ||
Mads Kiilerich
|
r5568 | ^^^^^^^^^^^^^^^^^^^^^^ | ||
Nicolas VINOT
|
r1592 | |||
Michael V. DePalatis
|
r4955 | Adds a user to a user group. If the user already is in that group, success will be | ||
``false``. | ||||
Mads Kiilerich
|
r4879 | This command can only be executed using the api_key of a user with admin rights. | ||
Nicolas VINOT
|
r1592 | |||
INPUT:: | ||||
r2143 | id : <id_for_response> | |||
Nicolas VINOT
|
r1592 | api_key : "<api_key>" | ||
Rasmus Selsmark
|
r4493 | method : "add_user_user_group" | ||
Nicolas VINOT
|
r1592 | args: { | ||
Mads Kiilerich
|
r3410 | "usersgroupid" : "<user group id or name>", | ||
r2531 | "userid" : "<user_id or username>", | |||
Nicolas VINOT
|
r1592 | } | ||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
Nicolas VINOT
|
r1592 | result: { | ||
r1989 | "success": True|False # depends on if member is in group | |||
Mads Kiilerich
|
r4879 | "msg": "added member `<username>` to a user group `<groupname>` | | ||
r1989 | User is already in that group" | |||
} | ||||
error: null | ||||
Rasmus Selsmark
|
r4493 | remove_user_from_user_group | ||
Mads Kiilerich
|
r5568 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||
r1989 | ||||
Mads Kiilerich
|
r4879 | Remove a user from a user group. If the user isn't in the given group, success will | ||
Michael V. DePalatis
|
r4955 | be ``false``. | ||
Mads Kiilerich
|
r4879 | This command can only be executed using the api_key of a user with admin rights. | ||
r1989 | ||||
INPUT:: | ||||
r2143 | id : <id_for_response> | |||
r1989 | api_key : "<api_key>" | |||
Rasmus Selsmark
|
r4493 | method : "remove_user_from_user_group" | ||
r1989 | args: { | |||
Mads Kiilerich
|
r3410 | "usersgroupid" : "<user group id or name>", | ||
r2531 | "userid" : "<user_id or username>", | |||
r1989 | } | |||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
r1989 | result: { | |||
"success": True|False, # depends on if member is in group | ||||
Mads Kiilerich
|
r3410 | "msg": "removed member <username> from user group <groupname> | | ||
r1989 | User wasn't in group" | |||
Nicolas VINOT
|
r1592 | } | ||
error: null | ||||
r1843 | get_repo | |||
Mads Kiilerich
|
r5568 | ^^^^^^^^ | ||
r1843 | ||||
Mads Kiilerich
|
r4879 | Get an existing repository by its name or repository_id. Members will contain | ||
Michael V. DePalatis
|
r4955 | either users_group or users associated to that repository. | ||
Mads Kiilerich
|
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. | ||||
r1982 | ||||
r1843 | INPUT:: | |||
r2143 | id : <id_for_response> | |||
r1843 | api_key : "<api_key>" | |||
method : "get_repo" | ||||
args: { | ||||
domruf
|
r6593 | "repoid" : "<reponame or repo_id>", | ||
"with_revision_names": "<bool> = Optional(False)", | ||||
domruf
|
r6594 | "with_pullrequests": "<bool> = Optional(False)", | ||
r1843 | } | |||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
r1843 | result: None if repository does not exist or | |||
{ | ||||
r3115 | "repo_id" : "<repo_id>", | |||
"repo_name" : "<reponame>" | ||||
"repo_type" : "<repo_type>", | ||||
"clone_uri" : "<clone_uri>", | ||||
"enable_downloads": "<bool>", | ||||
r3224 | "enable_statistics": "<bool>", | |||
r3115 | "private": "<bool>", | |||
r3224 | "created_on" : "<date_time_created>", | |||
r3115 | "description" : "<description>", | |||
"landing_rev": "<landing_rev>", | ||||
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
|
r6593 | }, | ||
r3115 | "owner": "<repo_owner>", | |||
"fork_of": "<name_of_fork_parent>", | ||||
r1843 | "members" : [ | |||
r3224 | { | |||
r3213 | "type": "user", | |||
r3174 | "user_id" : "<user_id>", | |||
Ton Plomp
|
r3940 | "api_key" : "<api_key>", | ||
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>", | ||||
r1843 | "permission" : "repository.(read|write|admin)" | |||
}, | ||||
… | ||||
r3224 | { | |||
r3213 | "type": "users_group", | |||
r1843 | "id" : "<usersgroupid>", | |||
"name" : "<usersgroupname>", | ||||
"active": "<bool>", | ||||
"permission" : "repository.(read|write|admin)" | ||||
}, | ||||
… | ||||
domruf
|
r6593 | ], | ||
r3213 | "followers": [ | |||
{ | ||||
"user_id" : "<user_id>", | ||||
"username" : "<username>", | ||||
Ton Plomp
|
r3940 | "api_key" : "<api_key>", | ||
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>", | ||||
r3224 | "last_login": "<last_login>", | |||
r3213 | }, | |||
r3224 | … | |||
domruf
|
r6593 | ], | ||
<if with_revision_names == True> | ||||
"tags": { | ||||
"<tagname>": "<raw_id>", | ||||
... | ||||
}, | ||||
"branches": { | ||||
"<branchname>": "<raw_id>", | ||||
... | ||||
}, | ||||
"bookmarks": { | ||||
"<bookmarkname>": "<raw_id>", | ||||
... | ||||
}, | ||||
domruf
|
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>", | ||||
... | ||||
] | ||||
}, | ||||
... | ||||
] | ||||
r1843 | } | |||
error: null | ||||
Nicolas VINOT
|
r1592 | get_repos | ||
Mads Kiilerich
|
r5568 | ^^^^^^^^^ | ||
Nicolas VINOT
|
r1592 | |||
Mads Kiilerich
|
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
|
r1592 | |||
INPUT:: | ||||
r2143 | id : <id_for_response> | |||
Nicolas VINOT
|
r1592 | api_key : "<api_key>" | ||
method : "get_repos" | ||||
args: { } | ||||
r1500 | ||||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
Nicolas VINOT
|
r1592 | result: [ | ||
{ | ||||
r3115 | "repo_id" : "<repo_id>", | |||
"repo_name" : "<reponame>" | ||||
"repo_type" : "<repo_type>", | ||||
"clone_uri" : "<clone_uri>", | ||||
Mads Kiilerich
|
r5274 | "private" : "<bool>", | ||
r3224 | "created_on" : "<datetimecreated>", | |||
r3115 | "description" : "<description>", | |||
"landing_rev": "<landing_rev>", | ||||
"owner": "<repo_owner>", | ||||
"fork_of": "<name_of_fork_parent>", | ||||
"enable_downloads": "<bool>", | ||||
r3224 | "enable_statistics": "<bool>", | |||
Nicolas VINOT
|
r1592 | }, | ||
… | ||||
] | ||||
error: null | ||||
r1810 | get_repo_nodes | |||
Mads Kiilerich
|
r5568 | ^^^^^^^^^^^^^^ | ||
r1810 | ||||
Mads Kiilerich
|
r4879 | Return a list of files and directories for a given path at the given revision. | ||
Michael V. DePalatis
|
r4955 | It is possible to specify ret_type to show only ``files`` or ``dirs``. | ||
Mads Kiilerich
|
r4879 | This command can only be executed using the api_key of a user with admin rights. | ||
r1810 | ||||
INPUT:: | ||||
r2143 | id : <id_for_response> | |||
r1810 | api_key : "<api_key>" | |||
method : "get_repo_nodes" | ||||
args: { | ||||
r2531 | "repoid" : "<reponame or repo_id>" | |||
r1810 | "revision" : "<revision>", | |||
"root_path" : "<root_path>", | ||||
r2531 | "ret_type" : "<ret_type> = Optional('all')" | |||
r1810 | } | |||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
r1810 | result: [ | |||
{ | ||||
"name" : "<name>" | ||||
"type" : "<type>", | ||||
}, | ||||
… | ||||
] | ||||
error: null | ||||
Nicolas VINOT
|
r1592 | create_repo | ||
Mads Kiilerich
|
r5568 | ^^^^^^^^^^^ | ||
Nicolas VINOT
|
r1592 | |||
Mads Kiilerich
|
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
|
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
|
r1592 | |||
INPUT:: | ||||
r2143 | id : <id_for_response> | |||
Nicolas VINOT
|
r1592 | api_key : "<api_key>" | ||
method : "create_repo" | ||||
args: { | ||||
r3115 | "repo_name" : "<reponame>", | |||
Mads Kiilerich
|
r5274 | "owner" : "<owner_name_or_id = Optional(=apiuser)>", | ||
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
|
r1592 | } | ||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
r1843 | result: { | |||
r2531 | "msg": "Created new repository `<reponame>`", | |||
r2378 | "repo": { | |||
r3115 | "repo_id" : "<repo_id>", | |||
"repo_name" : "<reponame>" | ||||
"repo_type" : "<repo_type>", | ||||
"clone_uri" : "<clone_uri>", | ||||
Mads Kiilerich
|
r5274 | "private" : "<bool>", | ||
r3224 | "created_on" : "<datetimecreated>", | |||
r3115 | "description" : "<description>", | |||
"landing_rev": "<landing_rev>", | ||||
r3122 | "owner": "<username or user_id>", | |||
r3115 | "fork_of": "<name_of_fork_parent>", | |||
"enable_downloads": "<bool>", | ||||
r3224 | "enable_statistics": "<bool>", | |||
r2378 | }, | |||
r1843 | } | |||
Nicolas VINOT
|
r1592 | error: null | ||
Mads Kiilerich
|
r5274 | update_repo | ||
Mads Kiilerich
|
r5568 | ^^^^^^^^^^^ | ||
Mads Kiilerich
|
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 | ||||
r3122 | fork_repo | |||
Mads Kiilerich
|
r5568 | ^^^^^^^^^ | ||
r3122 | ||||
Michael V. DePalatis
|
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
|
r4879 | asynchronously. | ||
Mads Kiilerich
|
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
|
r4879 | Regular users cannot specify owner parameter. | ||
r3122 | ||||
INPUT:: | ||||
id : <id_for_response> | ||||
api_key : "<api_key>" | ||||
method : "fork_repo" | ||||
args: { | ||||
"repoid" : "<reponame or repo_id>", | ||||
"fork_name": "<forkname>", | ||||
r3163 | "owner": "<username or user_id = Optional(=apiuser)>", | |||
r3122 | "description": "<description>", | |||
"copy_permissions": "<bool>", | ||||
"private": "<bool>", | ||||
"landing_rev": "<landing_rev>" | ||||
r3224 | ||||
r3122 | } | |||
OUTPUT:: | ||||
id : <id_given_in_input> | ||||
result: { | ||||
"msg": "Created fork of `<reponame>` as `<forkname>`", | ||||
"success": true | ||||
} | ||||
error: null | ||||
r2003 | delete_repo | |||
Mads Kiilerich
|
r5568 | ^^^^^^^^^^^ | ||
r2003 | ||||
Mads Kiilerich
|
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
|
r4955 | When ``forks`` param is set it is possible to detach or delete forks of the deleted repository. | ||
r2003 | ||||
INPUT:: | ||||
r2143 | id : <id_for_response> | |||
r2003 | api_key : "<api_key>" | |||
method : "delete_repo" | ||||
args: { | ||||
r3641 | "repoid" : "<reponame or repo_id>", | |||
"forks" : "`delete` or `detach` = Optional(None)" | ||||
r2003 | } | |||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
r2003 | result: { | |||
r2531 | "msg": "Deleted repository `<reponame>`", | |||
"success": true | ||||
r2003 | } | |||
error: null | ||||
r1982 | grant_user_permission | |||
Mads Kiilerich
|
r5568 | ^^^^^^^^^^^^^^^^^^^^^ | ||
Nicolas VINOT
|
r1592 | |||
Michael V. DePalatis
|
r4955 | Grant permission for a user on the given repository, or update the existing one if found. | ||
Mads Kiilerich
|
r4879 | This command can only be executed using the api_key of a user with admin rights. | ||
r1982 | ||||
Nicolas VINOT
|
r1592 | INPUT:: | ||
r2143 | id : <id_for_response> | |||
Nicolas VINOT
|
r1592 | api_key : "<api_key>" | ||
r1982 | method : "grant_user_permission" | |||
Nicolas VINOT
|
r1592 | args: { | ||
r2531 | "repoid" : "<reponame or repo_id>" | |||
"userid" : "<username or user_id>" | ||||
r1982 | "perm" : "(repository.(none|read|write|admin))", | |||
} | ||||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
r1982 | result: { | |||
r2531 | "msg" : "Granted perm: `<perm>` for user: `<username>` in repo: `<reponame>`", | |||
"success": true | ||||
r1982 | } | |||
error: null | ||||
revoke_user_permission | ||||
Mads Kiilerich
|
r5568 | ^^^^^^^^^^^^^^^^^^^^^^ | ||
r1982 | ||||
Michael V. DePalatis
|
r4955 | Revoke permission for a user on the given repository. | ||
Mads Kiilerich
|
r4879 | This command can only be executed using the api_key of a user with admin rights. | ||
r1982 | ||||
INPUT:: | ||||
r2143 | id : <id_for_response> | |||
r1982 | api_key : "<api_key>" | |||
method : "revoke_user_permission" | ||||
args: { | ||||
r2531 | "repoid" : "<reponame or repo_id>" | |||
"userid" : "<username or user_id>" | ||||
Nicolas VINOT
|
r1592 | } | ||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
r1843 | result: { | |||
r2531 | "msg" : "Revoked perm for user: `<username>` in repo: `<reponame>`", | |||
"success": true | ||||
r1843 | } | |||
Nicolas VINOT
|
r1592 | error: null | ||
r1793 | ||||
Rasmus Selsmark
|
r4493 | grant_user_group_permission | ||
Mads Kiilerich
|
r5568 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||
r1793 | ||||
Michael V. DePalatis
|
r4955 | Grant permission for a user group on the given repository, or update the | ||
Mads Kiilerich
|
r4879 | existing one if found. | ||
This command can only be executed using the api_key of a user with admin rights. | ||||
r1982 | ||||
r1793 | INPUT:: | |||
r2143 | id : <id_for_response> | |||
r1793 | api_key : "<api_key>" | |||
Rasmus Selsmark
|
r4493 | method : "grant_user_group_permission" | ||
r1982 | args: { | |||
r2531 | "repoid" : "<reponame or repo_id>" | |||
Mads Kiilerich
|
r3410 | "usersgroupid" : "<user group id or name>" | ||
r1982 | "perm" : "(repository.(none|read|write|admin))", | |||
} | ||||
OUTPUT:: | ||||
r2531 | id : <id_given_in_input> | |||
r1982 | result: { | |||
r2531 | "msg" : "Granted perm: `<perm>` for group: `<usersgroupname>` in repo: `<reponame>`", | |||
"success": true | ||||
r1982 | } | |||
error: null | ||||
r3224 | ||||
Rasmus Selsmark
|
r4493 | revoke_user_group_permission | ||
Mads Kiilerich
|
r5568 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||
r1982 | ||||
Michael V. DePalatis
|
r4955 | Revoke permission for a user group on the given repository. | ||
Mads Kiilerich
|
r4879 | This command can only be executed using the api_key of a user with admin rights. | ||
r1982 | ||||
INPUT:: | ||||
r2143 | id : <id_for_response> | |||
r1982 | api_key : "<api_key>" | |||
Rasmus Selsmark
|
r4493 | method : "revoke_user_group_permission" | ||
r1793 | args: { | |||
r2531 | "repoid" : "<reponame or repo_id>" | |||
Mads Kiilerich
|
r3410 | "usersgroupid" : "<user group id or name>" | ||
r1843 | } | |||
r1982 | ||||
r1843 | OUTPUT:: | |||
r1982 | ||||
r2531 | id : <id_given_in_input> | |||
r1843 | result: { | |||
r2531 | "msg" : "Revoked perm for group: `<usersgroupname>` in repo: `<reponame>`", | |||
"success": true | ||||
r1843 | } | |||
r3224 | error: null | |||
Mads Kiilerich
|
r5748 | |||
domruf
|
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
|
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
|
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
|
r5748 | |||
API access for web views | ||||
------------------------ | ||||
Mads Kiilerich
|
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
|
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
|
r5748 | |||
Exposing raw diffs is a good way to integrate with | ||||
third-party services like code review, or build farms that can download archives. | ||||