hyrax 3.1.0 → 3.2.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (114) hide show
  1. checksums.yaml +4 -4
  2. data/.circleci/config.yml +5 -5
  3. data/.dassie/Gemfile +1 -1
  4. data/.dassie/app/controllers/catalog_controller.rb +6 -0
  5. data/Dockerfile +2 -3
  6. data/app/actors/hyrax/actors/base_actor.rb +1 -1
  7. data/app/actors/hyrax/actors/collections_membership_actor.rb +3 -3
  8. data/app/actors/hyrax/actors/file_set_actor.rb +2 -0
  9. data/app/assets/stylesheets/hyrax/_styles.scss +5 -0
  10. data/app/controllers/concerns/hyrax/collections_controller_behavior.rb +13 -5
  11. data/app/controllers/concerns/hyrax/controller.rb +13 -2
  12. data/app/controllers/hyrax/admin/admin_sets_controller.rb +2 -19
  13. data/app/controllers/hyrax/admin/permission_template_accesses_controller.rb +5 -2
  14. data/app/controllers/hyrax/collections_controller.rb +3 -1
  15. data/app/controllers/hyrax/dashboard/collection_members_controller.rb +12 -9
  16. data/app/controllers/hyrax/dashboard/collections_controller.rb +92 -28
  17. data/app/controllers/hyrax/dashboard/nest_collections_controller.rb +75 -39
  18. data/app/controllers/hyrax/my_controller.rb +4 -4
  19. data/app/controllers/hyrax/workflow_actions_controller.rb +8 -5
  20. data/app/forms/hyrax/forms/administrative_set_form.rb +62 -0
  21. data/app/forms/hyrax/forms/collection_form.rb +2 -2
  22. data/app/forms/hyrax/forms/dashboard/nest_collection_form.rb +14 -4
  23. data/app/forms/hyrax/forms/pcdm_collection_form.rb +64 -0
  24. data/app/forms/hyrax/forms/resource_form.rb +15 -10
  25. data/app/forms/hyrax/forms/workflow_action_form.rb +4 -0
  26. data/app/helpers/hyrax/hyrax_helper_behavior.rb +9 -0
  27. data/app/indexers/hyrax/administrative_set_indexer.rb +6 -6
  28. data/app/indexers/hyrax/pcdm_collection_indexer.rb +2 -0
  29. data/app/models/admin_set.rb +16 -5
  30. data/app/models/concerns/hyrax/ability/admin_set_ability.rb +31 -7
  31. data/app/models/concerns/hyrax/ability/collection_ability.rb +35 -20
  32. data/app/models/concerns/hyrax/ability/collection_type_ability.rb +1 -1
  33. data/app/models/concerns/hyrax/ability.rb +2 -2
  34. data/app/models/concerns/hyrax/solr_document_behavior.rb +2 -2
  35. data/app/models/hyrax/administrative_set.rb +7 -1
  36. data/app/models/hyrax/permission.rb +1 -1
  37. data/app/models/hyrax/permission_template.rb +19 -5
  38. data/app/models/hyrax/work.rb +1 -0
  39. data/app/models/hyrax/workflow_action_info.rb +16 -0
  40. data/app/models/sipity/comment.rb +17 -0
  41. data/app/models/sipity.rb +11 -2
  42. data/app/presenters/hyrax/admin_set_presenter.rb +8 -3
  43. data/app/presenters/hyrax/collection_presenter.rb +3 -3
  44. data/app/presenters/hyrax/work_show_presenter.rb +2 -1
  45. data/app/search_builders/hyrax/abstract_type_relation.rb +4 -2
  46. data/app/search_builders/hyrax/dashboard/collections_search_builder.rb +1 -1
  47. data/app/search_builders/hyrax/exposed_models_relation.rb +1 -1
  48. data/app/search_builders/hyrax/filter_by_type.rb +1 -2
  49. data/app/search_builders/hyrax/my/collections_search_builder.rb +1 -1
  50. data/app/services/hyrax/admin_set_create_service.rb +136 -54
  51. data/app/services/hyrax/collection_types/permissions_service.rb +1 -1
  52. data/app/services/hyrax/collections/collection_member_service.rb +12 -2
  53. data/app/services/hyrax/collections/permissions_create_service.rb +81 -79
  54. data/app/services/hyrax/collections/permissions_service.rb +1 -1
  55. data/app/services/hyrax/curation_concern.rb +24 -2
  56. data/app/services/hyrax/default_middleware_stack.rb +11 -0
  57. data/app/services/hyrax/ensure_well_formed_admin_set_service.rb +3 -3
  58. data/app/services/hyrax/listeners/active_fedora_acl_index_listener.rb +1 -0
  59. data/app/services/hyrax/listeners/metadata_index_listener.rb +25 -9
  60. data/app/services/hyrax/permission_manager.rb +4 -4
  61. data/app/services/hyrax/solr_service.rb +1 -1
  62. data/app/services/hyrax/statistics/collections/over_time.rb +2 -1
  63. data/app/services/hyrax/workflow/abstract_notification.rb +2 -2
  64. data/app/services/hyrax/workflow/action_taken_service.rb +16 -4
  65. data/app/services/hyrax/workflow/activate_object.rb +5 -4
  66. data/app/services/hyrax/workflow/changes_required_notification.rb +5 -4
  67. data/app/services/hyrax/workflow/deactivate_object.rb +7 -5
  68. data/app/services/hyrax/workflow/deposited_notification.rb +8 -4
  69. data/app/services/hyrax/workflow/grant_edit_to_depositor.rb +7 -3
  70. data/app/services/hyrax/workflow/grant_read_to_depositor.rb +10 -3
  71. data/app/services/hyrax/workflow/revoke_edit_from_depositor.rb +8 -2
  72. data/app/services/hyrax/workflow/workflow_action_service.rb +4 -1
  73. data/app/views/hyrax/admin/admin_sets/_form.html.erb +1 -1
  74. data/app/views/hyrax/dashboard/collections/_collection_title.html.erb +1 -1
  75. data/app/views/hyrax/dashboard/collections/_form.html.erb +1 -1
  76. data/app/views/hyrax/dashboard/collections/_sort_and_per_page.html.erb +1 -1
  77. data/app/views/hyrax/homepage/index.html.erb +1 -1
  78. data/app/views/hyrax/my/collections/_modal_collection_types_to_create.html.erb +1 -1
  79. data/app/views/layouts/hyrax/dashboard.html.erb +1 -0
  80. data/app/views/layouts/hyrax.html.erb +1 -0
  81. data/app/views/shared/_read_only.html.erb +5 -0
  82. data/chart/hyrax/Chart.yaml +2 -2
  83. data/chart/hyrax/templates/deployment.yaml +6 -0
  84. data/config/features.rb +3 -0
  85. data/config/initializers/1_healthz.rb +1 -0
  86. data/config/initializers/listeners.rb +2 -1
  87. data/config/locales/hyrax.en.yml +1 -0
  88. data/db/seeds.rb +1 -1
  89. data/documentation/developing-your-hyrax-based-app.md +1 -1
  90. data/documentation/legacyREADME.md +1 -1
  91. data/hyrax.gemspec +1 -1
  92. data/lib/generators/hyrax/templates/catalog_controller.rb +3 -1
  93. data/lib/generators/hyrax/templates/config/initializers/hyrax.rb +10 -0
  94. data/lib/generators/hyrax/work/templates/feature_spec.rb.erb +1 -1
  95. data/lib/generators/hyrax/work_resource/templates/indexer_spec.rb.erb +1 -0
  96. data/lib/hyrax/collection_name.rb +6 -2
  97. data/lib/hyrax/configuration.rb +28 -0
  98. data/lib/hyrax/form_fields.rb +1 -0
  99. data/lib/hyrax/publisher.rb +12 -0
  100. data/lib/hyrax/resource_sync/change_list_writer.rb +2 -2
  101. data/lib/hyrax/resource_sync/resource_list_writer.rb +2 -2
  102. data/lib/hyrax/specs/shared_specs/hydra_works.rb +2 -0
  103. data/lib/hyrax/specs/shared_specs/indexers.rb +6 -0
  104. data/lib/hyrax/transactions/collection_create.rb +25 -0
  105. data/lib/hyrax/transactions/collection_update.rb +20 -0
  106. data/lib/hyrax/transactions/container.rb +26 -0
  107. data/lib/hyrax/transactions/steps/add_to_collections.rb +13 -1
  108. data/lib/hyrax/transactions/steps/apply_collection_type_permissions.rb +29 -0
  109. data/lib/hyrax/transactions/steps/save.rb +18 -6
  110. data/lib/hyrax/transactions/steps/set_collection_type_gid.rb +35 -0
  111. data/lib/hyrax/version.rb +1 -1
  112. data/lib/tasks/default_admin_set.rake +12 -11
  113. data/template.rb +1 -1
  114. metadata +16 -9
