Class: Rhoconnect::User

Inherits:
Model
  • Object
show all
Defined in:
lib/rhoconnect/user.rb

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

Constructor Details

This class inherits a constructor from Rhoconnect::Model

Class Method Details

.authenticate(login, password) ⇒ Object



29
30
31
32
33
34
# File 'lib/rhoconnect/user.rb', line 29

def authenticate(,password)
  return unless is_exist?()
  current_user = load()
  return if current_user.nil?
  return current_user if User.encrypt(password, current_user.salt) == current_user.hashed_password
end

.create(fields = {}) ⇒ Object

Raises:

  • (ArgumentError)


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_tokenObject



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.).id
end

#deleteObject



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

#tokenObject



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., :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