forked from refinery/refinerycms
/
base_controller.rb
92 lines (71 loc) · 2.9 KB
/
base_controller.rb
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
require 'action_controller'
require 'application_helper'
module Refinery
module Admin
module BaseController
extend ActiveSupport::Concern
included do
layout :layout?
before_filter :authenticate_refinery_user!, :restrict_plugins, :restrict_controller
after_filter :store_location?, :except => [:new, :create, :edit, :update, :destroy, :update_positions] # for redirect_back_or_default
helper_method :searching?, :group_by_date
end
module InstanceMethods
def admin?
true # we're in the admin base controller, so always true.
end
def searching?
params[:search].present?
end
def error_404(exception=nil)
# fallback to the default 404.html page.
render :file => Rails.root.join("public", "404.html").cleanpath.to_s,
:layout => false,
:status => 404
end
protected
def group_by_date(records)
new_records = []
records.each do |record|
key = record.created_at.strftime("%Y-%m-%d")
record_group = new_records.collect{|records| records.last if records.first == key }.flatten.compact << record
(new_records.delete_if {|i| i.first == key}) << [key, record_group]
end
new_records
end
def restrict_plugins
current_length = (plugins = current_refinery_user.authorized_plugins).length
# Superusers get granted access if they don't already have access.
if current_refinery_user.has_role?(:superuser)
if (plugins = plugins | ::Refinery::Plugins.registered.names).length > current_length
current_refinery_user.plugins = plugins
end
end
::Refinery::Plugins.set_active(plugins)
end
def restrict_controller
# if ::Refinery::Plugins.active.reject { |plugin| params[:controller] !~ Regexp.new(plugin.menu_match)}.empty?
# warn "'#{current_refinery_user.username}' tried to access '#{params[:controller]}' but was rejected."
# error_404
# end
end
# Override method from application_controller. Not needed in this controller.
def find_pages_for_menu; end
private
def layout?
"refinery/admin#{"_dialog" if from_dialog?}"
end
# Check whether it makes sense to return the user to the last page they
# were at instead of the default e.g. refinery_admin_pages_path
# right now we just want to snap back to index actions and definitely not to dialogues.
def store_location?
store_location unless action_name !~ /index/ or request.xhr? or from_dialog?
end
# Override authorized? so that only users with the Refinery role can admin the website.
def authorized?
refinery_user?
end
end
end
end
end