2012-07-05 06:57:45 -07:00
|
|
|
## List users
|
|
|
|
|
|
|
|
Get a list of users.
|
|
|
|
|
|
|
|
```
|
|
|
|
GET /users
|
|
|
|
```
|
|
|
|
|
|
|
|
```json
|
|
|
|
[
|
|
|
|
{
|
|
|
|
"id": 1,
|
2012-12-10 23:46:31 +01:00
|
|
|
"username": "john_smith",
|
2012-07-05 06:57:45 -07:00
|
|
|
"email": "john@example.com",
|
|
|
|
"name": "John Smith",
|
|
|
|
"blocked": false,
|
|
|
|
"created_at": "2012-05-23T08:00:58Z",
|
|
|
|
"bio": null,
|
|
|
|
"skype": "",
|
|
|
|
"linkedin": "",
|
|
|
|
"twitter": "",
|
|
|
|
"dark_scheme": false,
|
2012-12-18 21:24:31 +02:00
|
|
|
"extern_uid": "john.smith",
|
|
|
|
"provider": "provider_name",
|
2012-07-05 06:57:45 -07:00
|
|
|
"theme_id": 1
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"id": 2,
|
2012-12-10 23:46:31 +01:00
|
|
|
"username": "jack_smith",
|
2012-07-05 06:57:45 -07:00
|
|
|
"email": "jack@example.com",
|
|
|
|
"name": "Jack Smith",
|
|
|
|
"blocked": false,
|
|
|
|
"created_at": "2012-05-23T08:01:01Z",
|
|
|
|
"bio": null,
|
|
|
|
"skype": "",
|
|
|
|
"linkedin": "",
|
|
|
|
"twitter": "",
|
|
|
|
"dark_scheme": true,
|
2012-12-18 21:24:31 +02:00
|
|
|
"extern_uid": "jack.smith",
|
|
|
|
"provider": "provider_name",
|
2012-07-05 06:57:45 -07:00
|
|
|
"theme_id": 1
|
|
|
|
}
|
|
|
|
]
|
|
|
|
```
|
|
|
|
|
2013-02-18 11:15:26 +01:00
|
|
|
Return values:
|
|
|
|
|
|
|
|
+ `200 Ok` on success and a list with all users
|
|
|
|
+ `401 Unauthorized` if user is not allowed to access the list
|
|
|
|
|
|
|
|
|
2012-07-05 06:57:45 -07:00
|
|
|
## Single user
|
|
|
|
|
|
|
|
Get a single user.
|
|
|
|
|
|
|
|
```
|
|
|
|
GET /users/:id
|
|
|
|
```
|
|
|
|
|
|
|
|
Parameters:
|
|
|
|
|
|
|
|
+ `id` (required) - The ID of a user
|
|
|
|
|
|
|
|
```json
|
|
|
|
{
|
|
|
|
"id": 1,
|
2012-12-10 23:46:31 +01:00
|
|
|
"username": "john_smith",
|
2012-07-05 06:57:45 -07:00
|
|
|
"email": "john@example.com",
|
|
|
|
"name": "John Smith",
|
|
|
|
"blocked": false,
|
|
|
|
"created_at": "2012-05-23T08:00:58Z",
|
|
|
|
"bio": null,
|
|
|
|
"skype": "",
|
|
|
|
"linkedin": "",
|
|
|
|
"twitter": "",
|
|
|
|
"dark_scheme": false,
|
2012-12-18 21:24:31 +02:00
|
|
|
"extern_uid": "john.smith",
|
|
|
|
"provider": "provider_name",
|
2012-07-05 06:57:45 -07:00
|
|
|
"theme_id": 1
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2013-02-18 11:15:26 +01:00
|
|
|
Return values:
|
|
|
|
|
|
|
|
+ `200 Ok` on success and the user entry
|
|
|
|
+ `401 Unauthorized` if it is not allowed to access the user
|
|
|
|
+ `404 Not Found` if the user with ID is not found
|
|
|
|
|
|
|
|
|
2012-10-02 12:52:13 +03:00
|
|
|
## User creation
|
2013-02-20 12:10:51 +01:00
|
|
|
|
|
|
|
Creates a new user. Note only administrators can create new users.
|
2012-10-02 12:52:13 +03:00
|
|
|
|
|
|
|
```
|
|
|
|
POST /users
|
|
|
|
```
|
|
|
|
|
|
|
|
Parameters:
|
|
|
|
|
2013-02-20 12:10:51 +01:00
|
|
|
+ `email` (required) - Email
|
|
|
|
+ `password` (required) - Password
|
|
|
|
+ `username` (required) - Username
|
|
|
|
+ `name` (required) - Name
|
|
|
|
+ `skype` (optional) - Skype ID
|
|
|
|
+ `linkedin` (optional) - Linkedin
|
|
|
|
+ `twitter` (optional) - Twitter account
|
|
|
|
+ `projects_limit` (optional) - Number of projects user can create
|
|
|
|
+ `extern_uid` (optional) - External UID
|
|
|
|
+ `provider` (optional) - External provider name
|
|
|
|
+ `bio` (optional) - User's bio
|
|
|
|
|
|
|
|
Return values:
|
|
|
|
|
|
|
|
+ `201 Created` on success and returns the new user
|
|
|
|
+ `400 Bad Request` if one of the required attributes is missing from the request
|
|
|
|
+ `401 Unauthorized` if the user is not authorized
|
|
|
|
+ `403 Forbidden` if the user is not allowed to create a new user (must be admin)
|
|
|
|
+ `404 Not Found` if something else fails
|
|
|
|
+ `409 Conflict` if a user with the same email address or username already exists
|
|
|
|
|
2012-10-02 12:52:13 +03:00
|
|
|
|
2012-12-18 21:24:31 +02:00
|
|
|
## User modification
|
2013-02-20 12:10:51 +01:00
|
|
|
|
|
|
|
Modifies an existing user. Only administrators can change attributes of a user.
|
2012-12-18 21:24:31 +02:00
|
|
|
|
|
|
|
```
|
|
|
|
PUT /users/:id
|
|
|
|
```
|
|
|
|
|
|
|
|
Parameters:
|
2013-02-20 12:10:51 +01:00
|
|
|
|
2012-12-18 21:24:31 +02:00
|
|
|
+ `email` - Email
|
|
|
|
+ `username` - Username
|
|
|
|
+ `name` - Name
|
|
|
|
+ `password` - Password
|
|
|
|
+ `skype` - Skype ID
|
|
|
|
+ `linkedin` - Linkedin
|
|
|
|
+ `twitter` - Twitter account
|
|
|
|
+ `projects_limit` - Limit projects wich user can create
|
|
|
|
+ `extern_uid` - External UID
|
|
|
|
+ `provider` - External provider name
|
|
|
|
+ `bio` - User's bio
|
|
|
|
|
2013-02-20 12:10:51 +01:00
|
|
|
Return values:
|
|
|
|
|
|
|
|
+ `200 Ok` on success and returns the new user
|
|
|
|
+ `401 Unauthorized` if the user is not authorized
|
|
|
|
+ `403 Forbidden` if the user is not allowed to create a new user (must be admin)
|
|
|
|
+ `404 Not Found` if something else fails
|
|
|
|
|
|
|
|
Note, at the moment this method does only return a 404 error, even in cases where a 409 (Conflict) would
|
|
|
|
be more appropriate, e.g. when renaming the email address to some exsisting one.
|
2012-12-18 21:24:31 +02:00
|
|
|
|
|
|
|
|
|
|
|
## User deletion
|
2013-02-20 12:10:51 +01:00
|
|
|
|
|
|
|
Deletes a user. Available only for administrators. This is an idempotent function, calling this function
|
|
|
|
for a non-existent user id still returns a status code `200 Ok`. The JSON response differs if the user
|
|
|
|
was actually deleted or not. In the former the user is returned and in the latter not.
|
2012-12-18 21:24:31 +02:00
|
|
|
|
|
|
|
```
|
|
|
|
DELETE /users/:id
|
|
|
|
```
|
|
|
|
|
2013-02-20 12:10:51 +01:00
|
|
|
Parameters:
|
|
|
|
|
|
|
|
+ `id` (required) - The ID of the user
|
|
|
|
|
|
|
|
Return values:
|
|
|
|
|
|
|
|
+ `200 Ok` on success and returns the deleted user
|
|
|
|
+ `401 Unauthorized` if the user is not authorized
|
|
|
|
+ `403 Forbidden` if the user is not allowed to create a new user (must be admin)
|
|
|
|
+ `404 Not Found` if user with ID not found or something else fails
|
|
|
|
|
2012-12-18 21:24:31 +02:00
|
|
|
|
2012-07-05 06:57:45 -07:00
|
|
|
## Current user
|
|
|
|
|
2013-02-20 12:10:51 +01:00
|
|
|
Gets currently authenticated user.
|
2012-07-05 06:57:45 -07:00
|
|
|
|
|
|
|
```
|
|
|
|
GET /user
|
|
|
|
```
|
|
|
|
|
|
|
|
```json
|
|
|
|
{
|
|
|
|
"id": 1,
|
2012-12-10 23:46:31 +01:00
|
|
|
"username": "john_smith",
|
2012-07-05 06:57:45 -07:00
|
|
|
"email": "john@example.com",
|
|
|
|
"name": "John Smith",
|
|
|
|
"blocked": false,
|
|
|
|
"created_at": "2012-05-23T08:00:58Z",
|
|
|
|
"bio": null,
|
|
|
|
"skype": "",
|
|
|
|
"linkedin": "",
|
|
|
|
"twitter": "",
|
|
|
|
"dark_scheme": false,
|
|
|
|
"theme_id": 1
|
|
|
|
}
|
|
|
|
```
|
2012-09-21 04:49:28 -07:00
|
|
|
|
2013-02-20 12:10:51 +01:00
|
|
|
Return values:
|
|
|
|
|
|
|
|
+ `200 Ok` on success and returns the current user
|
|
|
|
+ `401 Unauthorized` if the user is not authorized
|
|
|
|
+ `404 Not Found` if something else fails
|
|
|
|
|
|
|
|
|
2012-09-21 04:49:28 -07:00
|
|
|
## List SSH keys
|
|
|
|
|
|
|
|
Get a list of currently authenticated user's SSH keys.
|
|
|
|
|
|
|
|
```
|
|
|
|
GET /user/keys
|
|
|
|
```
|
|
|
|
|
|
|
|
```json
|
|
|
|
[
|
|
|
|
{
|
|
|
|
"id": 1,
|
|
|
|
"title" : "Public key"
|
|
|
|
"key": "ssh-rsa AAAAB3NzaC1yc2EAAAABJQAAAIEAiPWx6WM4lhHNedGfBpPJNPpZ7yKu+dnn1SJejgt4
|
|
|
|
596k6YjzGGphH2TUxwKzxcKDKKezwkpfnxPkSMkuEspGRt/aZZ9wa++Oi7Qkr8prgHc4
|
|
|
|
soW6NUlfDzpvZK2H5E7eQaSeP3SAwGmQKUFHCddNaP0L+hM7zhFNzjFvpaMgJw0=",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"id": 3,
|
|
|
|
"title" : "Another Public key"
|
|
|
|
"key": "ssh-rsa AAAAB3NzaC1yc2EAAAABJQAAAIEAiPWx6WM4lhHNedGfBpPJNPpZ7yKu+dnn1SJejgt4
|
|
|
|
596k6YjzGGphH2TUxwKzxcKDKKezwkpfnxPkSMkuEspGRt/aZZ9wa++Oi7Qkr8prgHc4
|
|
|
|
soW6NUlfDzpvZK2H5E7eQaSeP3SAwGmQKUFHCddNaP0L+hM7zhFNzjFvpaMgJw0="
|
|
|
|
}
|
|
|
|
]
|
|
|
|
```
|
|
|
|
|
2013-02-20 12:10:51 +01:00
|
|
|
Parameters:
|
|
|
|
|
|
|
|
+ **none**
|
|
|
|
|
|
|
|
Return values:
|
|
|
|
|
|
|
|
+ `200 Ok` on success and a list of ssh keys
|
|
|
|
+ `401 Unauthorized` if the user is not authenticated
|
|
|
|
+ `404 Not Found` if something else fails
|
|
|
|
|
|
|
|
|
2012-09-21 04:49:28 -07:00
|
|
|
## Single SSH key
|
|
|
|
|
|
|
|
Get a single key.
|
|
|
|
|
|
|
|
```
|
|
|
|
GET /user/keys/:id
|
|
|
|
```
|
|
|
|
|
|
|
|
Parameters:
|
|
|
|
|
|
|
|
+ `id` (required) - The ID of an SSH key
|
|
|
|
|
|
|
|
```json
|
|
|
|
{
|
|
|
|
"id": 1,
|
|
|
|
"title" : "Public key"
|
|
|
|
"key": "ssh-rsa AAAAB3NzaC1yc2EAAAABJQAAAIEAiPWx6WM4lhHNedGfBpPJNPpZ7yKu+dnn1SJejgt4
|
|
|
|
596k6YjzGGphH2TUxwKzxcKDKKezwkpfnxPkSMkuEspGRt/aZZ9wa++Oi7Qkr8prgHc4
|
|
|
|
soW6NUlfDzpvZK2H5E7eQaSeP3SAwGmQKUFHCddNaP0L+hM7zhFNzjFvpaMgJw0="
|
|
|
|
}
|
|
|
|
```
|
2013-02-20 12:10:51 +01:00
|
|
|
|
|
|
|
Return values:
|
|
|
|
|
|
|
|
+ `200 Ok` on success and the ssh key with ID
|
|
|
|
+ `401 Unauthorized` if it is not allowed to access the user
|
|
|
|
+ `404 Not Found` if the ssh key with ID not found
|
|
|
|
|
|
|
|
|
2012-09-21 04:49:28 -07:00
|
|
|
## Add SSH key
|
|
|
|
|
2013-02-20 12:10:51 +01:00
|
|
|
Creates a new key owned by the currently authenticated user.
|
2012-09-21 04:49:28 -07:00
|
|
|
|
|
|
|
```
|
|
|
|
POST /user/keys
|
|
|
|
```
|
|
|
|
|
|
|
|
Parameters:
|
|
|
|
|
|
|
|
+ `title` (required) - new SSH Key's title
|
|
|
|
+ `key` (required) - new SSH key
|
|
|
|
|
2013-02-20 12:10:51 +01:00
|
|
|
Return values:
|
|
|
|
|
|
|
|
+ `201 Created` on success and the added key
|
|
|
|
+ `400 Bad Request` if one of the required attributes is not given
|
|
|
|
+ `401 Unauthorized` if user is not authorized to add ssh key
|
|
|
|
+ `404 Not Found` if something else fails
|
|
|
|
|
2012-09-21 04:49:28 -07:00
|
|
|
|
|
|
|
## Delete SSH key
|
|
|
|
|
2013-02-20 12:10:51 +01:00
|
|
|
Deletes key owned by currently authenticated user. This is an idempotent function and calling it on a key that is already
|
|
|
|
deleted or not available results in `200 Ok`.
|
2012-09-21 04:49:28 -07:00
|
|
|
|
|
|
|
```
|
|
|
|
DELETE /user/keys/:id
|
|
|
|
```
|
|
|
|
|
|
|
|
Parameters:
|
|
|
|
|
|
|
|
+ `id` (required) - SSH key ID
|
|
|
|
|
2013-02-20 12:10:51 +01:00
|
|
|
Return values:
|
|
|
|
|
|
|
|
+ `200 Ok` on success
|
|
|
|
+ `401 Unauthorized` if user is not allowed to delete they key
|
|
|
|
+ `404 Not Found` if something else fails
|