2012-06-29 03:46:01 -07:00
|
|
|
module Gitlab
|
|
|
|
# Users API
|
|
|
|
class Users < Grape::API
|
|
|
|
before { authenticate! }
|
|
|
|
|
|
|
|
resource :users do
|
|
|
|
# Get a users list
|
|
|
|
#
|
|
|
|
# Example Request:
|
|
|
|
# GET /users
|
|
|
|
get do
|
2012-09-03 04:46:29 -07:00
|
|
|
@users = paginate User
|
2012-08-10 18:07:50 -04:00
|
|
|
present @users, with: Entities::User
|
2012-06-29 03:46:01 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
# Get a single user
|
|
|
|
#
|
|
|
|
# Parameters:
|
|
|
|
# id (required) - The ID of a user
|
|
|
|
# Example Request:
|
|
|
|
# GET /users/:id
|
|
|
|
get ":id" do
|
|
|
|
@user = User.find(params[:id])
|
2012-08-10 18:07:50 -04:00
|
|
|
present @user, with: Entities::User
|
2012-06-29 03:46:01 -07:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-09-21 04:49:28 -07:00
|
|
|
resource :user do
|
|
|
|
# Get currently authenticated user
|
|
|
|
#
|
|
|
|
# Example Request:
|
|
|
|
# GET /user
|
|
|
|
get do
|
|
|
|
present @current_user, with: Entities::User
|
|
|
|
end
|
|
|
|
|
|
|
|
# Get currently authenticated user's keys
|
|
|
|
#
|
|
|
|
# Example Request:
|
|
|
|
# GET /user/keys
|
|
|
|
get "keys" do
|
|
|
|
present current_user.keys, with: Entities::SSHKey
|
|
|
|
end
|
|
|
|
|
|
|
|
# Get single key owned by currently authenticated user
|
|
|
|
#
|
|
|
|
# Example Request:
|
|
|
|
# GET /user/keys/:id
|
|
|
|
get "keys/:id" do
|
|
|
|
key = current_user.keys.find params[:id]
|
|
|
|
present key, with: Entities::SSHKey
|
|
|
|
end
|
|
|
|
|
|
|
|
# Add new ssh key to currently authenticated user
|
|
|
|
#
|
|
|
|
# Parameters:
|
|
|
|
# key (required) - New SSH Key
|
|
|
|
# title (required) - New SSH Key's title
|
|
|
|
# Example Request:
|
|
|
|
# POST /user/keys
|
|
|
|
post "keys" do
|
|
|
|
attrs = attributes_for_keys [:title, :key]
|
|
|
|
key = current_user.keys.new attrs
|
|
|
|
if key.save
|
|
|
|
present key, with: Entities::SSHKey
|
|
|
|
else
|
|
|
|
not_found!
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Delete existed ssh key of currently authenticated user
|
|
|
|
#
|
|
|
|
# Parameters:
|
|
|
|
# id (required) - SSH Key ID
|
|
|
|
# Example Request:
|
|
|
|
# DELETE /user/keys/:id
|
|
|
|
delete "keys/:id" do
|
|
|
|
key = current_user.keys.find params[:id]
|
|
|
|
key.delete
|
|
|
|
end
|
2012-06-29 03:46:01 -07:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|