session.rb
1.39 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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
module API
# require 'api/validations/uniqueness'
# Users API
class Session < Grape::API
#params do
# requires :login, :uniqueness => true
#end
# Login to get token
#
# Parameters:
# login (*required) - user login or email
# password (required) - user password
#
# Example Request:
# POST /session
get "/login" do
# post "/session" do
environment = nil #FIXME load the correct environment create a method in helper
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
# name - Name
# Example Request:
# POST /users
# post do
get "register" do
required_attributes! [:email, :login, :password]
attrs = attributes_for_keys [:email, :login, :password]
attrs[:password_confirmation] = attrs[:password]
user = User.new(attrs)
begin
if user.save
present user, :with => Entities::User
else
not_found!
end
rescue
# not_found!
#FIXME See why notfound is not working
{}
end
# user
end
end
end