Sha256: 5cb8930a3712e1754f44b1324e335f378ed3d197a06b25238f54b75db5c88d56
Contents?: true
Size: 1.77 KB
Versions: 20
Compression:
Stored size: 1.77 KB
Contents
class Caboose::User < ActiveRecord::Base self.table_name = "users" #has_and_belongs_to_many :roles has_many :role_memberships has_many :roles, :through => :role_memberships attr_accessible :email, :first_name, :last_name, :username, :token, :password, :phone before_save do self.email = self.email.downcase if self.email end def self.logged_out_user return self.where('username' => 'elo').first end def self.logged_out_user_id return self.where('username' => 'elo').limit(1).pluck(:id)[0] end def is_allowed(resource, action) elo = Caboose::Role.logged_out_role return true if elo.is_allowed(resource, action) eli = Caboose::Role.logged_in_role return true if self.id != elo.id && eli.is_allowed(resource, action) for role in roles return true if role.is_allowed(resource, action) end return false; end def self.validate_token(token) user = self.where('token' => token).first return user end def add_to_role_with_name(role_name) r = Caboose::Role.where(:name => role_name).first return false if r.nil? return add_to_role(r.id) end def add_to_role(role_id) r = Caboose::Role.find(role_id) return false if r.nil? if (!is_member?(r.id)) roles.push r save end return true end def is_member?(role_id) roles.each do |r| return true if (r.id == role_id) end return false end def self.user_for_reset_id(reset_id) return nil if reset_id.nil? d = DateTime.now - 3.days if self.where("password_reset_id = ? and password_reset_sent > ?", reset_id, d).exists? return self.where("password_reset_id = ? and password_reset_sent > ?", reset_id, d).first end return nil end end
Version data entries
20 entries across 20 versions & 1 rubygems