Module: Ddr::Models::HasAdminMetadata
- Extended by:
- ActiveSupport::Concern, Deprecation
- Included in:
- Base
- Defined in:
- lib/ddr/models/has_admin_metadata.rb
Instance Method Summary collapse
- #copy_resource_roles_from(other) ⇒ Object
- #effective_permissions(agents) ⇒ Object
- #finding_aid ⇒ Object
- #grant_roles_to_creator(creator) ⇒ Object
- #inherited_roles ⇒ Object
- #lock ⇒ Object
- #lock! ⇒ Object
- #locked? ⇒ Boolean
- #research_help ⇒ Object
- #roles ⇒ Object
- #unlock ⇒ Object
- #unlock! ⇒ Object
- #workflow ⇒ Object
Instance Method Details
#copy_resource_roles_from(other) ⇒ Object
61 62 63 |
# File 'lib/ddr/models/has_admin_metadata.rb', line 61 def copy_resource_roles_from(other) roles.grant *(other.roles.in_resource_scope) end |
#effective_permissions(agents) ⇒ Object
65 66 67 |
# File 'lib/ddr/models/has_admin_metadata.rb', line 65 def (agents) Ddr::Auth::EffectivePermissions.call(self, agents) end |
#finding_aid ⇒ Object
73 74 75 76 77 |
# File 'lib/ddr/models/has_admin_metadata.rb', line 73 def finding_aid if ead_id FindingAid.new(ead_id) end end |
#grant_roles_to_creator(creator) ⇒ Object
55 56 57 58 59 |
# File 'lib/ddr/models/has_admin_metadata.rb', line 55 def grant_roles_to_creator(creator) roles.grant type: Ddr::Auth::Roles::EDITOR, agent: creator, scope: Ddr::Auth::Roles::RESOURCE_SCOPE end |
#inherited_roles ⇒ Object
47 48 49 |
# File 'lib/ddr/models/has_admin_metadata.rb', line 47 def inherited_roles Ddr::Auth::InheritedRoles.call(self) end |
#lock ⇒ Object
83 84 85 |
# File 'lib/ddr/models/has_admin_metadata.rb', line 83 def lock self.is_locked = true end |
#lock! ⇒ Object
91 92 93 94 |
# File 'lib/ddr/models/has_admin_metadata.rb', line 91 def lock! lock save end |
#locked? ⇒ Boolean
79 80 81 |
# File 'lib/ddr/models/has_admin_metadata.rb', line 79 def locked? !!is_locked || Ddr::Models.repository_locked end |
#research_help ⇒ Object
69 70 71 |
# File 'lib/ddr/models/has_admin_metadata.rb', line 69 def research_help Ddr::Models::Contact.call(research_help_contact) if research_help_contact end |
#roles ⇒ Object
43 44 45 |
# File 'lib/ddr/models/has_admin_metadata.rb', line 43 def roles Ddr::Auth::Roles::PropertyRoleSet.new(adminMetadata.access_role) end |
#unlock ⇒ Object
87 88 89 |
# File 'lib/ddr/models/has_admin_metadata.rb', line 87 def unlock self.is_locked = false end |
#unlock! ⇒ Object
96 97 98 99 |
# File 'lib/ddr/models/has_admin_metadata.rb', line 96 def unlock! unlock save end |
#workflow ⇒ Object
51 52 53 |
# File 'lib/ddr/models/has_admin_metadata.rb', line 51 def workflow @workflow ||= Ddr::Managers::WorkflowManager.new(self) end |