application.rb
4.46 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
# his is the application's main controller. Features defined here are
# available in all controllers.
class ApplicationController < ActionController::Base
  include ApplicationHelper
  layout :get_layout
  def get_layout
    theme_option(:layout) || 'application'
  end
  filter_parameter_logging :password
  def log_processing
    super
    return unless ENV['RAILS_ENV'] == 'production'
    if logger && logger.info?
      logger.info("  HTTP Referer: #{request.referer}")
      logger.info("  User Agent: #{request.user_agent}")
      logger.info("  Accept-Language: #{request.headers['HTTP_ACCEPT_LANGUAGE']}")
    end
  end
  helper :document
  helper :language
  def boxes_editor?
    false
  end
  protected :boxes_editor?
  def self.no_design_blocks
    @no_design_blocks = true
  end
  def self.uses_design_blocks?
    !@no_design_blocks
  end
  def uses_design_blocks?
    !@no_design_blocks && self.class.uses_design_blocks?
  end
  # Be sure to include AuthenticationSystem in Application Controller instead
  include AuthenticatedSystem
  include PermissionCheck
  def self.require_ssl(*options)
    before_filter :check_ssl, *options
  end
  def check_ssl
    return true if (request.ssl? || ENV['RAILS_ENV'] == 'development')
    redirect_to_ssl
  end
  def redirect_to_ssl
    return false if environment.disable_ssl
    redirect_to(params.merge(:protocol => 'https://'))
    true
  end
  def self.refuse_ssl(*options)
    before_filter :avoid_ssl, *options
  end
  def avoid_ssl
    return true if (!request.ssl? || ENV['RAILS_ENV'] == 'development')
    redirect_to(params.merge(:protocol => 'http://'))
    false
  end
  before_init_gettext :maybe_save_locale
  after_init_gettext :check_locale
  if Noosfero.available_locales.size == 1
    GetText.locale = Noosfero.available_locales.first
  end
  init_gettext 'noosfero'
  include NeedsProfile
  before_filter :detect_stuff_by_domain
  attr_reader :environment
  before_filter :load_terminology
  # declares that the given <tt>actions</tt> cannot be accessed by other HTTP
  # method besides POST.
  def self.post_only(actions, redirect = { :action => 'index'})
    verify :method => :post, :only => actions, :redirect_to => redirect
  end
  # Fix some problems with Single Table Inheritance
  require_dependency 'textile_article'
  require_dependency 'tiny_mce_article'
  require_dependency 'text_article'
  require_dependency 'article'
  protected
  # TODO: move this logic somewhere else (Domain class?)
  def detect_stuff_by_domain
    @domain = Domain.find_by_name(request.host)
    if @domain.nil?
      @environment = Environment.default
    else
      @environment = @domain.environment
      @profile = @domain.profile
    end
  end
  def load_terminology
    # cache terminology for performance
    @@terminology_cache ||= {}
    @@terminology_cache[environment.id] ||= environment.terminology
    Noosfero.terminology = @@terminology_cache[environment.id]
  end
  def render_not_found(path = nil)
    @no_design_blocks = true
    @path ||= request.path
    render :template => 'shared/not_found.rhtml', :status => 404
  end
  def render_access_denied(message = nil)
    @no_design_blocks = true
    @message = message
    render :template => 'shared/access_denied.rhtml', :status => 403
  end
  def user
    current_user.person if logged_in?
  end
  def maybe_save_locale
    if Noosfero.available_locales.size > 1
      # save locale if forced
      if params[:lang]
        cookies[:lang] = params[:lang]
      end
      # force GetText to load a matching locale
      GetText.locale = nil
    end
  end
  def check_locale
    available_locales = Noosfero.available_locales
    return if available_locales.size == 1
    # do not accept unsupported locales
    if !available_locales.include?(locale.to_s)
      old_locale = locale.to_s
      # find a similar locale
      similar = available_locales.find { |loc| locale.to_s.split('_').first == loc.split('_').first }
      if similar
        set_locale similar
        cookies[:lang] = similar
      else
        # no similar locale, fallback to default
        set_locale(Noosfero.default_locale)
        cookies[:lang] = Noosfero.default_locale
      end
      RAILS_DEFAULT_LOGGER.info('Locale reverted from %s to %s' % [old_locale, locale])
    end
  end
  def load_category
    unless params[:category_path].blank?
      path = params[:category_path].join('/')
      @category = environment.categories.find_by_path(path)
      if @category.nil?
        render_not_found(path)
      end
    end
  end
end