Sha256: 3497d4cae96080198aaa1a0453792add1ef106f58f582da311327e971ad94978
Contents?: true
Size: 1.89 KB
Versions: 2
Compression:
Stored size: 1.89 KB
Contents
module Ddr module Models module HasAdminMetadata extend ActiveSupport::Concern included do has_metadata "adminMetadata", type: Ddr::Datastreams::AdministrativeMetadataDatastream, versionable: true, control_group: "M" has_attributes :admin_set, :display_format, :local_id, :permanent_id, :permanent_url, :workflow_state, datastream: "adminMetadata", multiple: false delegate :publish, :publish!, :unpublish, :unpublish!, :published?, to: :workflow after_create :assign_permanent_id!, if: "Ddr::Models.auto_assign_permanent_ids" around_destroy :update_permanent_id_on_destroy, if: "permanent_id.present?" end def permanent_id_manager @permanent_id_manager ||= Ddr::Managers::PermanentIdManager.new(self) end def roles Ddr::Auth::Roles::PropertyRoleSet.new(adminMetadata.access_role) end def workflow @workflow ||= Ddr::Managers::WorkflowManager.new(self) end def assign_permanent_id! permanent_id_manager.assign_later end def grant_roles_to_creator(creator) roles.grant type: Ddr::Auth::Roles::EDITOR, agent: creator, scope: Ddr::Auth::Roles::RESOURCE_SCOPE end def copy_resource_roles_from(other) roles.grant *(other.roles.in_resource_scope) end def inherited_roles Ddr::Auth::InheritedRoles.call(self) end def effective_roles Ddr::Auth::EffectiveRoles.call(self) end private def update_permanent_id_on_destroy @permanent_id = permanent_id yield Resque.enqueue(Ddr::Jobs::PermanentId::MakeUnavailable, @permanent_id, "deleted") end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
ddr-models-2.0.0.pre.3 | lib/ddr/models/has_admin_metadata.rb |
ddr-models-2.0.0.pre.2 | lib/ddr/models/has_admin_metadata.rb |