Class: Caboose::User
- Inherits:
-
ActiveRecord::Base
- Object
- ActiveRecord::Base
- Caboose::User
- Defined in:
- app/models/caboose/user.rb
Constant Summary collapse
- ADMIN_USER_ID =
1
- LOGGED_OUT_USER_ID =
2
Class Method Summary collapse
- .logged_out_user(site_id) ⇒ Object
- .logged_out_user_id(site_id) ⇒ Object
- .user_for_reset_id(reset_id) ⇒ Object
- .validate_token(token) ⇒ Object
Instance Method Summary collapse
- #add_to_role(role_id) ⇒ Object
- #add_to_role_with_name(role_name) ⇒ Object
- #card_is_expired? ⇒ Boolean
- #is_allowed(resource, action) ⇒ Object
- #is_logged_out_user? ⇒ Boolean
- #is_member?(role_id) ⇒ Boolean
- #is_super_admin? ⇒ Boolean
- #toggle_roles(role_id, value) ⇒ Object
Class Method Details
.logged_out_user(site_id) ⇒ Object
27 28 29 30 |
# File 'app/models/caboose/user.rb', line 27 def self.logged_out_user(site_id) return self.where(:site_id => site_id, :username => 'elo').first #return self.where(:id => self::LOGGED_OUT_USER_ID).first end |
.logged_out_user_id(site_id) ⇒ Object
32 33 34 35 |
# File 'app/models/caboose/user.rb', line 32 def self.logged_out_user_id(site_id) return self.where(:site_id => site_id, :username => 'elo').limit(1).pluck(:id)[0] #return self::LOGGED_OUT_USER_ID end |
.user_for_reset_id(reset_id) ⇒ Object
94 95 96 97 98 99 100 101 |
# File 'app/models/caboose/user.rb', line 94 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 |
.validate_token(token) ⇒ Object
65 66 67 68 |
# File 'app/models/caboose/user.rb', line 65 def self.validate_token(token) user = self.where('token' => token).first return user end |
Instance Method Details
#add_to_role(role_id) ⇒ Object
76 77 78 79 80 81 82 83 84 85 |
# File 'app/models/caboose/user.rb', line 76 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 |
#add_to_role_with_name(role_name) ⇒ Object
70 71 72 73 74 |
# File 'app/models/caboose/user.rb', line 70 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 |
#card_is_expired? ⇒ Boolean
122 123 124 125 126 |
# File 'app/models/caboose/user.rb', line 122 def card_is_expired? return true if self.stripe_customer_id.nil? d = Date.new(self.card_exp_year, self.card_exp_month, 1) return d <= Date.today end |
#is_allowed(resource, action) ⇒ Object
45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 |
# File 'app/models/caboose/user.rb', line 45 def is_allowed(resource, action) elo = Caboose::Role.logged_out_role(self.site_id) elo_is_allowed = elo.is_allowed(resource, action) return true if elo_is_allowed return false if !elo_is_allowed && self.is_logged_out_user? eli = Caboose::Role.logged_in_role(self.site_id) return true if self.id != elo.id && eli.is_allowed(resource, action) for role in roles #Caboose.log("Checking permissions for #{role.name} role") if role.is_allowed(resource, action) #Caboose.log("Role #{role.name} is allowed to view page") return true else #Caboose.log("Role #{role.name} is not allowed to view page") end #return true if role.is_allowed(resource, action) end return false; end |
#is_logged_out_user? ⇒ Boolean
37 38 39 |
# File 'app/models/caboose/user.rb', line 37 def is_logged_out_user? return self.id == Caboose::User.logged_out_user_id(self.site_id) end |
#is_member?(role_id) ⇒ Boolean
87 88 89 90 91 92 |
# File 'app/models/caboose/user.rb', line 87 def is_member?(role_id) roles.each do |r| return true if (r.id == role_id) end return false end |
#is_super_admin? ⇒ Boolean
41 42 43 |
# File 'app/models/caboose/user.rb', line 41 def is_super_admin? return self.username == 'superadmin' end |
#toggle_roles(role_id, value) ⇒ Object
103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 |
# File 'app/models/caboose/user.rb', line 103 def toggle_roles(role_id, value) if value.to_i > 0 # Add to role if role_id == 'all' Caboose::RoleMembership.where(:user_id => self.id).destroy_all Caboose::Role.where(:site_id => self.site_id).reorder(:name).all.each{ |r| RoleMembership.create(:user_id => self.id, :role_id => r.id) } else if !Caboose::RoleMembership.where(:user_id => self.id, :role_id => role_id.to_i).exists? Caboose::RoleMembership.create( :user_id => self.id, :role_id => role_id.to_i) end end else # Remove from role if role_id == 'all' Caboose::RoleMembership.where(:user_id => self.id).destroy_all else Caboose::RoleMembership.where(:user_id => self.id, :role_id => role_id.to_i).destroy_all end end end |