Module: Dor::Governable
- Extended by:
- ActiveSupport::Concern
- Included in:
- Abstract
- Defined in:
- lib/dor/models/concerns/governable.rb
Instance Method Summary collapse
- #add_collection(collection_or_druid) ⇒ Object
- #can_manage_content?(roles) ⇒ Boolean
- #can_manage_desc_metadata?(roles) ⇒ Boolean
- #can_manage_embargo?(roles) ⇒ Boolean
- #can_manage_item?(roles) ⇒ Boolean
- #can_manage_rights?(roles) ⇒ Boolean
- #can_manage_system_metadata?(roles) ⇒ Boolean
- #can_view_content?(roles) ⇒ Boolean
- #can_view_metadata?(roles) ⇒ Boolean
-
#default_workflow_lane ⇒ String
Returns the default lane_id from the item’s APO.
- #groups_which_manage_content ⇒ Object
- #groups_which_manage_desc_metadata ⇒ Object
- #groups_which_manage_embargo ⇒ Object
- #groups_which_manage_item ⇒ Object
- #groups_which_manage_rights ⇒ Object
- #groups_which_manage_system_metadata ⇒ Object
- #groups_which_view_content ⇒ Object
- #groups_which_view_metadata ⇒ Object
- #initiate_apo_workflow(name) ⇒ Object
- #intersect(arr1, arr2) ⇒ Object
-
#reapplyAdminPolicyObjectDefaults ⇒ Object
set the rights metadata datastream to the content of the APO’s default object rights.
- #remove_collection(collection_or_druid) ⇒ Object
- #reset_to_apo_default ⇒ Object
- #rights ⇒ Object
- #set_read_rights(rights) ⇒ Object
Instance Method Details
#add_collection(collection_or_druid) ⇒ Object
36 37 38 39 40 41 42 43 44 45 46 |
# File 'lib/dor/models/concerns/governable.rb', line 36 def add_collection(collection_or_druid) collection = case collection_or_druid when String Dor::Collection.find(collection_or_druid) when Dor::Collection collection_or_druid end collections << collection sets << collection end |
#can_manage_content?(roles) ⇒ Boolean
115 116 117 |
# File 'lib/dor/models/concerns/governable.rb', line 115 def can_manage_content?(roles) intersect roles, groups_which_manage_content end |
#can_manage_desc_metadata?(roles) ⇒ Boolean
109 110 111 |
# File 'lib/dor/models/concerns/governable.rb', line 109 def (roles) intersect roles, end |
#can_manage_embargo?(roles) ⇒ Boolean
121 122 123 |
# File 'lib/dor/models/concerns/governable.rb', line 121 def (roles) intersect roles, end |
#can_manage_item?(roles) ⇒ Boolean
106 107 108 |
# File 'lib/dor/models/concerns/governable.rb', line 106 def can_manage_item?(roles) intersect roles, groups_which_manage_item end |
#can_manage_rights?(roles) ⇒ Boolean
118 119 120 |
# File 'lib/dor/models/concerns/governable.rb', line 118 def can_manage_rights?(roles) intersect roles, groups_which_manage_rights end |
#can_manage_system_metadata?(roles) ⇒ Boolean
112 113 114 |
# File 'lib/dor/models/concerns/governable.rb', line 112 def (roles) intersect roles, end |
#can_view_content?(roles) ⇒ Boolean
124 125 126 |
# File 'lib/dor/models/concerns/governable.rb', line 124 def can_view_content?(roles) intersect roles, groups_which_view_content end |
#can_view_metadata?(roles) ⇒ Boolean
127 128 129 |
# File 'lib/dor/models/concerns/governable.rb', line 127 def (roles) intersect roles, end |
#default_workflow_lane ⇒ String
Returns the default lane_id from the item’s APO. Will return ‘default’ if the item does not have
and APO, or if the APO does not have a default_lane
18 19 20 21 22 23 24 25 26 |
# File 'lib/dor/models/concerns/governable.rb', line 18 def default_workflow_lane return 'default' if admin_policy_object.nil? # TODO: log warning? admin_md = admin_policy_object.datastreams['administrativeMetadata'] return 'default' unless admin_md.respond_to? :default_workflow_lane lane = admin_md.default_workflow_lane return 'default' if lane.nil? || lane.strip == '' lane end |
#groups_which_manage_content ⇒ Object
88 89 90 |
# File 'lib/dor/models/concerns/governable.rb', line 88 def groups_which_manage_content ['dor-administrator', 'sdr-administrator', 'dor-apo-manager', 'dor-apo-depositor'] end |
#groups_which_manage_desc_metadata ⇒ Object
82 83 84 |
# File 'lib/dor/models/concerns/governable.rb', line 82 def ['dor-administrator', 'sdr-administrator', 'dor-apo-manager', 'dor-apo-depositor', 'dor-apo-metadata'] end |
#groups_which_manage_embargo ⇒ Object
94 95 96 |
# File 'lib/dor/models/concerns/governable.rb', line 94 def ['dor-administrator', 'sdr-administrator', 'dor-apo-manager', 'dor-apo-depositor'] end |
#groups_which_manage_item ⇒ Object
79 80 81 |
# File 'lib/dor/models/concerns/governable.rb', line 79 def groups_which_manage_item ['dor-administrator', 'sdr-administrator', 'dor-apo-manager', 'dor-apo-depositor'] end |
#groups_which_manage_rights ⇒ Object
91 92 93 |
# File 'lib/dor/models/concerns/governable.rb', line 91 def groups_which_manage_rights ['dor-administrator', 'sdr-administrator', 'dor-apo-manager', 'dor-apo-depositor'] end |
#groups_which_manage_system_metadata ⇒ Object
85 86 87 |
# File 'lib/dor/models/concerns/governable.rb', line 85 def ['dor-administrator', 'sdr-administrator', 'dor-apo-manager', 'dor-apo-depositor'] end |
#groups_which_view_content ⇒ Object
97 98 99 |
# File 'lib/dor/models/concerns/governable.rb', line 97 def groups_which_view_content ['dor-administrator', 'sdr-administrator', 'dor-apo-manager', 'dor-apo-depositor', 'dor-viewer', 'sdr-viewer'] end |
#groups_which_view_metadata ⇒ Object
100 101 102 |
# File 'lib/dor/models/concerns/governable.rb', line 100 def ['dor-administrator', 'sdr-administrator', 'dor-apo-manager', 'dor-apo-depositor', 'dor-viewer', 'sdr-viewer'] end |
#initiate_apo_workflow(name) ⇒ Object
11 12 13 |
# File 'lib/dor/models/concerns/governable.rb', line 11 def initiate_apo_workflow(name) create_workflow(name, !self.new_record?) end |
#intersect(arr1, arr2) ⇒ Object
103 104 105 |
# File 'lib/dor/models/concerns/governable.rb', line 103 def intersect(arr1, arr2) (arr1 & arr2).length > 0 end |
#reapplyAdminPolicyObjectDefaults ⇒ Object
set the rights metadata datastream to the content of the APO’s default object rights
61 62 63 |
# File 'lib/dor/models/concerns/governable.rb', line 61 def reapplyAdminPolicyObjectDefaults rightsMetadata.content = admin_policy_object.datastreams['defaultObjectRights'].content end |
#remove_collection(collection_or_druid) ⇒ Object
48 49 50 51 52 53 54 55 56 57 58 59 |
# File 'lib/dor/models/concerns/governable.rb', line 48 def remove_collection(collection_or_druid) collection = case collection_or_druid when String Dor::Collection.find(collection_or_druid) when Dor::Collection collection_or_druid end collections.delete(collection) sets.delete(collection) end |
#reset_to_apo_default ⇒ Object
28 29 30 |
# File 'lib/dor/models/concerns/governable.rb', line 28 def reset_to_apo_default rightsMetadata.content = admin_policy_object.rightsMetadata.ng_xml end |
#rights ⇒ Object
64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 |
# File 'lib/dor/models/concerns/governable.rb', line 64 def rights return nil unless self.respond_to? :rightsMetadata return nil if rightsMetadata.nil? xml = rightsMetadata.ng_xml return nil if xml.search('//rightsMetadata').length != 1 # ORLY? if xml.search('//rightsMetadata/access[@type=\'read\']/machine/group').length == 1 'Stanford' elsif xml.search('//rightsMetadata/access[@type=\'read\']/machine/world').length == 1 'World' elsif xml.search('//rightsMetadata/access[@type=\'discover\']/machine/none').length == 1 'Dark' else 'None' end end |
#set_read_rights(rights) ⇒ Object
32 33 34 |
# File 'lib/dor/models/concerns/governable.rb', line 32 def set_read_rights(rights) rightsMetadata.set_read_rights(rights) end |