Class: User

Inherits:
Record show all
Defined in:
lib/yodel/models/security/user.rb

Constant Summary collapse

SALT_ALPHABET =
(65..90).to_a
SALT_LENGTH =
40
PASS_LENGTH =
8

Constants inherited from AbstractRecord

AbstractRecord::CALLBACKS, AbstractRecord::FIELD_CALLBACKS, AbstractRecord::ORDERS

Instance Attribute Summary

Attributes inherited from Record

#mixins, #model, #model_record, #real_record

Attributes inherited from SiteRecord

#site

Attributes inherited from AbstractRecord

#changed, #errors, #stash, #typecast, #values

Instance Method Summary collapse

Methods inherited from Record

#all_children, #append_to_siblings, #children_and_self, #collection, #content, #create_eigenmodel, #create_mixin_instances, #default_values, #delegate_mixins, #destroy_children, #field_sections, #fields, #first_non_blank_response_to, #first_parent, #first_response_to, #get_binding, #has_eigenmodel?, #initialize, #insert_in_siblings, #inspect_hash, #load_model, #model_name, #parent?, #parents, #perform_reload, #prepare_reload_params, #remove_eigenmodel, #remove_from_siblings, #root?, #run_record_after_create_callbacks, #run_record_after_destroy_callbacks, #run_record_after_save_callbacks, #run_record_after_update_callbacks, #run_record_after_validation_callbacks, #run_record_before_create_callbacks, #run_record_before_destroy_callbacks, #run_record_before_save_callbacks, #run_record_before_update_callbacks, #run_record_before_validation_callbacks, #set_content, #siblings, #to_str, #update_search_keywords, #user_allowed_to?, #user_allowed_to_create?, #user_allowed_to_delete?, #user_allowed_to_update?, #user_allowed_to_view?

Methods inherited from SiteRecord

#default_values, #initialize, #inspect_hash, #perform_reload, #prepare_reload_params, #site_id

Methods included from SiteModel

#load, #scoped, #scoped_for

Methods included from MongoModel

#collection, #load, #scoped

Methods included from AbstractModel

#embed_many, #embed_one, #field, #fields, #many, #modify_field, #one, #remove_field

Methods inherited from MongoRecord

#collection, #default_values, #fields, #id, #increment!, #inspect_hash, #load_from_mongo, #load_mongo_document, #perform_destroy, #perform_reload, #perform_save, #set_id

Methods inherited from AbstractRecord

#changed!, #changed?, #clear_key, #default_values, #destroy, #destroyed?, #eql?, #errors?, #field, #field?, #field_was, #fields, #from_json, #get, #get_meta, #get_raw, #hash, #id, #increment!, inherited, #initialize, #inspect, #inspect_hash, #inspect_value, #method_missing, #new?, #prepare_reload_params, #present?, #reload, #save, #save_without_validation, #search_terms, #set, #set_meta, #set_raw, #to_json, #to_str, #trigger_field_callback, #update, #valid?

Constructor Details

This class inherits a constructor from Record

Dynamic Method Handling

This class handles dynamic methods through the method_missing method in the class AbstractRecord

Instance Method Details

#create_salt_and_hash_passwordObject



8
9
10
11
12
13
# File 'lib/yodel/models/security/user.rb', line 8

def create_salt_and_hash_password
  self.password_salt = ''
  SALT_LENGTH.times {self.password_salt += SALT_ALPHABET.sample.chr}
  self.password_salt = Digest::SHA1.hexdigest(password_salt)
  hash_password
end

#hash_passwordObject



17
18
19
20
# File 'lib/yodel/models/security/user.rb', line 17

def hash_password
  return unless password_changed? && password? && password_salt?
  self.password = Password.hashed_password(password_salt, password)
end

#passwords_match?(password) ⇒ Boolean

check if a plain text password matches the hashed, salted password

Returns:

  • (Boolean)


23
24
25
# File 'lib/yodel/models/security/user.rb', line 23

def passwords_match?(password)
  self.password_was == Password.hashed_password(password_salt, password) ? self : nil
end

#reset_passwordObject

create and set a new password for this user, returning the new plain text password



28
29
30
31
32
# File 'lib/yodel/models/security/user.rb', line 28

def reset_password
  self.password = ''
  PASS_LENGTH.times {self.password += SALT_ALPHABET.sample.chr}
  self.password.tap {self.save}
end