2013-05-14 12:33:31 +00:00
|
|
|
module API
|
2012-09-20 14:44:44 +00:00
|
|
|
# Users API
|
|
|
|
class Session < Grape::API
|
|
|
|
# Login to get token
|
|
|
|
#
|
2013-07-16 08:28:19 +00:00
|
|
|
# Parameters:
|
|
|
|
# login (*required) - user login
|
|
|
|
# email (*required) - user email
|
|
|
|
# password (required) - user password
|
|
|
|
#
|
2012-09-20 14:44:44 +00:00
|
|
|
# Example Request:
|
|
|
|
# POST /session
|
|
|
|
post "/session" do
|
2016-06-10 12:51:16 +00:00
|
|
|
user = Gitlab::Auth.find_with_user_password(params[:email] || params[:login], params[:password])
|
2012-09-20 14:44:44 +00:00
|
|
|
|
2013-07-16 08:28:19 +00:00
|
|
|
return unauthorized! unless user
|
2016-08-17 22:39:20 +00:00
|
|
|
return render_api_error!('401 Unauthorized. You have 2FA enabled. Please use a personal access token to access the API', 401) if user.two_factor_enabled?
|
2013-07-16 08:28:19 +00:00
|
|
|
present user, with: Entities::UserLogin
|
2012-09-20 14:44:44 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|