Class: Rhoconnect::User
Overview
Inspired by sinatra-authentication Password uses simple sha1 digest for hashing
Instance Attribute Summary
Attributes inherited from Model
#id
Class Method Summary
collapse
Instance Method Summary
collapse
Methods inherited from Model
_field_key, _prefix, class_prefix, #decrement!, field, #field_key, fields, #increment!, #initialize, is_exist?, list, load, marshal_class_name, #next_id, populate_attributes, #redis, redis, set, #to_array, validates_presence_of
Class Method Details
.authenticate(login, password) ⇒ Object
29
30
31
32
33
34
|
# File 'lib/rhoconnect/user.rb', line 29
def authenticate(login,password)
return unless is_exist?(login)
current_user = load(login)
return if current_user.nil?
return current_user if User.encrypt(password, current_user.salt) == current_user.hashed_password
end
|
.create(fields = {}) ⇒ Object
16
17
18
19
20
21
22
23
24
25
26
27
|
# File 'lib/rhoconnect/user.rb', line 16
def create(fields={})
raise ArgumentError.new("Empty login") if (fields[:login].nil? or fields[:login].empty?)
raise ArgumentError.new("Reserved user id #{fields[:login]}") if fields[:login] && fields[:login] == '__shared__'
fields[:id] = fields[:login]
user = super(fields)
if Rhoconnect.stats
Rhoconnect::Stats::Record.set('users') { Store.incr('user:count') }
else
Store.incr('user:count')
end
user
end
|
Instance Method Details
#create_token ⇒ Object
60
61
62
63
64
65
|
# File 'lib/rhoconnect/user.rb', line 60
def create_token
if self.token_id && ApiToken.is_exist?(self.token_id)
self.token.delete
end
self.token_id = ApiToken.create(:user_id => self.login).id
end
|
#delete ⇒ Object
47
48
49
50
51
52
53
54
55
56
57
58
|
# File 'lib/rhoconnect/user.rb', line 47
def delete
clients.members.each do |client_id|
Client.load(client_id,{:source_name => '*'}).delete
end
self.token.delete if self.token
if Rhoconnect.stats
Rhoconnect::Stats::Record.set('users') { Store.decr('user:count') }
else
Store.decr('user:count')
end
super
end
|
#new_password=(pass) ⇒ Object
37
38
39
|
# File 'lib/rhoconnect/user.rb', line 37
def new_password=(pass)
self.password=(pass)
end
|
#password=(pass) ⇒ Object
41
42
43
44
45
|
# File 'lib/rhoconnect/user.rb', line 41
def password=(pass)
@password = pass
self.salt = User.random_string(10) if !self.salt
self.hashed_password = User.encrypt(@password, self.salt)
end
|
#token ⇒ Object
67
68
69
|
# File 'lib/rhoconnect/user.rb', line 67
def token
ApiToken.load(self.token_id)
end
|
#token=(value) ⇒ Object
71
72
73
74
75
76
|
# File 'lib/rhoconnect/user.rb', line 71
def token=(value)
if self.token_id && ApiToken.is_exist?(self.token_id)
self.token.delete
end
self.token_id = ApiToken.create(:user_id => self.login, :value => value).id
end
|
#update(fields) ⇒ Object
78
79
80
81
82
|
# File 'lib/rhoconnect/user.rb', line 78
def update(fields)
fields.each do |key,value|
self.send("#{key.to_sym}=", value) unless key == 'login'
end
end
|