application.rb
1.74 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
# his is the application's main controller. Features defined here are
# available in all controllers.
class ApplicationController < ActionController::Base
helper :document
helper :language
design :holder => 'environment'
# Be sure to include AuthenticationSystem in Application Controller instead
include AuthenticatedSystem
extend PermissionCheck
init_gettext 'noosfero'
before_filter :detect_stuff_by_domain, :load_profile_from_params
attr_reader :environment
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
# before_filter :load_profile_from_params
def load_profile_from_params
if params[:profile]
@profile ||= Profile.find_by_identifier(params[:profile])
end
end
def profile
@profile
end
def self.needs_profile
before_filter :load_profile
design :holder => 'profile'
end
def load_profile
@profile = Profile.find_by_identifier(params[:profile])
if @profile.nil?
flash[:notice] = _('There is no page %s') % params[:profile]
redirect_to :controller => 'search', :action => 'index', :query => params[:profile]
end
end
def self.acts_as_environment_admin_controller
before_filter :load_admin_controller
end
def load_admin_controller
# TODO: check access control
end
# 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
end