Module: Dor::Governable
Instance Method Summary
collapse
Methods included from Rightsable
#build_rightsMetadata_datastream, #world_doc
Instance Method Details
#add_collection(collection_or_druid) ⇒ Object
37
38
39
40
41
42
43
44
45
46
47
|
# File 'lib/dor/models/governable.rb', line 37
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
116
117
118
|
# File 'lib/dor/models/governable.rb', line 116
def can_manage_content?(roles)
intersect roles, groups_which_manage_content
end
|
110
111
112
|
# File 'lib/dor/models/governable.rb', line 110
def can_manage_desc_metadata?(roles)
intersect roles, groups_which_manage_desc_metadata
end
|
#can_manage_embargo?(roles) ⇒ Boolean
122
123
124
|
# File 'lib/dor/models/governable.rb', line 122
def can_manage_embargo?(roles)
intersect roles, groups_which_manage_embargo
end
|
#can_manage_item?(roles) ⇒ Boolean
107
108
109
|
# File 'lib/dor/models/governable.rb', line 107
def can_manage_item?(roles)
intersect roles, groups_which_manage_item
end
|
#can_manage_rights?(roles) ⇒ Boolean
119
120
121
|
# File 'lib/dor/models/governable.rb', line 119
def can_manage_rights?(roles)
intersect roles, groups_which_manage_rights
end
|
113
114
115
|
# File 'lib/dor/models/governable.rb', line 113
def can_manage_system_metadata?(roles)
intersect roles, groups_which_manage_system_metadata
end
|
#can_view_content?(roles) ⇒ Boolean
125
126
127
|
# File 'lib/dor/models/governable.rb', line 125
def can_view_content?(roles)
intersect roles, groups_which_view_content
end
|
128
129
130
|
# File 'lib/dor/models/governable.rb', line 128
def can_view_metadata?(roles)
intersect roles, groups_which_view_metadata
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
19
20
21
22
23
24
25
26
27
|
# File 'lib/dor/models/governable.rb', line 19
def default_workflow_lane
return 'default' if admin_policy_object.nil?
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
89
90
91
|
# File 'lib/dor/models/governable.rb', line 89
def groups_which_manage_content
['dor-administrator', 'sdr-administrator', 'dor-apo-manager', 'dor-apo-depositor']
end
|
83
84
85
|
# File 'lib/dor/models/governable.rb', line 83
def groups_which_manage_desc_metadata
['dor-administrator', 'sdr-administrator', 'dor-apo-manager', 'dor-apo-depositor', 'dor-apo-metadata']
end
|
#groups_which_manage_embargo ⇒ Object
95
96
97
|
# File 'lib/dor/models/governable.rb', line 95
def groups_which_manage_embargo
['dor-administrator', 'sdr-administrator', 'dor-apo-manager', 'dor-apo-depositor']
end
|
#groups_which_manage_item ⇒ Object
80
81
82
|
# File 'lib/dor/models/governable.rb', line 80
def groups_which_manage_item
['dor-administrator', 'sdr-administrator', 'dor-apo-manager', 'dor-apo-depositor']
end
|
#groups_which_manage_rights ⇒ Object
92
93
94
|
# File 'lib/dor/models/governable.rb', line 92
def groups_which_manage_rights
['dor-administrator', 'sdr-administrator', 'dor-apo-manager', 'dor-apo-depositor']
end
|
86
87
88
|
# File 'lib/dor/models/governable.rb', line 86
def groups_which_manage_system_metadata
['dor-administrator', 'sdr-administrator', 'dor-apo-manager', 'dor-apo-depositor']
end
|
#groups_which_view_content ⇒ Object
98
99
100
|
# File 'lib/dor/models/governable.rb', line 98
def groups_which_view_content
['dor-administrator', 'sdr-administrator', 'dor-apo-manager', 'dor-apo-depositor', 'dor-viewer', 'sdr-viewer']
end
|
101
102
103
|
# File 'lib/dor/models/governable.rb', line 101
def groups_which_view_metadata
['dor-administrator', 'sdr-administrator', 'dor-apo-manager', 'dor-apo-depositor', 'dor-viewer', 'sdr-viewer']
end
|
#initiate_apo_workflow(name) ⇒ Object
12
13
14
|
# File 'lib/dor/models/governable.rb', line 12
def initiate_apo_workflow(name)
create_workflow(name, !self.new_record?)
end
|
#intersect(arr1, arr2) ⇒ Object
104
105
106
|
# File 'lib/dor/models/governable.rb', line 104
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
62
63
64
|
# File 'lib/dor/models/governable.rb', line 62
def reapplyAdminPolicyObjectDefaults
rightsMetadata.content = admin_policy_object.datastreams['defaultObjectRights'].content
end
|
#remove_collection(collection_or_druid) ⇒ Object
49
50
51
52
53
54
55
56
57
58
59
60
|
# File 'lib/dor/models/governable.rb', line 49
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
29
30
31
|
# File 'lib/dor/models/governable.rb', line 29
def reset_to_apo_default
rightsMetadata.content = admin_policy_object.rightsMetadata.ng_xml
end
|
#rights ⇒ Object
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
# File 'lib/dor/models/governable.rb', line 65
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
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
33
34
35
|
# File 'lib/dor/models/governable.rb', line 33
def set_read_rights(rights)
rightsMetadata.set_read_rights(rights)
end
|