Module: ActiveScaffold
- Defined in:
- lib/active_scaffold/model_permissions.rb,
lib/active_scaffold.rb,
lib/active_scaffold/engine.rb,
lib/active_scaffold/finder.rb,
lib/active_scaffold/render.rb,
lib/active_scaffold/bridges.rb,
lib/active_scaffold/version.rb,
lib/active_scaffold/constraints.rb,
lib/active_scaffold/configurable.rb,
lib/active_scaffold/marked_model.rb,
lib/active_scaffold/attribute_params.rb,
lib/active_scaffold/helpers/id_helpers.rb,
lib/active_scaffold/helpers/view_helpers.rb,
lib/active_scaffold/bridges/dragonfly/form_ui.rb,
lib/active_scaffold/bridges/dragonfly/list_ui.rb,
lib/active_scaffold/bridges/shared/date_bridge.rb,
lib/active_scaffold/helpers/controller_helpers.rb,
lib/active_scaffold/helpers/pagination_helpers.rb,
lib/active_scaffold/bridges/carrierwave/form_ui.rb,
lib/active_scaffold/bridges/carrierwave/list_ui.rb,
lib/active_scaffold/helpers/association_helpers.rb,
lib/active_scaffold/helpers/form_column_helpers.rb,
lib/active_scaffold/helpers/list_column_helpers.rb,
lib/active_scaffold/helpers/show_column_helpers.rb,
lib/active_scaffold/helpers/search_column_helpers.rb,
lib/active_scaffold/helpers/human_condition_helpers.rb,
lib/active_scaffold/bridges/dragonfly/dragonfly_bridge.rb,
lib/active_scaffold/extensions/name_option_for_datetime.rb,
lib/active_scaffold/bridges/carrierwave/carrierwave_bridge.rb,
lib/active_scaffold/bridges/dragonfly/dragonfly_bridge_helpers.rb,
lib/active_scaffold/bridges/carrierwave/carrierwave_bridge_helpers.rb
Overview
This module attempts to create permissions conventions for your models. It supports english-based methods that let you restrict access per-model, per-record, per-column, per-action, and per-user. All at once.
You may define instance methods in the following formats:
def #{column}_authorized_for_#{action}?
def #{column}_authorized?
def authorized_for_#{action}?
Defined Under Namespace
Modules: Actions, AttributeParams, Bridges, ClassMethods, Config, Configurable, Constraints, DataStructures, DateSelectExtension, Finder, Helpers, MarkedModel, ModelPermissions, Render, RespondsToParent, Version
Classes: ActionNotAllowed, ControllerNotFound, DependencyFailure, Engine, MalformedConstraint, Paginator, RecordNotAllowed, ReverseAssociationRequired, Ring
Class Method Summary
collapse
Instance Method Summary
collapse
Class Method Details
.autoload_subdir(dir, mod = self, root = File.dirname(__FILE__)) ⇒ Object
24
25
26
27
28
29
30
31
|
# File 'lib/active_scaffold.rb', line 24
def self.autoload_subdir(dir, mod=self, root = File.dirname(__FILE__))
Dir["#{root}/active_scaffold/#{dir}/*.rb"].each { |file|
basename = File.basename(file, ".rb")
mod.module_eval {
autoload basename.camelcase.to_sym, "active_scaffold/#{dir}/#{basename}"
}
}
end
|
.exclude_bridges ⇒ Object
135
136
137
|
# File 'lib/active_scaffold.rb', line 135
def self.exclude_bridges
@@exclude_bridges ||= []
end
|
.exclude_bridges=(bridges) ⇒ Object
exclude bridges you do not need name of bridge subdir should be used to exclude it eg
ActiveScaffold.exclude_bridges = [:cancan, :ancestry]
if you are using Activescaffold as a gem add to initializer
if you are using Activescaffold as a plugin add to active_scaffold_env.rb
131
132
133
|
# File 'lib/active_scaffold.rb', line 131
def self.exclude_bridges=(bridges)
@@exclude_bridges = bridges
end
|
.included(base) ⇒ Object
56
57
58
59
60
61
62
63
64
65
66
|
# File 'lib/active_scaffold.rb', line 56
def self.included(base)
base.extend(ClassMethods)
base.module_eval do
before_filter :handle_user_settings
before_filter :check_input_device
end
base.helper_method :touch_device?
base.helper_method :hover_via_click?
end
|
.js_config ⇒ Object
121
122
123
|
# File 'lib/active_scaffold.rb', line 121
def self.js_config
@@js_config ||= {:scroll_on_close => true}
end
|
.js_config=(config) ⇒ Object
117
118
119
|
# File 'lib/active_scaffold.rb', line 117
def self.js_config=(config)
@@js_config = config
end
|
139
140
141
|
# File 'lib/active_scaffold.rb', line 139
def self.root
File.dirname(__FILE__) + "/.."
end
|
.set_defaults(&block) ⇒ Object
Instance Method Details
#active_scaffold_config ⇒ Object
72
73
74
|
# File 'lib/active_scaffold.rb', line 72
def active_scaffold_config
self.class.active_scaffold_config
end
|
#active_scaffold_config_for(klass) ⇒ Object
76
77
78
|
# File 'lib/active_scaffold.rb', line 76
def active_scaffold_config_for(klass)
self.class.active_scaffold_config_for(klass)
end
|
#active_scaffold_session_storage(id = nil) ⇒ Object
80
81
82
83
84
85
|
# File 'lib/active_scaffold.rb', line 80
def active_scaffold_session_storage(id = nil)
id ||= params[:eid] || "#{params[:controller]}#{"_#{nested.parent_id}" if nested?}"
session_index = "as:#{id}"
session[session_index] ||= {}
session[session_index]
end
|
99
100
101
102
103
104
105
106
107
|
# File 'lib/active_scaffold.rb', line 99
def check_input_device
if request.env["HTTP_USER_AGENT"] && request.env["HTTP_USER_AGENT"][/(iPhone|iPod|iPad)/i]
session[:input_device_type] = 'TOUCH'
session[:hover_supported] = false
else
session[:input_device_type] = 'MOUSE'
session[:hover_supported] = true
end if session[:input_device_type].nil?
end
|
#handle_user_settings ⇒ Object
at some point we need to pass the session and params into config. we’ll just take care of that before any particular action occurs by passing those hashes off to the UserSettings class of each action.
88
89
90
91
92
93
94
95
96
97
|
# File 'lib/active_scaffold.rb', line 88
def handle_user_settings
if self.class.uses_active_scaffold?
active_scaffold_config.actions.each do |action_name|
conf_instance = active_scaffold_config.send(action_name) rescue next
next if conf_instance.class::UserSettings == ActiveScaffold::Config::Base::UserSettings active_scaffold_session_storage[action_name] ||= {}
conf_instance.user = conf_instance.class::UserSettings.new(conf_instance, active_scaffold_session_storage[action_name], params)
end
end
end
|
#hover_via_click? ⇒ Boolean
113
114
115
|
# File 'lib/active_scaffold.rb', line 113
def hover_via_click?
session[:hover_supported] == false
end
|
#touch_device? ⇒ Boolean
109
110
111
|
# File 'lib/active_scaffold.rb', line 109
def touch_device?
session[:input_device_type] == 'TOUCH'
end
|