ddr-models 2.11.0 → 3.0.0.alpha.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +0 -1
- data/.travis.yml +7 -6
- data/Gemfile +2 -3
- data/Rakefile +5 -5
- data/app/controllers/users/sessions_controller.rb +5 -0
- data/app/helpers/models_helper.rb +7 -0
- data/app/models/attachment.rb +3 -5
- data/app/models/collection.rb +12 -79
- data/app/models/component.rb +8 -67
- data/app/models/item.rb +8 -73
- data/app/models/target.rb +6 -5
- data/config/initializers/active_fedora_base.rb +11 -30
- data/config/initializers/{active_fedora_datastream.rb → active_fedora_file.rb} +1 -1
- data/config/initializers/devise.rb +2 -3
- data/config/initializers/subscriptions.rb +2 -19
- data/ddr-models.gemspec +10 -14
- data/lib/ddr/actions/fixity_check.rb +1 -1
- data/lib/ddr/actions/virus_check.rb +17 -10
- data/lib/ddr/auth.rb +6 -38
- data/lib/ddr/auth/ability.rb +1 -5
- data/lib/ddr/auth/ability_definitions/collection_ability_definitions.rb +0 -16
- data/lib/ddr/auth/ability_definitions/datastream_ability_definitions.rb +10 -4
- data/lib/ddr/auth/ability_definitions/role_based_ability_definitions.rb +16 -9
- data/lib/ddr/auth/ability_factory.rb +25 -2
- data/lib/ddr/auth/abstract_ability.rb +1 -2
- data/lib/ddr/auth/auth_context.rb +0 -18
- data/lib/ddr/auth/auth_context_factory.rb +2 -0
- data/lib/ddr/auth/group.rb +0 -6
- data/lib/ddr/auth/grouper_gateway.rb +0 -24
- data/lib/ddr/auth/permissions.rb +1 -12
- data/lib/ddr/auth/role_based_access_controls_enforcement.rb +5 -5
- data/lib/ddr/auth/roles.rb +1 -11
- data/lib/ddr/auth/roles/role_set.rb +0 -7
- data/lib/ddr/auth/roles/roles_datastream.rb +9 -0
- data/lib/ddr/contacts.rb +25 -0
- data/lib/ddr/datastreams.rb +10 -28
- data/lib/ddr/datastreams/datastream_behavior.rb +30 -100
- data/lib/ddr/datastreams/descriptive_metadata_datastream.rb +28 -31
- data/lib/ddr/datastreams/fits_datastream.rb +9 -22
- data/lib/ddr/datastreams/metadata_datastream.rb +17 -31
- data/lib/ddr/derivatives.rb +13 -16
- data/lib/ddr/derivatives/derivative.rb +68 -0
- data/lib/ddr/derivatives/{generator.rb → generators/generator.rb} +11 -7
- data/lib/ddr/derivatives/generators/png_generator.rb +23 -0
- data/lib/ddr/derivatives/generators/ptif_generator.rb +56 -0
- data/lib/ddr/derivatives/multires_image.rb +59 -0
- data/lib/ddr/derivatives/thumbnail.rb +36 -0
- data/lib/ddr/events.rb +0 -1
- data/lib/ddr/events/deletion_event.rb +9 -5
- data/lib/ddr/events/event.rb +8 -13
- data/lib/ddr/events/fixity_check_event.rb +0 -6
- data/lib/ddr/events/ingestion_event.rb +9 -5
- data/lib/ddr/events/update_event.rb +4 -17
- data/lib/ddr/index.rb +4 -4
- data/lib/ddr/index/abstract_query_result.rb +4 -3
- data/lib/ddr/index/connection.rb +9 -28
- data/lib/ddr/index/csv_query_result.rb +32 -47
- data/lib/ddr/index/field.rb +1 -11
- data/lib/ddr/index/fields.rb +16 -99
- data/lib/ddr/index/filter.rb +30 -103
- data/lib/ddr/index/filters.rb +19 -0
- data/lib/ddr/index/query.rb +11 -58
- data/lib/ddr/index/query_builder.rb +36 -147
- data/lib/ddr/index/query_clause.rb +19 -79
- data/lib/ddr/index/query_result.rb +4 -36
- data/lib/ddr/index/query_value.rb +18 -0
- data/lib/ddr/index/response.rb +2 -19
- data/lib/ddr/jobs.rb +12 -0
- data/lib/ddr/jobs/fits_file_characterization.rb +51 -0
- data/lib/ddr/jobs/permanent_id.rb +23 -0
- data/lib/ddr/managers.rb +1 -0
- data/lib/ddr/managers/derivatives_manager.rb +53 -93
- data/lib/ddr/managers/permanent_id_manager.rb +91 -0
- data/lib/ddr/managers/technical_metadata_manager.rb +10 -24
- data/lib/ddr/managers/workflow_manager.rb +10 -29
- data/lib/ddr/models.rb +50 -101
- data/lib/ddr/models/access_controllable.rb +12 -0
- data/lib/ddr/models/admin_set.rb +5 -16
- data/lib/ddr/models/base.rb +45 -165
- data/lib/ddr/models/describable.rb +19 -21
- data/lib/ddr/models/engine.rb +11 -39
- data/lib/ddr/models/error.rb +0 -3
- data/lib/ddr/models/file_management.rb +36 -72
- data/lib/ddr/models/finding_aid.rb +2 -35
- data/lib/ddr/models/fixity_checkable.rb +4 -0
- data/lib/ddr/models/governable.rb +3 -1
- data/lib/ddr/models/has_admin_metadata.rb +82 -56
- data/lib/ddr/models/has_attachments.rb +3 -1
- data/lib/ddr/models/has_children.rb +3 -7
- data/lib/ddr/models/has_content.rb +35 -32
- data/lib/ddr/models/has_multires_image.rb +7 -12
- data/lib/ddr/models/has_struct_metadata.rb +44 -6
- data/lib/ddr/models/has_thumbnail.rb +1 -4
- data/lib/ddr/models/indexing.rb +97 -186
- data/lib/ddr/models/licenses/admin_policy_license.rb +11 -0
- data/lib/ddr/models/licenses/effective_license.rb +9 -0
- data/lib/ddr/models/licenses/inherited_license.rb +9 -0
- data/lib/ddr/models/licenses/license.rb +21 -0
- data/lib/ddr/models/licenses/parent_license.rb +11 -0
- data/lib/ddr/models/metadata/descriptive_metadata.rb +50 -0
- data/lib/ddr/models/metadata/metadata.rb +37 -0
- data/lib/ddr/models/metadata/metadata_mapper.rb +32 -0
- data/lib/ddr/models/metadata/metadata_mappers.rb +18 -0
- data/lib/ddr/models/metadata/metadata_term.rb +24 -0
- data/lib/ddr/models/metadata/metadata_vocabularies.rb +18 -0
- data/lib/ddr/models/metadata/metadata_vocabulary.rb +34 -0
- data/lib/ddr/models/solr_document.rb +24 -156
- data/lib/ddr/models/struct_div.rb +63 -0
- data/lib/ddr/models/structure.rb +39 -175
- data/lib/ddr/models/version.rb +1 -1
- data/lib/ddr/models/year_facet.rb +118 -60
- data/lib/ddr/notifications.rb +12 -10
- data/lib/ddr/utils.rb +15 -28
- data/lib/ddr/vocab.rb +17 -15
- data/lib/ddr/vocab/asset.rb +17 -42
- data/lib/ddr/vocab/contact.rb +7 -5
- data/lib/ddr/vocab/display.rb +8 -6
- data/lib/ddr/vocab/duke_terms.rb +10 -8
- data/lib/ddr/vocab/rdf_vocabulary_parser.rb +39 -37
- data/lib/ddr/vocab/roles.rb +19 -17
- data/lib/ddr/vocab/sources/duketerms.rdf +8 -22
- data/lib/ddr/vocab/vocabulary.rb +26 -26
- data/spec/auth/ability_factory_spec.rb +1 -18
- data/spec/auth/ability_spec.rb +15 -119
- data/spec/auth/effective_permissions_spec.rb +1 -1
- data/spec/auth/effective_roles_spec.rb +1 -1
- data/spec/auth/ldap_gateway_spec.rb +9 -0
- data/spec/contacts/contacts_spec.rb +26 -0
- data/spec/controllers/including_role_based_access_controls_enforcement_spec.rb +5 -5
- data/spec/derivatives/multires_image_spec.rb +48 -0
- data/spec/derivatives/png_generator_spec.rb +8 -13
- data/spec/derivatives/ptif_generator_spec.rb +11 -9
- data/spec/derivatives/thumbnail_spec.rb +48 -0
- data/spec/dummy/config/environments/test.rb +1 -1
- data/spec/dummy/db/schema.rb +23 -25
- data/spec/factories/attachment_factories.rb +2 -2
- data/spec/factories/collection_factories.rb +2 -3
- data/spec/factories/component_factories.rb +2 -2
- data/spec/factories/item_factories.rb +2 -2
- data/spec/factories/structure_factories.rb +2 -8
- data/spec/factories/test_model_factories.rb +12 -4
- data/spec/fixtures/fits/document.xml +44 -42
- data/spec/fixtures/fits/image.xml +41 -42
- data/spec/helpers/models_helper_spec.rb +11 -0
- data/spec/index/filter_spec.rb +30 -208
- data/spec/index/filters_spec.rb +17 -0
- data/spec/index/query_spec.rb +10 -82
- data/spec/jobs/fits_file_characterization_spec.rb +52 -0
- data/spec/managers/derivatives_manager_spec.rb +105 -107
- data/spec/managers/technical_metadata_manager_spec.rb +27 -34
- data/spec/models/active_fedora_base_spec.rb +105 -5
- data/spec/models/active_fedora_datastream_spec.rb +39 -106
- data/spec/models/admin_set_spec.rb +10 -43
- data/spec/models/attachment_spec.rb +2 -3
- data/spec/models/collection_spec.rb +11 -225
- data/spec/models/component_spec.rb +4 -106
- data/spec/models/descriptive_metadata_spec.rb +38 -0
- data/spec/models/effective_license_spec.rb +64 -0
- data/spec/models/events_spec.rb +59 -52
- data/spec/models/file_management_spec.rb +13 -113
- data/spec/models/finding_aid_spec.rb +8 -31
- data/spec/models/has_admin_metadata_spec.rb +122 -131
- data/spec/models/has_children_spec.rb +3 -3
- data/spec/models/has_struct_metadata_spec.rb +37 -50
- data/spec/models/indexing_spec.rb +23 -160
- data/spec/models/item_spec.rb +2 -133
- data/spec/models/license_spec.rb +24 -0
- data/spec/models/solr_document_spec.rb +47 -236
- data/spec/models/struct_div_spec.rb +70 -0
- data/spec/models/structure_spec.rb +11 -89
- data/spec/models/target_spec.rb +2 -4
- data/spec/models/year_facet_spec.rb +23 -50
- data/spec/spec_helper.rb +13 -17
- data/spec/support/ezid_mock_identifier.rb +2 -2
- data/spec/support/shared_examples_for_auth_contexts.rb +0 -33
- data/spec/support/shared_examples_for_ddr_models.rb +94 -142
- data/spec/support/shared_examples_for_describables.rb +36 -31
- data/spec/support/shared_examples_for_governables.rb +2 -3
- data/spec/support/shared_examples_for_has_content.rb +46 -101
- data/spec/support/shared_examples_for_indexing.rb +6 -6
- data/spec/support/shared_examples_for_non_collection_models.rb +1 -32
- data/spec/support/structural_metadata_helper.rb +59 -230
- data/spec/utils_spec.rb +2 -0
- metadata +96 -229
- data/.ruby-version +0 -1
- data/config/initializers/rsolr_monkey_patches.rb +0 -7
- data/config/initializers/rubydora_monkey_patch.rb +0 -11
- data/config/locales/ddr-models.en.yml +0 -81
- data/db/migrate/20161021201011_add_permanent_id_to_events.rb +0 -8
- data/lib/ddr/auth/ability_definitions/admin_set_ability_definitions.rb +0 -9
- data/lib/ddr/auth/ability_definitions/lock_ability_definitions.rb +0 -13
- data/lib/ddr/auth/ability_definitions/publication_ability_definitions.rb +0 -16
- data/lib/ddr/datastreams/administrative_metadata_datastream.rb +0 -75
- data/lib/ddr/datastreams/caption_datastream.rb +0 -5
- data/lib/ddr/datastreams/content_datastream.rb +0 -17
- data/lib/ddr/datastreams/delete_external_files.rb +0 -29
- data/lib/ddr/datastreams/external_file_datastream.rb +0 -80
- data/lib/ddr/datastreams/intermediate_file_datastream.rb +0 -5
- data/lib/ddr/datastreams/multires_image_datastream.rb +0 -5
- data/lib/ddr/datastreams/streamable_media_datastream.rb +0 -5
- data/lib/ddr/derivatives/png_generator.rb +0 -17
- data/lib/ddr/derivatives/ptif_generator.rb +0 -55
- data/lib/ddr/derivatives/update_derivatives.rb +0 -25
- data/lib/ddr/events/deaccession_event.rb +0 -8
- data/lib/ddr/index/field_attribute.rb +0 -22
- data/lib/ddr/index/query_params.rb +0 -40
- data/lib/ddr/index/sort_order.rb +0 -28
- data/lib/ddr/models/cache.rb +0 -20
- data/lib/ddr/models/captionable.rb +0 -37
- data/lib/ddr/models/contact.rb +0 -23
- data/lib/ddr/models/file_characterization.rb +0 -37
- data/lib/ddr/models/has_intermediate_file.rb +0 -41
- data/lib/ddr/models/language.rb +0 -31
- data/lib/ddr/models/media_type.rb +0 -22
- data/lib/ddr/models/permanent_id.rb +0 -240
- data/lib/ddr/models/rights_statement.rb +0 -25
- data/lib/ddr/models/streamable.rb +0 -37
- data/lib/ddr/models/structures/agent.rb +0 -49
- data/lib/ddr/models/structures/component_type_term.rb +0 -29
- data/lib/ddr/models/structures/div.rb +0 -64
- data/lib/ddr/models/structures/f_locat.rb +0 -54
- data/lib/ddr/models/structures/file.rb +0 -52
- data/lib/ddr/models/structures/file_grp.rb +0 -35
- data/lib/ddr/models/structures/file_sec.rb +0 -22
- data/lib/ddr/models/structures/fptr.rb +0 -31
- data/lib/ddr/models/structures/mets_hdr.rb +0 -37
- data/lib/ddr/models/structures/mptr.rb +0 -49
- data/lib/ddr/models/structures/struct_map.rb +0 -40
- data/lib/ddr/models/with_content_file.rb +0 -37
- data/spec/datastreams/external_file_datastream_spec.rb +0 -48
- data/spec/dummy/config/structure_component_type.yml +0 -18
- data/spec/fixtures/abcd1234.vtt +0 -38
- data/spec/fixtures/arrow1rightred_e0.gif +0 -0
- data/spec/fixtures/extractedText1.txt +0 -1
- data/spec/fixtures/extractedText2.txt +0 -1
- data/spec/fixtures/extractedText3.txt +0 -3
- data/spec/fixtures/imageA.jpg +0 -0
- data/spec/fixtures/imageB.jpg +0 -0
- data/spec/index/csv_query_result_spec.rb +0 -44
- data/spec/index/fields_spec.rb +0 -380
- data/spec/index/query_builder_spec.rb +0 -140
- data/spec/index/query_clause_spec.rb +0 -68
- data/spec/models/cache_spec.rb +0 -32
- data/spec/models/contact_spec.rb +0 -56
- data/spec/models/descriptive_metadata_datastream_spec.rb +0 -139
- data/spec/models/file_characterization_spec.rb +0 -39
- data/spec/models/language_spec.rb +0 -59
- data/spec/models/media_type_spec.rb +0 -46
- data/spec/models/permanent_id_spec.rb +0 -432
- data/spec/models/rights_statement_spec.rb +0 -55
- data/spec/models/structures/agent_spec.rb +0 -30
- data/spec/models/structures/component_type_term_spec.rb +0 -14
- data/spec/models/structures/div_spec.rb +0 -26
- data/spec/models/structures/f_locat_spec.rb +0 -78
- data/spec/models/structures/file_grp_spec.rb +0 -23
- data/spec/models/structures/file_sec_spec.rb +0 -22
- data/spec/models/structures/file_spec.rb +0 -60
- data/spec/models/structures/fptr_spec.rb +0 -23
- data/spec/models/structures/mets_hdr_spec.rb +0 -26
- data/spec/models/structures/mptr_spec.rb +0 -25
- data/spec/models/structures/struct_map_spec.rb +0 -24
- data/spec/models/with_content_file_spec.rb +0 -37
- data/spec/support/shared_examples_for_associations.rb +0 -8
- data/spec/support/shared_examples_for_captionable.rb +0 -23
- data/spec/support/shared_examples_for_has_intermediate_file.rb +0 -28
- data/spec/support/shared_examples_for_publication.rb +0 -43
- data/spec/support/shared_examples_for_streamable_media.rb +0 -23
@@ -4,20 +4,10 @@ require "delegate"
|
|
4
4
|
module Ddr
|
5
5
|
module Auth
|
6
6
|
class GrouperGateway < SimpleDelegator
|
7
|
-
extend Deprecation
|
8
7
|
|
9
8
|
SUBJECT_ID_RE = Regexp.new('[^@]+(?=@duke\.edu)')
|
10
9
|
DEFAULT_TIMEOUT = 5
|
11
10
|
|
12
|
-
def self.const_missing(name)
|
13
|
-
if name == :REPOSITORY_GROUP_FILTER
|
14
|
-
Deprecation.warn(self, "The constant `#{name}` is deprecated and will be removed in ddr-models 3.0." \
|
15
|
-
" Use `Ddr::Auth.repository_group_filter` instead.")
|
16
|
-
return Ddr::Auth.repository_group_filter
|
17
|
-
end
|
18
|
-
super
|
19
|
-
end
|
20
|
-
|
21
11
|
def self.repository_groups(*args)
|
22
12
|
new.repository_groups(*args)
|
23
13
|
end
|
@@ -46,13 +36,6 @@ module Ddr
|
|
46
36
|
end
|
47
37
|
end
|
48
38
|
|
49
|
-
# @deprecated Use {#repository_groups} instead.
|
50
|
-
def repository_group_names
|
51
|
-
Deprecation.warn(self.class, "`Ddr::Auth::GrouperGateway#repository_group_names` is deprecated." \
|
52
|
-
" Use `#repository_groups` instead.")
|
53
|
-
repository_groups
|
54
|
-
end
|
55
|
-
|
56
39
|
def user_groups(user, raw = false)
|
57
40
|
groups = []
|
58
41
|
subject_id = user.principal_name.scan(SUBJECT_ID_RE).first
|
@@ -82,13 +65,6 @@ module Ddr
|
|
82
65
|
end
|
83
66
|
end
|
84
67
|
|
85
|
-
# @deprecated Use {#user_groups} instead.
|
86
|
-
def user_group_names(user)
|
87
|
-
Deprecation.warn(self.class, "`Ddr::Auth::GrouperGateway#user_group_names` is deprecated." \
|
88
|
-
" Use `#user_groups` instead.")
|
89
|
-
user_groups(user)
|
90
|
-
end
|
91
|
-
|
92
68
|
end
|
93
69
|
end
|
94
70
|
end
|
data/lib/ddr/auth/permissions.rb
CHANGED
@@ -1,6 +1,5 @@
|
|
1
1
|
module Ddr::Auth
|
2
2
|
class Permissions
|
3
|
-
extend Deprecation
|
4
3
|
|
5
4
|
READ = :read
|
6
5
|
DOWNLOAD = :download
|
@@ -8,20 +7,10 @@ module Ddr::Auth
|
|
8
7
|
UPDATE = :update
|
9
8
|
REPLACE = :replace
|
10
9
|
ARRANGE = :arrange
|
11
|
-
PUBLISH = :publish
|
12
|
-
UNPUBLISH = :unpublish
|
13
10
|
AUDIT = :audit
|
14
11
|
GRANT = :grant
|
15
12
|
|
16
|
-
ALL = [ READ, DOWNLOAD, ADD_CHILDREN, UPDATE, REPLACE, ARRANGE,
|
17
|
-
|
18
|
-
def self.const_missing(name)
|
19
|
-
if name == :EDIT
|
20
|
-
Deprecation.warn(self, "`EDIT` is deprecated. Use `UPDATE` instead.")
|
21
|
-
return UPDATE
|
22
|
-
end
|
23
|
-
super
|
24
|
-
end
|
13
|
+
ALL = [ READ, DOWNLOAD, ADD_CHILDREN, UPDATE, REPLACE, ARRANGE, AUDIT, GRANT ]
|
25
14
|
|
26
15
|
end
|
27
16
|
end
|
@@ -17,22 +17,22 @@ module Ddr
|
|
17
17
|
@current_ability ||= AbilityFactory.call(current_user, request.env)
|
18
18
|
end
|
19
19
|
|
20
|
-
# List of
|
20
|
+
# List of IDs for policies on which any of the current user's agent has a role in policy scope
|
21
21
|
def policy_role_policies
|
22
22
|
@policy_role_policies ||= Array.new.tap do |uris|
|
23
23
|
filters = current_ability.agents.map do |agent|
|
24
24
|
"#{Ddr::Index::Fields::POLICY_ROLE}:\"#{agent}\""
|
25
25
|
end.join(" OR ")
|
26
26
|
query = "#{Ddr::Index::Fields::ACTIVE_FEDORA_MODEL}:Collection AND (#{filters})"
|
27
|
-
results = ActiveFedora::SolrService.query(query, rows: Collection.count, fl: Ddr::Index::Fields::
|
28
|
-
results.each_with_object(uris) { |r, memo| memo << r[Ddr::Index::Fields::
|
27
|
+
results = ActiveFedora::SolrService.query(query, rows: Collection.count, fl: Ddr::Index::Fields::ID)
|
28
|
+
results.each_with_object(uris) { |r, memo| memo << r[Ddr::Index::Fields::ID] }
|
29
29
|
end
|
30
30
|
end
|
31
31
|
|
32
32
|
def policy_role_filters
|
33
33
|
if policy_role_policies.present?
|
34
|
-
rels = policy_role_policies.map { |pid| [:
|
35
|
-
ActiveFedora::SolrService.construct_query_for_rel(rels, "OR")
|
34
|
+
rels = policy_role_policies.map { |pid| [:isGovernedBy, pid] }
|
35
|
+
ActiveFedora::SolrService.construct_query_for_rel(rels, " OR ")
|
36
36
|
end
|
37
37
|
end
|
38
38
|
|
data/lib/ddr/auth/roles.rb
CHANGED
@@ -1,13 +1,13 @@
|
|
1
1
|
module Ddr::Auth
|
2
2
|
module Roles
|
3
3
|
extend ActiveSupport::Autoload
|
4
|
-
extend Deprecation
|
5
4
|
|
6
5
|
autoload :DetachedRoleSet
|
7
6
|
autoload :PropertyRoleSet
|
8
7
|
autoload :Role
|
9
8
|
autoload :RoleSet
|
10
9
|
autoload :RoleSetQuery
|
10
|
+
autoload :RolesDatastream
|
11
11
|
autoload :RoleType
|
12
12
|
autoload :RoleTypes
|
13
13
|
|
@@ -19,16 +19,6 @@ module Ddr::Auth
|
|
19
19
|
|
20
20
|
class << self
|
21
21
|
|
22
|
-
def const_missing(name)
|
23
|
-
if name == :ArrayRoleSet
|
24
|
-
Deprecation.warn(Ddr::Auth::Roles, "`Ddr::Auth::Roles::ArrayRoleSet` is deprecated." \
|
25
|
-
" Use `Ddr::Auth::Roles::DetachedRoleSet` instead.")
|
26
|
-
DetachedRoleSet
|
27
|
-
else
|
28
|
-
super
|
29
|
-
end
|
30
|
-
end
|
31
|
-
|
32
22
|
def type_map
|
33
23
|
@type_map ||= role_types.map { |role_type| [role_type.to_s, role_type] }.to_h
|
34
24
|
end
|
@@ -1,6 +1,5 @@
|
|
1
1
|
module Ddr::Auth
|
2
2
|
module Roles
|
3
|
-
extend Deprecation
|
4
3
|
#
|
5
4
|
# Wraps a set of Roles
|
6
5
|
#
|
@@ -21,12 +20,6 @@ module Ddr::Auth
|
|
21
20
|
@role_set = role_set
|
22
21
|
end
|
23
22
|
|
24
|
-
def granted
|
25
|
-
Deprecation.warn(self.class, "`granted` is deprecated." \
|
26
|
-
" Use the RoleSet object directly.")
|
27
|
-
self
|
28
|
-
end
|
29
|
-
|
30
23
|
# Grants roles - i.e., adds them to the role set
|
31
24
|
# @example - default scope ("resource")
|
32
25
|
# grant type: "Curator", agent: "bob"
|
data/lib/ddr/contacts.rb
ADDED
@@ -0,0 +1,25 @@
|
|
1
|
+
module Ddr
|
2
|
+
module Contacts
|
3
|
+
extend ActiveSupport::Autoload
|
4
|
+
|
5
|
+
class << self
|
6
|
+
attr_accessor :contacts
|
7
|
+
end
|
8
|
+
|
9
|
+
def self.get(contact_slug)
|
10
|
+
load_contacts unless contacts
|
11
|
+
contacts[contact_slug]
|
12
|
+
end
|
13
|
+
|
14
|
+
def self.load_contacts
|
15
|
+
self.contacts = OpenStruct.new
|
16
|
+
contacts_file = File.join(Rails.root, 'config', 'contacts.yml')
|
17
|
+
YAML.load_file(contacts_file).each do |key, value|
|
18
|
+
contacts[key] = OpenStruct.new(value.merge('slug' => key))
|
19
|
+
end
|
20
|
+
rescue SystemCallError
|
21
|
+
Rails.logger.warn("Unable to load Contacts file: #{contacts_file}")
|
22
|
+
end
|
23
|
+
|
24
|
+
end
|
25
|
+
end
|
data/lib/ddr/datastreams.rb
CHANGED
@@ -4,22 +4,16 @@ module Ddr
|
|
4
4
|
module Datastreams
|
5
5
|
extend ActiveSupport::Autoload
|
6
6
|
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
STREAMABLE_MEDIA = "streamableMedia"
|
18
|
-
STRUCT_METADATA = "structMetadata"
|
19
|
-
THUMBNAIL = "thumbnail"
|
20
|
-
|
21
|
-
SAVE = "save.repo_file"
|
22
|
-
DELETE = "delete.repo_file"
|
7
|
+
CONTENT = "content"
|
8
|
+
DC = "DC"
|
9
|
+
DEFAULT_RIGHTS = "defaultRights"
|
10
|
+
DESC_METADATA = "descMetadata"
|
11
|
+
EXTRACTED_TEXT = "extractedText"
|
12
|
+
FITS = "fits".freeze
|
13
|
+
RELS_EXT = "RELS-EXT"
|
14
|
+
RIGHTS_METADATA = "rightsMetadata"
|
15
|
+
STRUCT_METADATA = "structMetadata"
|
16
|
+
THUMBNAIL = "thumbnail"
|
23
17
|
|
24
18
|
CHECKSUM_TYPE_MD5 = "MD5"
|
25
19
|
CHECKSUM_TYPE_SHA1 = "SHA-1"
|
@@ -29,24 +23,12 @@ module Ddr
|
|
29
23
|
|
30
24
|
CHECKSUM_TYPES = [ CHECKSUM_TYPE_MD5, CHECKSUM_TYPE_SHA1, CHECKSUM_TYPE_SHA256, CHECKSUM_TYPE_SHA384, CHECKSUM_TYPE_SHA512 ]
|
31
25
|
|
32
|
-
autoload :AdministrativeMetadataDatastream
|
33
|
-
autoload :CaptionDatastream
|
34
|
-
autoload :ContentDatastream
|
35
26
|
autoload :DatastreamBehavior
|
36
|
-
autoload :DeleteExternalFiles
|
37
27
|
autoload :DescriptiveMetadataDatastream
|
38
|
-
autoload :ExternalFileDatastream
|
39
28
|
autoload :FitsDatastream
|
40
|
-
autoload :IntermediateFileDatastream
|
41
29
|
autoload :MetadataDatastream
|
42
|
-
autoload :MultiresImageDatastream
|
43
30
|
autoload :PlainTextDatastream
|
44
|
-
autoload :StreamableMediaDatastream
|
45
31
|
autoload :StructuralMetadataDatastream
|
46
32
|
|
47
|
-
mattr_accessor :update_derivatives_on_changed do
|
48
|
-
[ CONTENT, INTERMEDIATE_FILE ]
|
49
|
-
end
|
50
|
-
|
51
33
|
end
|
52
34
|
end
|
@@ -1,92 +1,54 @@
|
|
1
1
|
module Ddr
|
2
2
|
module Datastreams
|
3
3
|
module DatastreamBehavior
|
4
|
-
extend ActiveSupport::Concern
|
5
4
|
|
6
5
|
DEFAULT_FILE_EXTENSION = "bin"
|
7
|
-
|
8
6
|
STRFTIME_FORMAT = "%Y-%m-%dT%H:%M:%S.%LZ"
|
9
7
|
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
def validate_checksum! checksum, checksum_type=nil
|
16
|
-
raise Ddr::Models::Error, "Checksum cannot be validated on new datastream." if new?
|
17
|
-
raise Ddr::Models::Error, "Checksum cannot be validated on unpersisted content." if content_changed?
|
18
|
-
raise Ddr::Models::ChecksumInvalid, "The repository internal checksum validation failed." unless dsChecksumValid
|
19
|
-
algorithm = checksum_type || self.checksumType
|
20
|
-
ds_checksum = if !external? && algorithm == self.checksumType
|
21
|
-
self.checksum
|
22
|
-
else
|
23
|
-
content_digest(algorithm)
|
24
|
-
end
|
25
|
-
if checksum == ds_checksum
|
26
|
-
"The checksum [#{algorithm}]#{checksum} is valid for datastream #{version_info}."
|
27
|
-
else
|
28
|
-
raise Ddr::Models::ChecksumInvalid, "The checksum [#{algorithm}]#{checksum} is not valid for datastream #{version_info}."
|
8
|
+
def dsid
|
9
|
+
warn "[DEPRECATION] `dsid` is no longer a datastream/file method." \
|
10
|
+
" Use `File.basename(id)`."
|
11
|
+
if id
|
12
|
+
::File.basename(id)
|
29
13
|
end
|
30
14
|
end
|
31
15
|
|
32
|
-
def
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
def version_uri
|
37
|
-
# E.g., info:fedora/duke:1/content/content.0
|
38
|
-
["info:fedora", pid, dsid, dsVersionID].join("/") unless new?
|
39
|
-
end
|
40
|
-
|
41
|
-
def version_info
|
42
|
-
# E.g., info:fedora/duke:1/content/content.0 [2013-09-26T20:00:03.357Z]
|
43
|
-
"#{version_uri} [#{Ddr::Utils.ds_as_of_date_time(self)}]" unless new?
|
16
|
+
def dsCreateDate
|
17
|
+
warn "[DEPRECATION] `dsCreateDate` is no longer a datastream/file method." \
|
18
|
+
" Use `create_date` instead."
|
19
|
+
create_date
|
44
20
|
end
|
45
21
|
|
46
|
-
def
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
22
|
+
def validate_checksum!(checksum_value, checksum_type=nil)
|
23
|
+
raise Ddr::Models::Error, "Checksum cannot be validated on new datastream." if new_record?
|
24
|
+
raise Ddr::Models::Error, "Checksum cannot be validated on unpersisted content." if content_changed?
|
25
|
+
raise Ddr::Models::ChecksumInvalid, "The repository internal checksum validation failed." unless check_fixity
|
26
|
+
algorithm = checksum_type || checksum.algorithm
|
27
|
+
calculated_checksum = if algorithm == checksum.algorithm
|
28
|
+
checksum.value
|
29
|
+
else
|
30
|
+
content_digest(algorithm)
|
31
|
+
end
|
32
|
+
if checksum_value == calculated_checksum
|
33
|
+
"The checksum #{algorithm}:#{checksum_value} is valid for datastream #{dsid}."
|
57
34
|
else
|
58
|
-
|
35
|
+
raise Ddr::Models::ChecksumInvalid, "The checksum #{algorithm}:#{checksum_value} is not valid for datastream #{dsid}."
|
59
36
|
end
|
60
37
|
end
|
61
38
|
|
62
|
-
def
|
63
|
-
|
64
|
-
Ddr::Utils.path_from_uri(dsLocation)
|
65
|
-
end
|
66
|
-
end
|
67
|
-
|
68
|
-
def file_name
|
69
|
-
if path = file_path
|
70
|
-
File.basename(path)
|
71
|
-
end
|
39
|
+
def create_date_string
|
40
|
+
dsCreateDate.strftime(STRFTIME_FORMAT) if dsCreateDate
|
72
41
|
end
|
73
42
|
|
74
|
-
|
75
|
-
|
76
|
-
if external?
|
77
|
-
if path = file_path
|
78
|
-
File.size(path)
|
79
|
-
end
|
80
|
-
else
|
81
|
-
dsSize
|
82
|
-
end
|
43
|
+
def content_digest(algorithm)
|
44
|
+
Ddr::Utils.digest(content, algorithm)
|
83
45
|
end
|
84
46
|
|
85
47
|
# Return default file extension for datastream based on MIME type
|
86
48
|
def default_file_extension
|
87
|
-
mimetypes = MIME::Types[
|
49
|
+
mimetypes = MIME::Types[mime_type]
|
88
50
|
return mimetypes.first.extensions.first unless mimetypes.empty?
|
89
|
-
case
|
51
|
+
case mime_type
|
90
52
|
when 'application/n-triples'
|
91
53
|
'txt'
|
92
54
|
else
|
@@ -94,14 +56,13 @@ module Ddr
|
|
94
56
|
end
|
95
57
|
end
|
96
58
|
|
97
|
-
# Return default file name prefix based on object PID
|
98
59
|
def default_file_prefix
|
99
|
-
|
60
|
+
(id && id.gsub(/\//, "_")) || "NEW"
|
100
61
|
end
|
101
62
|
|
102
63
|
# Return default file name
|
103
64
|
def default_file_name
|
104
|
-
[default_file_prefix, default_file_extension].join(".")
|
65
|
+
[ default_file_prefix, default_file_extension ].join(".")
|
105
66
|
end
|
106
67
|
|
107
68
|
def tempfile(prefix: nil, suffix: nil)
|
@@ -117,37 +78,6 @@ module Ddr
|
|
117
78
|
end
|
118
79
|
end
|
119
80
|
|
120
|
-
private
|
121
|
-
|
122
|
-
def default_notification_payload
|
123
|
-
{ pid: pid, file_id: dsid, control_group: controlGroup }
|
124
|
-
end
|
125
|
-
|
126
|
-
def delete_notification_payload
|
127
|
-
default_notification_payload.merge(
|
128
|
-
profile: profile.dup,
|
129
|
-
version_history: version_history
|
130
|
-
)
|
131
|
-
end
|
132
|
-
|
133
|
-
def notify_save
|
134
|
-
ActiveSupport::Notifications.instrument(
|
135
|
-
Ddr::Datastreams::SAVE,
|
136
|
-
default_notification_payload.merge(attributes_changed: changes)
|
137
|
-
) do |payload|
|
138
|
-
yield
|
139
|
-
payload[:profile] = profile.dup
|
140
|
-
end
|
141
|
-
end
|
142
|
-
|
143
|
-
def notify_delete
|
144
|
-
ActiveSupport::Notifications.instrument(
|
145
|
-
Ddr::Datastreams::DELETE, delete_notification_payload
|
146
|
-
) do |payload|
|
147
|
-
yield
|
148
|
-
end
|
149
|
-
end
|
150
|
-
|
151
81
|
end
|
152
82
|
end
|
153
83
|
end
|
@@ -1,46 +1,43 @@
|
|
1
|
-
|
1
|
+
module Ddr
|
2
|
+
module Datastreams
|
3
|
+
class DescriptiveMetadataDatastream < MetadataDatastream
|
2
4
|
|
3
|
-
|
4
|
-
|
5
|
+
class_attribute :vocabularies
|
6
|
+
self.vocabularies = [RDF::DC, Ddr::Vocab::DukeTerms].freeze
|
5
7
|
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
def self.default_attributes
|
10
|
-
super.merge(:mimeType => 'application/n-triples')
|
11
|
-
end
|
8
|
+
def self.default_attributes
|
9
|
+
super.merge(:mimeType => 'application/n-triples')
|
10
|
+
end
|
12
11
|
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
12
|
+
def self.indexers
|
13
|
+
# Add term_name => [indexers] mapping to customize indexing
|
14
|
+
{}
|
15
|
+
end
|
17
16
|
|
18
|
-
|
19
|
-
|
20
|
-
|
17
|
+
def self.default_indexers
|
18
|
+
[:stored_searchable]
|
19
|
+
end
|
21
20
|
|
22
|
-
|
23
|
-
|
24
|
-
|
21
|
+
def self.indexers_for(term_name)
|
22
|
+
indexers.fetch(term_name, default_indexers)
|
23
|
+
end
|
25
24
|
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
# Do not include :license as a descriptive metadata property
|
31
|
-
unless term_name == :license
|
25
|
+
# Add terms from the vocabularies as properties
|
26
|
+
vocabularies.each do |vocab|
|
27
|
+
Ddr::Vocab::Vocabulary.property_terms(vocab).each do |term|
|
28
|
+
term_name = Ddr::Vocab::Vocabulary.term_name(vocab, term)
|
32
29
|
property term_name, predicate: term do |index|
|
33
30
|
index.as *indexers_for(term_name)
|
34
31
|
end
|
35
32
|
end
|
36
33
|
end
|
37
|
-
end
|
38
34
|
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
35
|
+
# Override ActiveFedora::Rdf::Indexing#apply_prefix(name) to not
|
36
|
+
# prepend the index field name with a string based on the datastream id.
|
37
|
+
def apply_prefix(name)
|
38
|
+
name
|
39
|
+
end
|
44
40
|
|
41
|
+
end
|
45
42
|
end
|
46
43
|
end
|