@@ -1,100 +1,136 @@
1
1
  # frozen_string_literal: true
2
2
  module Hyrax
3
3
  module Dashboard
4
+ ##
5
+ # @api public
4
6
  class NestCollectionsController < ApplicationController
5
7
  include Blacklight::Base
8
+
6
9
  class_attribute :form_class, :new_collection_form_class
7
10
  self.form_class = Hyrax::Forms::Dashboard::NestCollectionForm
8
11
  self.new_collection_form_class = Hyrax::Forms::CollectionForm
9
12
 
10
13
  # Add this collection as a subcollection within another existing collection
11
14
  def create_relationship_within
12
- @form = build_within_form
13
- if @form.save
14
- notice = I18n.t('create_within', scope: 'hyrax.dashboard.nest_collections_form', child_title: @form.child.title.first, parent_title: @form.parent.title.first)
15
- redirect_to redirect_path(item: @form.child), notice: notice
15
+ authorize! :read, form_params[:child_id]
16
+
17
+ if form.save
18
+ notice = I18n.t('create_within', scope: 'hyrax.dashboard.nest_collections_form', child_title: form.child.title.first, parent_title: form.parent.title.first)
19
+ redirect_to redirect_path(item: form.child), notice: notice
16
20
  else
17
- redirect_to redirect_path(item: @form.child), flash: { error: @form.errors.full_messages }
21
+ redirect_to redirect_path(item: form.child), flash: { error: form.errors.full_messages }
18
22
  end
