hydra-access-controls 5.1.0 → 5.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,7 +1,5 @@
1
1
  # Allows you to use CanCan to control access to Models
2
- require 'cancan'
3
2
  class Ability
4
- include CanCan::Ability
5
3
  include Hydra::Ability
6
4
  include Hydra::PolicyAwareAbility
7
5
  end
@@ -1,11 +1,18 @@
1
1
  # Code for [CANCAN] access to Hydra models
2
+ require 'cancan'
2
3
  module Hydra::Ability
3
4
  extend ActiveSupport::Concern
4
5
 
6
+ # once you include Hydra::Ability you can add custom permission methods by appending to ability_logic like so:
7
+ #
8
+ # self.ability_logic +=[:setup_my_permissions]
5
9
 
6
10
  included do
11
+ include CanCan::Ability
7
12
  include Hydra::AccessControlsEnforcement
8
13
  include Blacklight::SolrHelper
14
+ class_attribute :ability_logic
15
+ self.ability_logic = [:create_permissions, :edit_permissions, :read_permissions, :custom_permissions]
9
16
  end
10
17
 
11
18
  def self.user_class
@@ -38,10 +45,9 @@ module Hydra::Ability
38
45
  def hydra_default_permissions(user=nil, session=nil)
39
46
  ActiveSupport::Deprecation.warn("No need to pass user or session to hydra_default_permissions, use the instance_variables", caller()) if user || session
40
47
  logger.debug("Usergroups are " + user_groups.inspect)
41
- create_permissions()
42
- edit_permissions()
43
- read_permissions()
44
- custom_permissions()
48
+ self.ability_logic.each do |method|
49
+ send(method)
50
+ end
45
51
  end
46
52
 
47
53
  def create_permissions(user=nil, session=nil)
@@ -245,6 +245,30 @@ describe Ability do
245
245
 
246
246
  end
247
247
 
248
+ describe "custom method" do
249
+ before do
250
+ class MyAbility
251
+ include Hydra::Ability
252
+ self.ability_logic +=[:setup_my_permissions]
253
+
254
+ def setup_my_permissions
255
+ can :accept, ActiveFedora::Base
256
+ end
257
+ end
258
+ end
259
+
260
+ after do
261
+ Object.send(:remove_const, :MyAbility)
262
+ end
263
+
264
+ subject { MyAbility.new(FactoryGirl.create(:staff)) }
265
+
266
+ it "should be set the custom permission" do
267
+ subject.can?(:accept, ActiveFedora::Base).should be_true
268
+ end
269
+
270
+ end
271
+
248
272
  #
249
273
  # Policy-based Access Controls
250
274
  #
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: hydra-access-controls
3
3
  version: !ruby/object:Gem::Version
4
- version: 5.1.0
4
+ version: 5.2.0
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -11,7 +11,7 @@ authors:
11
11
  autorequire:
12
12
  bindir: bin
13
13
  cert_chain: []
14
- date: 2012-12-20 00:00:00.000000000 Z
14
+ date: 2013-01-09 00:00:00.000000000 Z
15
15
  dependencies:
16
16
  - !ruby/object:Gem::Dependency
17
17
  name: activesupport