Class: Caboose::Site
- Inherits:
-
ActiveRecord::Base
- Object
- ActiveRecord::Base
- Caboose::Site
- Defined in:
- app/models/caboose/site.rb
Class Method Summary collapse
Instance Method Summary collapse
- #custom_css ⇒ Object
- #custom_css=(str) ⇒ Object
- #custom_css_url ⇒ Object
- #custom_js ⇒ Object
- #custom_js=(str) ⇒ Object
- #custom_js_url ⇒ Object
- #default_layout ⇒ Object
- #init_users_and_roles ⇒ Object
- #primary_domain ⇒ Object
- #retargeting_config ⇒ Object
- #smtp_config ⇒ Object
- #social_config ⇒ Object
Class Method Details
.id_for_domain(domain) ⇒ Object
47 48 49 50 51 |
# File 'app/models/caboose/site.rb', line 47 def self.id_for_domain(domain) d = Caboose::Domain.where(:domain => domain).first return nil if d.nil? return d.site_id end |
.sanitize_name(name) ⇒ Object
53 54 55 |
# File 'app/models/caboose/site.rb', line 53 def self.sanitize_name(name) self.name = self.name.downcase.gsub(' ', '_') end |
Instance Method Details
#custom_css ⇒ Object
82 83 84 85 86 87 88 89 |
# File 'app/models/caboose/site.rb', line 82 def custom_css resp = HTTParty.get(self.custom_css_url) if resp.nil? || resp.code.to_i == 403 self.custom_css = "" return "" end return resp.body end |
#custom_css=(str) ⇒ Object
100 101 102 103 104 105 106 107 |
# File 'app/models/caboose/site.rb', line 100 def custom_css=(str) config = YAML.load(File.read(Rails.root.join('config', 'aws.yml')))[Rails.env] AWS.config(:access_key_id => config['access_key_id'], :secret_access_key => config['secret_access_key']) bucket = AWS::S3.new.buckets[config['bucket']] bucket.objects["assets/#{self.name}/css/custom.css"].write(str, :acl => 'public-read') self.date_css_updated = DateTime.now.utc self.save end |
#custom_css_url ⇒ Object
67 68 69 70 71 |
# File 'app/models/caboose/site.rb', line 67 def custom_css_url url = "http://#{Caboose::cdn_domain}/assets/#{self.name}/css/custom.css" url << "?#{self.date_css_updated.strftime('%Y%m%d%H%M%S')}" if self.date_css_updated return url end |
#custom_js ⇒ Object
73 74 75 76 77 78 79 80 |
# File 'app/models/caboose/site.rb', line 73 def custom_js resp = HTTParty.get(self.custom_js_url) if resp.nil? || resp.code.to_i == 403 self.custom_js = "" return "" end return resp.body end |
#custom_js=(str) ⇒ Object
91 92 93 94 95 96 97 98 |
# File 'app/models/caboose/site.rb', line 91 def custom_js=(str) config = YAML.load(File.read(Rails.root.join('config', 'aws.yml')))[Rails.env] AWS.config(:access_key_id => config['access_key_id'], :secret_access_key => config['secret_access_key']) bucket = AWS::S3.new.buckets[config['bucket']] bucket.objects["assets/#{self.name}/js/custom.js"].write(str, :acl => 'public-read') self.date_js_updated = DateTime.now.utc self.save end |
#custom_js_url ⇒ Object
61 62 63 64 65 |
# File 'app/models/caboose/site.rb', line 61 def custom_js_url url = "http://#{Caboose::cdn_domain}/assets/#{self.name}/js/custom.js" url << "?#{self.date_js_updated.strftime('%Y%m%d%H%M%S')}" if self.date_js_updated return url end |
#default_layout ⇒ Object
24 25 26 27 |
# File 'app/models/caboose/site.rb', line 24 def default_layout return Caboose::BlockType.where(:id => self.default_layout_id).first if self.default_layout_id return Caboose::BlockType.where(:name => 'layout_basic').first end |
#init_users_and_roles ⇒ Object
109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 |
# File 'app/models/caboose/site.rb', line 109 def init_users_and_roles admin_user = Caboose::User.where(:username => 'admin', :site_id => self.id).first admin_user = Caboose::User.create(:username => 'admin', :email => '[email protected]', :site_id => self.id, :password => Digest::SHA1.hexdigest(Caboose::salt + 'caboose')) if admin_user.nil? admin_role = Caboose::Role.where(:site_id => self.id, :name => 'Admin').first admin_role = Caboose::Role.create(:site_id => self.id, :parent_id => -1, :name => 'Admin') if admin_role.nil? elo_role = Caboose::Role.where(:site_id => self.id, :name => 'Everyone Logged Out').first elo_role = Caboose::Role.create(:site_id => self.id, :parent_id => -1, :name => 'Everyone Logged Out') if elo_role.nil? eli_role = Caboose::Role.where(:site_id => self.id, :name => 'Everyone Logged In').first eli_role = Caboose::Role.create(:site_id => self.id, :parent_id => elo_role.id, :name => 'Everyone Logged In') if eli_role.nil? # Make sure the admin role has the admin "all" permission admin_perm = Caboose::Permission.where(:resource => 'all', :action => 'all').first rp = Caboose::RolePermission.where(:role_id => admin_role.id, :permission_id => admin_perm.id).first rp = Caboose::RolePermission.create(:role_id => admin_role.id, :permission_id => admin_perm.id) if rp.nil? # Make sure the admin user is a member of the admin role rm = Caboose::RoleMembership.where(:role_id => admin_role.id, :user_id => admin_user.id).first rm = Caboose::RoleMembership.create(:role_id => admin_role.id, :user_id => admin_user.id) if rm.nil? end |
#primary_domain ⇒ Object
57 58 59 |
# File 'app/models/caboose/site.rb', line 57 def primary_domain Caboose::Domain.where(:site_id => self.id, :primary => true).first end |
#retargeting_config ⇒ Object
41 42 43 44 45 |
# File 'app/models/caboose/site.rb', line 41 def retargeting_config c = Caboose::RetargetingConfig.where(:site_id => self.id).first c = Caboose::RetargetingConfig.create(:site_id => self.id) if c.nil? return c end |
#smtp_config ⇒ Object
29 30 31 32 33 |
# File 'app/models/caboose/site.rb', line 29 def smtp_config c = Caboose::SmtpConfig.where(:site_id => self.id).first c = Caboose::SmtpConfig.create(:site_id => self.id) if c.nil? return c end |
#social_config ⇒ Object
35 36 37 38 39 |
# File 'app/models/caboose/site.rb', line 35 def s = Caboose::SocialConfig.where(:site_id => self.id).first s = Caboose::SocialConfig.create(:site_id => self.id) if s.nil? return s end |