19
23
  end
20
24
 
21
25
  # create and link a NEW subcollection under this collection, with this collection as parent
22
26
  def create_collection_under
23
- @form = build_create_collection_form
24
- if @form.validate_add
25
- redirect_to new_dashboard_collection_path(collection_type_id: @form.parent.collection_type.id, parent_id: @form.parent)
27
+ authorize! :deposit, form_params[:parent_id]
28
+
29
+ if form.validate_add
30
+ redirect_to new_dashboard_collection_path(collection_type_id: parent_type_id_for(form), parent_id: form.parent)
26
31
  else
27
- redirect_to redirect_path(item: @form.parent), flash: { error: @form.errors.full_messages }
32
+ redirect_to redirect_path(item: form.parent), flash: { error: form.errors.full_messages }
28
33
  end
29
34
  end
30
35
 
31
36
  # link this collection as parent by adding existing collection as subcollection under this one
32
37
  def create_relationship_under
33
- @form = build_under_form
34
- if @form.save
35
- notice = I18n.t('create_under', scope: 'hyrax.dashboard.nest_collections_form', child_title: @form.child.title.first, parent_title: @form.parent.title.first)
36
- redirect_to redirect_path(item: @form.parent), notice: notice
38
+ authorize! :read, form_params[:parent_id]
39
+
40
+ if form.save
41
+ notice = I18n.t('create_under', scope: 'hyrax.dashboard.nest_collections_form', child_title: form.child.title.first, parent_title: form.parent.title.first)
42
+ redirect_to redirect_path(item: form.parent), notice: notice
37
43
  else
38
- redirect_to redirect_path(item: @form.parent), flash: { error: @form.errors.full_messages }
44
+ redirect_to redirect_path(item: form.parent), flash: { error: form.errors.full_messages }
39
45
  end
40
46
  end
41
47
 
42
48
  # remove a parent collection relationship from this collection
43
49
  def remove_relationship_above
44
- @form = build_remove_form
45
- if @form.remove
46
- notice = I18n.t('removed_relationship', scope: 'hyrax.dashboard.nest_collections_form', child_title: @form.child.title.first, parent_title: @form.parent.title.first)
47
- redirect_to redirect_path(item: @form.child), notice: notice
50
+ authorize! :edit, form_params[:parent_id]
51
+ if form.remove
52
+ notice = I18n.t('removed_relationship', scope: 'hyrax.dashboard.nest_collections_form', child_title: form.child.title.first, parent_title: form.parent.title.first)
53
+ redirect_to redirect_path(item: form.child), notice: notice
48
54
  else
49
- redirect_to redirect_path(item: @form.child), flash: { error: @form.errors.full_messages }
55
+ redirect_to redirect_path(item: form.child), flash: { error: form.errors.full_messages }
50
56
  end
51
57
  end
52
58
 
53
59
  # remove a subcollection relationship from this collection
54
60
  def remove_relationship_under
55
- @form = build_remove_form
56
- if @form.remove
57
- notice = I18n.t('removed_relationship', scope: 'hyrax.dashboard.nest_collections_form', child_title: @form.child.title.first, parent_title: @form.parent.title.first)
58
- redirect_to redirect_path(item: @form.parent), notice: notice
61
+ authorize! :edit, form_params[:parent_id]
62
+
63
+ if form.remove
64
+ notice = I18n.t('removed_relationship', scope: 'hyrax.dashboard.nest_collections_form', child_title: form.child.title.first, parent_title: form.parent.title.first)
65
+ redirect_to redirect_path(item: form.parent), notice: notice
59
66
  else
60
- redirect_to redirect_path(item: @form.parent), flash: { error: @form.errors.full_messages }
67
+ redirect_to redirect_path(item: form.parent), flash: { error: form.errors.full_messages }
61
68
  end
62
69
  end
63
70
 
64
71
  private
65
72
 
73
+ ##
74
+ # @deprecated
66
75
  def build_within_form
