session.rb
1.15 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
module API
class Session < Grape::API
# Login to get token
#
# Parameters:
# login (*required) - user login or email
# password (required) - user password
#
# Example Request:
# POST /login?login=some&password=pass
post "/login" do
user ||= User.authenticate(params[:login], params[:password], environment)
return unauthorized! unless user
user.generate_private_token!
present user, :with => Entities::UserLogin
end
# Create user.
#
# Parameters:
# email (required) - Email
# password (required) - Password
# login - login
# Example Request:
# POST /register?email=some@mail.com&password=pas&login=some
post "/register" do
required_attributes! [:email, :login, :password]
unique_attributes! User, [:email, :login]
attrs = attributes_for_keys [:email, :login, :password]
attrs[:password_confirmation] = attrs[:password]
user = User.new(attrs)
if user.save
present user, :with => Entities::User
else
something_wrong!
end
end
end
end