67
- child = ::Collection.find(params.fetch(:child_id))
68
- authorize! :read, child
69
- parent = params.key?(:parent_id) ? ::Collection.find(params[:parent_id]) : nil
70
- form_class.new(child: child, parent: parent, context: self)
76
+ authorize! :read, form_params[:child_id]
77
+ form_class.new(context: self, **form_params.to_h.symbolize_keys)
71
78
  end
79
+ deprecation_deprecate :build_within_form
72
80
 
81
+ ##
82
+ # @deprecated
73
83
  def build_under_form
74
- parent = ::Collection.find(params.fetch(:parent_id))
75
- authorize! :deposit, parent
76
- child = params.key?(:child_id) ? ::Collection.find(params[:child_id]) : nil
77
- form_class.new(child: child, parent: parent, context: self)
84
+ authorize! :read, form_params[:parent_id]
85
+ form_class.new(context: self, **form_params.to_h.symbolize_keys)
78
86
  end
87
+ deprecation_deprecate :build_under_form
79
88
 
89
+ ##
90
+ # @deprecated
80
91
  def build_create_collection_form
81
- parent = ::Collection.find(params.fetch(:parent_id))
82
- authorize! :deposit, parent
83
- form_class.new(child: nil, parent: parent, context: self)
92
+ authorize! :deposit, form_params[:parent_id]
93
+ form_class.new(context: self, **form_params.to_h.symbolize_keys)
84
94
  end
95
+ deprecation_deprecate :build_create_collection_form
85
96
 
97
+ ##
98
+ # @deprecated
86
99
  def build_remove_form
87
- child = ::Collection.find(params.fetch(:child_id))
88
- parent = ::Collection.find(params.fetch(:parent_id))
89
- authorize! :edit, parent
90
- form_class.new(child: child, parent: parent, context: self)
100
+ authorize! :edit, form_params[:parent_id]
101
+ form_class.new(context: self, **form_params.to_h.symbolize_keys)
91
102
  end
103
+ deprecation_deprecate :build_create_collection_form
92
104
 
105
+ ##
106
+ # @api public
107
+ # @since 3.2.0
108
+ def form
109
+ @form ||=
110
+ form_class.new(context: self, **form_params.to_h.symbolize_keys)
111
+ end
112
+
113
+ ##
114
+ # @api public
115
+ # @since 3.2.0
116
+ def form_params
117
+ params.slice(:child_id, :parent_id).permit!
118
+ end
119
+
120
+ ##
121
+ # @api public
122
+ #
93
123
  # determine appropriate redirect location depending on specified source
94
124
  def redirect_path(item:)
95
125
  return my_collections_path if params[:source] == 'my'
96
126
  dashboard_collection_path(item)
97
127
  end
128
+
129
+ ##
130
+ # @api private
131
+ def parent_type_id_for(form)
132
+ URI::GID.parse(form.parent.collection_type_gid).model_id
133
+ end
98
134
  end
99
135
  end
100
136
  end
@@ -27,7 +27,9 @@ module Hyrax
27
27
  configure_facets
28
28
 
29
29
  before_action :authenticate_user!
30
- load_and_authorize_resource only: :show, instance_name: :collection
30
+ load_and_authorize_resource only: :show,
31
+ instance_name: :collection,
32
+ class: Hyrax.config.collection_model
31
33
 
32
34
  # include the render_check_all view helper method
33
35
  helper Hyrax::BatchEditsHelper
@@ -36,9 +38,7 @@ module Hyrax
36
38
 
37
39
  def index
38
40
  @user = current_user
39
- Deprecation.silence(Hyrax::MyController) do
40
- (@response, @document_list) = query_solr
41
- end
41
+ (@response, @document_list) = search_service.search_results
42
42
  prepare_instance_variables_for_batch_control_display
43
43
 
44
44
  respond_to do |format|
@@ -3,6 +3,13 @@ module Hyrax
3
3
  class WorkflowActionsController < ApplicationController
4
4
  DEFAULT_FORM_CLASS = Hyrax::Forms::WorkflowActionForm
5
5
 
6
+ ##
7
+ # @!attribute [r] curation_concern
8
+ # @api private
9
+ # @return [Hyrax::Resource]
10
+ attr_reader :curation_concern
11
+
12
+ load_resource class: Hyrax::Resource, instance_name: :curation_concern
6
13
  before_action :authenticate_user!
7
14
 
8
15
  def update
@@ -11,17 +18,13 @@ module Hyrax
11
18
  else
12
19
  respond_to do |wants|
13
20
  wants.html { render 'hyrax/base/unauthorized', status: :unauthorized }
14
- wants.json { render_json_response(response_type: :unprocessable_entity, options: { errors: curation_concern.errors }) }
21
+ wants.json { render_json_response(response_type: :unprocessable_entity, options: { errors: workflow_action_form.errors }) }
15
22
  end
16
23
  end
17
24
  end
18
25
 
19
26
  private
20
27
 
21
- def curation_concern
22
- @curation_concern ||= Hyrax.query_service.find_by_alternate_identifier(alternate_identifier: params[:id], use_valkyrie: false)
23
- end
24
-
25
28
  def workflow_action_form
26
29
  @workflow_action_form ||= DEFAULT_FORM_CLASS.new(
27
30
  current_ability: current_ability,
@@ -0,0 +1,62 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Hyrax
4
+ module Forms
5
+ ##
6
+ # @api public
7
+ # @see https://github.com/samvera/valkyrie/wiki/ChangeSets-and-Dirty-Tracking
8
+ class AdministrativeSetForm < Valkyrie::ChangeSet
9
+ property :title, required: true, primary: true
10
+ property :description, primary: true
11
+
12
+ property :human_readable_type, writable: false
13
+ property :date_modified, readable: false
14
+ property :date_uploaded, readable: false
15
+
16
+ property :depositor
17
+
18
+ class << self
19
+ def model_class
20
+ Hyrax::AdministrativeSet
21
+ end
22
+
23
+ ##
24
+ # @return [Array<Symbol>] list of required field names as symbols
25
+ def required_fields
26
+ definitions
27
+ .select { |_, definition| definition[:required] }
28
+ .keys.map(&:to_sym)
29
+ end
30
+ end
31
+
32
+ ##
33
+ # @return [Array<Symbol>] terms for display 'above-the-fold', or in the most
34
+ # prominent form real estate
35
+ def primary_terms
36
+ _form_field_definitions
37
+ .select { |_, definition| definition[:primary] }
38
+ .keys.map(&:to_sym)
39
+ end
40
+
41
+ ##
42
+ # @return [Array<Symbol>] terms for display 'below-the-fold'
43
+ def secondary_terms
44
+ _form_field_definitions
45
+ .select { |_, definition| definition[:display] && !definition[:primary] }
46
+ .keys.map(&:to_sym)
47
+ end
48
+
49
+ ##
50
+ # @return [Boolean] whether there are terms to display 'below-the-fold'
51
+ def display_additional_fields?
52
+ secondary_terms.any?
53
+ end
54
+
55
+ private
56
+
57
+ def _form_field_definitions
58
+ self.class.definitions
59
+ end
60
+ end
61
+ end
62
+ end
@@ -16,7 +16,7 @@ module Hyrax
16
16
  # Required for search builder (FIXME)
17
17
  alias collection model
18
18
 
19
- self.model_class = ::Collection
19
+ self.model_class = Hyrax.config.collection_class
20
20
 
21
21
  self.membership_service_class = Collections::CollectionMemberSearchService
22
22
 
@@ -131,7 +131,7 @@ module Hyrax
131
131
  def available_parent_collections(scope:)
132
132
  return @available_parents if @available_parents.present?
133
133
 
134
- collection = ::Collection.find(id)
134
+ collection = model_class.find(id)
135
135
  colls = Hyrax::Collections::NestedCollectionQueryService.available_parent_collections(child: collection, scope: scope, limit_to_id: nil)
136
136
  @available_parents = colls.map do |col|
137
137
  { "id" => col.id, "title_first" => col.title.first }
@@ -10,18 +10,28 @@ module Hyrax
10
10
  self.default_query_service = Hyrax::Collections::NestedCollectionQueryService
11
11
  self.default_persistence_service = Hyrax::Collections::NestedCollectionPersistenceService
12
12
 
13
+ ##
13
14
  # @param parent [::Collection, NilClass]
14
15
  # @param child [::Collection, NilClass]
16
+ # @param parent_id [String, nil]
17
+ # @param child_id [String, nil]
15
18
  # @param context [#can?,#repository,#blacklight_config]
16
19
  # @param query_service [Hyrax::Collections::NestedCollectionQueryService]
17
20
  # @param persistence_service [Hyrax::Collections::NestedCollectionPersistenceService] responsible for persisting the parent/child relationship
18
- def initialize(parent: nil, child: nil, context:, query_service: default_query_service, persistence_service: default_persistence_service)
19
- self.parent = parent
20
- self.child = child
21
+ # rubocop:disable Metrics/ParameterLists
22
+ def initialize(parent: nil,
23
+ child: nil,
24
+ parent_id: nil,
25
+ child_id: nil,
26
+ context:,
27
+ query_service: default_query_service,
28
+ persistence_service: default_persistence_service)
29
+ self.parent = parent || (parent_id.present? && Hyrax.config.collection_class.find(parent_id))
30
+ self.child = child || (child_id.present? && Hyrax.config.collection_class.find(child_id))
21
31
  self.context = context
22
32
  self.query_service = query_service
23
33
  self.persistence_service = persistence_service
24
- end
34
+ end # rubocop:enable Metrics/ParameterLists
25
35
 
26
36
  attr_accessor :parent, :child
27
37
 
@@ -0,0 +1,64 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Hyrax
4
+ module Forms
5
+ ##
6
+ # @api public
7
+ # @see https://github.com/samvera/valkyrie/wiki/ChangeSets-and-Dirty-Tracking
8
+ class PcdmCollectionForm < Valkyrie::ChangeSet # rubocop:disable Metrics/ClassLength
9
+ property :title, required: true, primary: true
10
+
11
+ property :human_readable_type, writable: false
12
+ property :date_modified, readable: false
13
+ property :date_uploaded, readable: false
14
+
15
+ property :depositor, required: true
16
+ property :collection_type_gid, required: true
17
+
18
+ property :member_of_collection_ids, default: [], type: Valkyrie::Types::Array
19
+
20
+ class << self
21
+ def model_class
22
+ Hyrax::PcdmCollection
23
+ end
24
+
25
+ ##
26
+ # @return [Array<Symbol>] list of required field names as symbols
27
+ def required_fields
28
+ definitions
29
+ .select { |_, definition| definition[:required] }
30
+ .keys.map(&:to_sym)
31
+ end
32
+ end
33
+
34
+ ##
35
+ # @return [Array<Symbol>] terms for display 'above-the-fold', or in the most
36
+ # prominent form real estate
37
+ def primary_terms
38
+ _form_field_definitions
39
+ .select { |_, definition| definition[:primary] }
40
+ .keys.map(&:to_sym)
41
+ end
42
+
43
+ ##
44
+ # @return [Array<Symbol>] terms for display 'below-the-fold'
45
+ def secondary_terms
46
+ _form_field_definitions
47
+ .select { |_, definition| definition[:display] && !definition[:primary] }
48
+ .keys.map(&:to_sym)
49
+ end
50
+
51
+ ##
52
+ # @return [Boolean] whether there are terms to display 'below-the-fold'
53
+ def display_additional_fields?
54
+ secondary_terms.any?
55
+ end
56
+
57
+ private
58
+
59
+ def _form_field_definitions
60
+ self.class.definitions
61
+ end
62
+ end
63
+ end
64
+ end
@@ -30,7 +30,7 @@ module Hyrax
30
30
  # @api public
31
31
  #
32
32
  # This form wraps `Hyrax::ChangeSet` in the `HydraEditor::Form` interface.
33
- class ResourceForm < Hyrax::ChangeSet
33
+ class ResourceForm < Hyrax::ChangeSet # rubocop:disable Metrics/ClassLength
34
34
  ##
35
35
  # @api private
36
36
  InWorksPopulator = lambda do |_options|
@@ -53,16 +53,15 @@ module Hyrax
53
53
  # we want to move away from application side lock validation and rely
54
54
  # on the adapter/database features instead.
55
55
  LockKeyPopulator = lambda do |_options|
56
- self.version =
57
- case Hyrax.metadata_adapter
58
- when Wings::Valkyrie::MetadataAdapter
56
+ if Hyrax.config.disable_wings || !Hyrax.metadata_adapter.is_a?(Wings::Valkyrie::MetadataAdapter)
57
+ Hyrax.logger.info "trying to prepopulate a lock token for " \
58
+ "#{self.class.inspect}, but optimistic locking isn't " \
59
+ "supported for the configured adapter: #{Hyrax.metadata_adapter.class}"
60
+ self.version = ''
61
+ else
62
+ self.version =
59
63
  model.persisted? ? Wings::ActiveFedoraConverter.convert(resource: model).etag : ''
60
- else
61
- Hyrax.logger.info 'trying to prepopulate a lock token for ' \
62
- "#{self.class.inspect}, but optimistic locking isn't " \
63
- "supported for the configured adapter: #{Hyrax.metadata_adapter.class}"
64
- ''
65
- end
64
+ end
66
65
  end
67
66
 
68
67
  class_attribute :model_class
@@ -101,6 +100,10 @@ module Hyrax
101
100
  property :member_ids, default: [], type: Valkyrie::Types::Array
102
101
  property :member_of_collection_ids, default: [], type: Valkyrie::Types::Array
103
102
 
103
+ property :representative_id, type: Valkyrie::Types::String
104
+ property :thumbnail_id, type: Valkyrie::Types::String
105
+ property :rendering_ids, default: [], type: Valkyrie::Types::Array
106
+
104
107
  # provide a lock token for optimistic locking; we name this `version` for
105
108
  # backwards compatibility
106
109
  #
@@ -130,6 +133,8 @@ module Hyrax
130
133
  case resource
131
134
  when Hyrax::FileSet
132
135
  Hyrax::Forms::FileSetForm.new(resource)
136
+ when Hyrax::PcdmCollection
137
+ Hyrax::Forms::PcdmCollectionForm.new(resource)
133
138
  else
134
139
  Hyrax::Forms::ResourceForm(resource.class).new(resource)
135
140
  end
@@ -17,6 +17,10 @@ module Hyrax
17
17
  include ActiveModel::Validations
18
18
  extend ActiveModel::Translation
19
19
 
20
+ ##
21
+ # @param current_ability [::Ability]
22
+ # @param work [ActiveFedora::Base, Valkyrie::Resource]
23
+ # @param attributes [Hash{Symbol => String}]
20
24
  def initialize(current_ability:, work:, attributes: {})
21
25
  @current_ability = current_ability
22
26
  @work = work
@@ -296,6 +296,15 @@ module Hyrax
296
296
  solr_field.first
297
297
  end
298
298
 
299
+ ##
300
+ # @param [Object] an object that might have a thumbnail
301
+ #
302
+ # @return [String] a label for the object's thumbnail
303
+ def thumbnail_label_for(object:)
304
+ object.try(:thumbnail_title).presence ||
305
+ ""
306
+ end
307
+
299
308
  private
300
309
 
301
310
  def user_agent
@@ -4,14 +4,14 @@ module Hyrax
4
4
  ##
5
5
  # Indexes Hyrax::AdministrativeSet objects
6
6
  class AdministrativeSetIndexer < Hyrax::ValkyrieIndexer
7
+ include Hyrax::Indexer(:core_metadata)
8
+
7
9
  def to_solr # rubocop:disable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/MethodLength
8
10
  super.tap do |solr_doc|
9
- solr_doc['generic_type_si'] = 'Admin Set'
10
- solr_doc['alternative_title_tesim'] = resource.alternative_title
11
- solr_doc['creator_ssim'] = resource.creator
12
- solr_doc['description_tesim'] = resource.description
13
- solr_doc['title_tesim'] = resource.title
14
- solr_doc['title_sim'] = resource.title
11
+ solr_doc[:generic_type_si] = 'Admin Set'
12
+ solr_doc[:alternative_title_tesim] = resource.alternative_title
13
+ solr_doc[:creator_ssim] = resource.creator
14
+ solr_doc[:description_tesim] = resource.description
15
15
  end
16
16
  end
17
17
  end
@@ -15,6 +15,8 @@ module Hyrax
15
15
  index_document[Hyrax.config.collection_type_index_field.to_sym] = Array(resource.try(:collection_type_gid)&.to_s)
16
16
  index_document[:generic_type_sim] = ['Collection']
17
17
  index_document[:thumbnail_path_ss] = Hyrax::CollectionThumbnailPathService.call(resource)
18
+ index_document[:depositor_ssim] = [resource.depositor]
19
+ index_document[:depositor_tesim] = [resource.depositor]
18
20
  end
19
21
  end
20
22
  end
@@ -21,9 +21,10 @@ class AdminSet < ActiveFedora::Base
21
21
  include Hyrax::Noid
22
22
  include Hyrax::HumanReadableType
23
23
  include Hyrax::HasRepresentative
24
+ include Hyrax::Permissions
24
25
 
25
- DEFAULT_ID = 'admin_set/default'
26
- DEFAULT_TITLE = ['Default Admin Set'].freeze
26
+ DEFAULT_ID = Hyrax::AdminSetCreateService::DEFAULT_ID
27
+ DEFAULT_TITLE = Hyrax::AdminSetCreateService::DEFAULT_TITLE
27
28
  DEFAULT_WORKFLOW_NAME = Hyrax.config.default_active_workflow_name
28
29
 
29
30
  validates_with Hyrax::HasOneTitleValidator
@@ -42,17 +43,27 @@ class AdminSet < ActiveFedora::Base
42
43
  after_destroy :destroy_permission_template
43
44
 
44
45
  def self.default_set?(id)
45
- id == DEFAULT_ID
46
+ Deprecation.warn("'##{__method__}' will be removed in Hyrax 4.0. " \
47
+ "Instead, use 'Hyrax::AdminSetCreateService.default_admin_set?(id:)'.")
48
+ Hyrax::AdminSetCreateService.default_admin_set?(id: id)
46
49
  end
47
50
 
48
51
  def default_set?
52
+ Deprecation.warn("'##{__method__}' will be removed in Hyrax 4.0. " \
53
+ "Instead, use 'Hyrax::AdminSetCreateService.default_admin_set?(id:)'.")
49
54
  self.class.default_set?(id)
50
55
  end
51
56
 
52
57
  # Creates the default AdminSet and an associated PermissionTemplate with workflow
53
58
  def self.find_or_create_default_admin_set_id
54
- Hyrax::AdminSetCreateService.create_default_admin_set(admin_set_id: DEFAULT_ID, title: DEFAULT_TITLE) unless exists?(DEFAULT_ID)
55
- DEFAULT_ID
59
+ Deprecation.warn("'##{__method__}' will be removed in Hyrax 4.0. " \
60
+ "Instead, use 'Hyrax::AdminSetCreateService.find_or_create_default_admin_set.id'.")
61
+ Hyrax::AdminSetCreateService.find_or_create_default_admin_set.id.to_s
62
+ end
63
+
64
+ def collection_type_gid
65
+ # allow AdminSet to behave more like a regular Collection
66
+ Hyrax::CollectionType.find_or_create_admin_set_type.to_global_id
56
67
  end
57
68
 
58
69
  def to_s
@@ -2,28 +2,52 @@
2
2
  module Hyrax
3
3
  module Ability
4
4
  module AdminSetAbility
5
- def admin_set_abilities # rubocop:disable Metrics/MethodLength
5
+ def admin_set_abilities # rubocop:disable Metrics/MethodLength, Metrics/AbcSize
6
6
  if admin?
7
- can :manage, AdminSet
7
+ can :manage, [AdminSet, Hyrax::AdministrativeSet]
8
8
  can :manage_any, AdminSet
9
+ can :manage_any, Hyrax::AdministrativeSet
9
10
  can :create_any, AdminSet
11
+ can :create_any, Hyrax::AdministrativeSet
10
12
  can :view_admin_show_any, AdminSet
13
+ can :view_admin_show_any, Hyrax::AdministrativeSet
11
14
  else
12
- can :manage_any, AdminSet if Hyrax::Collections::PermissionsService.can_manage_any_admin_set?(ability: self)
13
- can [:create_any, :create], AdminSet if Hyrax::CollectionTypes::PermissionsService.can_create_admin_set_collection_type?(ability: self)
14
- can :view_admin_show_any, AdminSet if Hyrax::Collections::PermissionsService.can_view_admin_show_for_any_admin_set?(ability: self)
15
-
16
- can [:edit, :update, :destroy], AdminSet do |admin_set| # for test by solr_doc, see solr_document_ability.rb
15
+ if Hyrax::Collections::PermissionsService.can_manage_any_admin_set?(ability: self)
16
+ can :manage_any, AdminSet
17
+ can :manage_any, Hyrax::AdministrativeSet
18
+ end
19
+ if Hyrax::CollectionTypes::PermissionsService.can_create_admin_set_collection_type?(ability: self)
20
+ can :create, [AdminSet, Hyrax::AdministrativeSet]
21
+ can :create_any, AdminSet
22
+ can :create_any, Hyrax::AdministrativeSet
23
+ end
24
+ if Hyrax::Collections::PermissionsService.can_view_admin_show_for_any_admin_set?(ability: self)
25
+ can :view_admin_show_any, AdminSet
26
+ can :view_admin_show_any, Hyrax::AdministrativeSet
27
+ end
28
+ # [:edit, :update, :destroy] for AdminSet is controlled by Hydra::Ability #edit_permissions
29
+ can [:edit, :update, :destroy], Hyrax::AdministrativeSet do |admin_set| # for test by solr_doc, see solr_document_ability.rb
17
30
  test_edit(admin_set.id)
18
31
  end
19
32
 
20
33
  can :deposit, AdminSet do |admin_set| # for test by solr_doc, see collection_ability.rb
21
34
  Hyrax::Collections::PermissionsService.can_deposit_in_collection?(ability: self, collection_id: admin_set.id)
22
35
  end
36
+ can :deposit, Hyrax::AdministrativeSet do |admin_set| # for test by solr_doc, see collection_ability.rb
37
+ Hyrax::Collections::PermissionsService.can_deposit_in_collection?(ability: self, collection_id: admin_set.id)
38
+ end
23
39
 
24
40
  can :view_admin_show, AdminSet do |admin_set| # admin show page # for test by solr_doc, see collection_ability.rb
25
41
  Hyrax::Collections::PermissionsService.can_view_admin_show_for_collection?(ability: self, collection_id: admin_set.id)
26
42
  end
43
+ can :view_admin_show, Hyrax::AdministrativeSet do |admin_set| # admin show page # for test by solr_doc, see collection_ability.rb
44
+ Hyrax::Collections::PermissionsService.can_view_admin_show_for_collection?(ability: self, collection_id: admin_set.id)
45
+ end
46
+
47
+ # [:read] for AdminSet is controlled by Hydra::Ability #read_permissions
48
+ can :read, Hyrax::AdministrativeSet do |admin_set| # admin show page # for test by solr_doc, see collection_ability.rb
49
+ test_read(admin_set.id)
50
+ end
27
51
  end
28
52
 
29
53
  # TODO: I'm not sure why this is checked with AdminSet abilities. It was before the refactor and since I'm not sure what the connection is, I left it here.