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
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: ea0970bcb0ea485337ce206cd398d9ca95ce9f5dbd22bda820b6112e089ed624
4
- data.tar.gz: c58183be603ec7ac6af52523412034f3b28332b2b8d5aa788239e7dabbf4c521
3
+ metadata.gz: d1dfd66c313400a16a149d5bdb7a2495164c18bce86b9bd8f079970b68e328cf
4
+ data.tar.gz: 66c678a483a9f2822712dea5f8448e55d9019dbdc47605b9a03177d0465ab775
5
5
  SHA512:
6
- metadata.gz: af2b27f2c10d54ede9007a17f4a126bf408d92c163a924081658625212ff52edccb06bbc7edcf49fce1faa56c715bdf0454f687fbc284f93cfd8d30dbb26d46a
7
- data.tar.gz: 85b38c0dc2628abbbb56dc8aed70461bb5fe6e9ce4444a2d61d6f972968efd1f9157881fc2a5f4443cb1bba85f0495b78e3bc2e7d0d7fe5ea9a8d4cb69d6946b
6
+ metadata.gz: 8309e7eb25d84767fd2395e04326df0c1f925bef0a2618818b0430327ac623f0f4078abbd45b5a966ccb6ccbc4c6bc233823e7d1b00d08b5e977771c97be4306
7
+ data.tar.gz: dd759280930d7cbc3448b3fafbfae5bbb631f9eb8fb93a9dca2e9ee73b3226f71d5b453ec29a40ac087dacf076059b752e8e72b2b9e35c5efab1b54743a1e958
data/.circleci/config.yml CHANGED
@@ -189,21 +189,21 @@ workflows:
189
189
  hyrax_valkyrie: "true"
190
190
  requires:
191
191
  - build
192
- ruby2-7-2:
192
+ ruby2-7-4:
193
193
  jobs:
194
194
  - bundle:
195
- ruby_version: "2.7.2"
195
+ ruby_version: "2.7.4"
196
196
  rails_version: "5.2.6"
197
197
  bundler_version: "2.1.4"
198
198
  - build:
199
- ruby_version: "2.7.2"
199
+ ruby_version: "2.7.4"
200
200
  rails_version: "5.2.6"
201
201
  bundler_version: "2.1.4"
202
202
  requires:
203
203
  - bundle
204
204
  - test:
205
- name: "ruby2-7-2"
206
- ruby_version: "2.7.2"
205
+ name: "ruby2-7-4"
206
+ ruby_version: "2.7.4"
207
207
  bundler_version: "2.1.4"
208
208
  requires:
209
209
  - build
data/.dassie/Gemfile CHANGED
@@ -8,7 +8,7 @@ else
8
8
  end
9
9
  git_source(:github) { |repo| "https://github.com/#{repo}.git" }
10
10
 
11
- ruby '2.7.2'
11
+ ruby '2.7.4'
12
12
 
13
13
  # Bundle edge Rails instead: gem 'rails', github: 'rails/rails'
14
14
  gem 'rails', '~> 5.2.4', '>= 5.2.4.4'
@@ -5,6 +5,8 @@ class CatalogController < ApplicationController
5
5
 
6
6
  # This filter applies the hydra access controls
7
7
  before_action :enforce_show_permissions, only: :show
8
+ # Allow all search options when in read-only mode
9
+ skip_before_action :check_read_only
8
10
 
9
11
  def self.uploaded_field
10
12
  "system_create_dtsi"
@@ -28,6 +30,10 @@ class CatalogController < ApplicationController
28
30
  config.view.gallery.partials = [:index_header, :index]
29
31
  config.view.slideshow.partials = [:index]
30
32
 
33
+ # Because too many times on Samvera tech people raise a problem regarding a failed query to SOLR.
34
+ # Often, it's because they inadvertently exceeded the character limit of a GET request.
35
+ config.http_method = :post
36
+
31
37
  ## Default parameters to send to solr for all search-like requests. See also SolrHelper#solr_search_params
32
38
  config.default_solr_params = {
33
39
  qt: "search",
data/Dockerfile CHANGED
@@ -1,6 +1,5 @@
1
- ARG RUBY_VERSION=2.7.2
2
- # lock at alpine3.12 because 3.13 has dns resolver problems
3
- FROM ruby:$RUBY_VERSION-alpine3.12 as hyrax-base
1
+ ARG RUBY_VERSION=2.7.4
2
+ FROM ruby:$RUBY_VERSION-alpine3.14 as hyrax-base
4
3
 
5
4
  ARG DATABASE_APK_PACKAGE="postgresql-dev"
6
5
  ARG EXTRA_APK_PACKAGES="git"
@@ -37,7 +37,7 @@ module Hyrax
37
37
  # @return [Boolean] true if destroy was successful
38
38
  def destroy(env)
39
39
  env.curation_concern.in_collection_ids.each do |id|
40
- destination_collection = ::Collection.find(id)
40
+ destination_collection = Hyrax.config.collection_class.find(id)
41
41
  destination_collection.members.delete(env.curation_concern)
42
42
  destination_collection.update_index
43
43
  end
@@ -69,7 +69,7 @@ module Hyrax
69
69
  # Adds the item to the ordered members so that it displays in the items
70
70
  # along side the FileSets on the show page
71
71
  def add(env, id)
72
- collection = ::Collection.find(id)
72
+ collection = Hyrax.config.collection_class.find(id)
73
73
  collection.reindex_extent = Hyrax::Adapters::NestingIndexAdapter::LIMITED_REINDEX
74
74
 
75
75
  return unless env.current_ability.can?(:deposit, collection)
@@ -78,7 +78,7 @@ module Hyrax
78
78
 
79
79
  # Remove the object from the members set and the ordered members list
80
80
  def remove(curation_concern, id)
81
- collection = ::Collection.find(id)
81
+ collection = Hyrax.config.collection_class.find(id)
82
82
  curation_concern.member_of_collections.delete(collection)
83
83
  end
84
84
 
@@ -107,7 +107,7 @@ module Hyrax
107
107
  collection_id = attributes_collection.first.second['id']
108
108
 
109
109
  # Do not apply permissions to work if collection type is configured not to
110
- collection = ::Collection.find(collection_id)
110
+ collection = Hyrax.config.collection_class.find(collection_id)
111
111
  return unless collection.share_applies_to_new_works?
112
112
 
113
113
  # Save the collection id in env for use in apply_permission_template_actor
@@ -165,6 +165,8 @@ module Hyrax
165
165
  elsif file_set.import_url.present?
166
166
  # This path is taken when file is a Tempfile (e.g. from ImportUrlJob)
167
167
  File.basename(Addressable::URI.unencode(file.file_url))
168
+ elsif file.respond_to?(:original_filename) # e.g. Rack::Test::UploadedFile
169
+ file.original_filename
168
170
  else
169
171
  File.basename(file)
170
172
  end
@@ -72,3 +72,8 @@ label.disabled {
72
72
  }
73
73
  }
74
74
  }
75
+
76
+ .read-only {
77
+ font-size: 1.2em;
78
+ margin: 0 0 10px;
79
+ }
@@ -29,7 +29,7 @@ module Hyrax
29
29
  end
30
30
 
31
31
  def show
32
- @curation_concern ||= Hyrax.query_service.find_by_alternate_identifier(alternate_identifier: params[:id])
32
+ @curation_concern = @collection # we must populate curation_concern
33
33
  presenter
34
34
  query_collection_members
35
35
  end
@@ -101,14 +101,22 @@ module Hyrax
101
101
  # uses the class attribute +parent_collection_query_service+ by default.
102
102
  def parent_collections(query_service: self.class.parent_collection_query_service)
103
103
  page = params[:parent_collection_page].to_i
104
- collection.parent_collections = query_service.parent_collections(
105
- child: collection_object, scope: self, page: page
106
- )
104
+
105
+ collection.parent_collections =
106
+ query_service.parent_collections(child: collection_object,
107
+ scope: self,
108
+ page: page)
107
109
  end
108
110
  alias load_parent_collections parent_collections
109
111
 
112
+ ##
113
+ # @note this is here because, though we want to load and authorize the real
114
+ # collection for show views, for apparently historical reasons,
115
+ # {#collection} is overridden to access `@presenter`. this should probably
116
+ # be deprecated and callers encouraged to use `@collection` but the scope
117
+ # and impact of that change needs more evaluation.
110
118
  def collection_object
111
- action_name == 'show' ? Collection.find(collection.id) : collection
119
+ action_name == 'show' ? @collection : collection
112
120
  end
113
121
 
114
122
  def member_subcollections
@@ -16,6 +16,7 @@ module Hyrax::Controller
16
16
  include Hydra::Controller::ControllerBehavior
17
17
  helper_method :create_work_presenter
18
18
  before_action :set_locale
19
+ before_action :check_read_only, except: [:show, :index]
19
20
  end
20
21
 
21
22
  # Provide a place for Devise to send the user to after signing in
@@ -34,12 +35,14 @@ module Hyrax::Controller
34
35
  # @api public
35
36
  #
36
37
  # @return [#[]] a resolver for Hyrax's Transactions; this *should* be a
37
- # thread-safe Dry::Container, but callers to this method should strictly
38
- # use #[] for access
38
+ # thread-safe {Dry::Container}, but callers to this method should strictly
39
+ # use +#[]+ for access.
39
40
  #
40
41
  # @example
41
42
  # transactions['change_set.create_work'].call(my_form)
42
43
  #
44
+ # @see Hyrax::Transactions::Container
45
+ # @see Hyrax::Transactions::Transaction
43
46
  # @see https://dry-rb.org/gems/dry-container
44
47
  def transactions
45
48
  Hyrax::Transactions::Container
@@ -88,4 +91,12 @@ module Hyrax::Controller
88
91
  wants.json { render_json_response(response_type: :unauthorized, message: json_message) }
89
92
  end
90
93
  end
94
+
95
+ # Redirect all deposit and edit requests with warning message when in read only mode
96
+ def check_read_only
97
+ return unless Flipflop.read_only?
98
+ # Allows feature to be turned off
99
+ return if self.class.to_s == Hyrax::Admin::StrategiesController.to_s
100
+ redirect_to root_path, flash: { error: t('hyrax.read_only') }
101
+ end
91
102
  end
@@ -4,9 +4,7 @@ module Hyrax
4
4
  include Hyrax::CollectionsControllerBehavior
5
5
 
6
6
  before_action :authenticate_user!
7
- before_action :ensure_manager!, except: [:show]
8
7
  load_and_authorize_resource
9
- before_action :ensure_viewer!, only: [:show]
10
8
 
11
9
  # Catch permission errors
12
10
  rescue_from Hydra::AccessDenied, CanCan::AccessDenied, with: :deny_adminset_access
@@ -43,10 +41,8 @@ module Hyrax
43
41
  end
44
42
 
45
43
  def index
46
- add_breadcrumb t(:'hyrax.controls.home'), root_path
47
- add_breadcrumb t(:'hyrax.dashboard.breadcrumbs.admin'), hyrax.dashboard_path
48
- add_breadcrumb t(:'hyrax.admin.sidebar.admin_sets'), hyrax.admin_admin_sets_path
49
- @admin_sets = Hyrax::AdminSetService.new(self).search_results(:edit)
44
+ # admin sets are listed with collections
45
+ redirect_to hyrax.my_collections_url
50
46
  end
51
47
 
52
48
  def new
@@ -106,19 +102,6 @@ module Hyrax
106
102
  hyrax.edit_admin_admin_set_path(@admin_set) + (params[:referer_anchor] || '')
107
103
  end
108
104
 
109
- def ensure_manager!
110
- # TODO: Review for possible removal. Doesn't appear to apply anymore.
111
- # Even though the user can view this admin set, they may not be able to view
112
- # it on the admin page.
113
- authorize! :manage_any, AdminSet
114
- end
115
-
116
- def ensure_viewer!
117
- # Even though the user can view this admin set, they may not be able to view
118
- # it on the admin page if access is granted as a public or registered user only.
119
- authorize! :view_admin_show, @admin_set
120
- end
121
-
122
105
  def create_admin_set
123
106
  admin_set_create_service.call(admin_set: @admin_set, creating_user: current_user)
124
107
  end
@@ -35,7 +35,7 @@ module Hyrax
35
35
  redirect_to hyrax.edit_admin_admin_set_path(source_id,
36
36
  anchor: 'participants'),
37
37
  notice: translate('participants', scope: 'hyrax.admin.admin_sets.form.permission_update_notices')
38
- elsif source.collection?
38
+ else
39
39
  redirect_to hyrax.edit_dashboard_collection_path(source_id,
40
40
  anchor: 'sharing'),
41
41
  notice: translate('sharing', scope: 'hyrax.dashboard.collections.form.permission_update_notices')
@@ -47,7 +47,7 @@ module Hyrax
47
47
  redirect_to hyrax.edit_admin_admin_set_path(source_id,
48
48
  anchor: 'participants'),
49
49
  alert: @permission_template_access.errors.full_messages.to_sentence
50
- elsif source.collection?
50
+ else
51
51
  redirect_to hyrax.edit_dashboard_collection_path(source_id,
52
52
  anchor: 'sharing'),
53
53
  alert: @permission_template_access.errors.full_messages.to_sentence
@@ -56,6 +56,9 @@ module Hyrax
56
56
 
57
57
  delegate :source_id, to: :permission_template
58
58
 
59
+ ##
60
+ # @todo can we avoid querying solr to deciede where to redirect? we
61
+ # otherwise don't need this data at all.
59
62
  def source
60
63
  @source ||= ::SolrDocument.find(source_id)
61
64
  end
@@ -4,7 +4,9 @@ module Hyrax
4
4
  include CollectionsControllerBehavior
5
5
  include BreadcrumbsForCollections
6
6
  with_themed_layout :decide_layout
7
- load_and_authorize_resource except: [:index, :show, :create], instance_name: :collection
7
+ load_and_authorize_resource except: [:index, :create],
8
+ instance_name: :collection,
9
+ class: Hyrax.config.collection_model
8
10
 
9
11
  # Renders a JSON response with a list of files in this collection
10
12
  # This is used by the edit form to populate the thumbnail_id dropdown
@@ -7,6 +7,10 @@ module Hyrax
7
7
 
8
8
  include Hyrax::Collections::AcceptsBatches
9
9
 
10
+ load_resource only: :update_members,
11
+ instance_name: :collection,
12
+ class: Hyrax.config.collection_model
13
+
10
14
  def after_update
11
15
  respond_to do |format|
12
16
  format.html { redirect_to success_return_path, notice: t('hyrax.dashboard.my.action.collection_update_success') }
@@ -26,9 +30,9 @@ module Hyrax
26
30
  after_update_error(err_msg) if err_msg.present?
27
31
  return if err_msg.present?
28
32
 
29
- collection.reindex_extent = Hyrax::Adapters::NestingIndexAdapter::LIMITED_REINDEX
33
+ @collection.try(:reindex_extent=, Hyrax::Adapters::NestingIndexAdapter::LIMITED_REINDEX)
30
34
  begin
31
- Hyrax::Collections::CollectionMemberService.add_members_by_ids(collection_id: collection.id,
35
+ Hyrax::Collections::CollectionMemberService.add_members_by_ids(collection_id: collection_id,
32
36
  new_member_ids: batch_ids,
33
37
  user: current_user)
34
38
  after_update
@@ -46,9 +50,12 @@ module Hyrax
46
50
  private
47
51
 
48
52
  def validate
49
- return t('hyrax.dashboard.my.action.members_no_access') if batch_ids.blank?
50
- return t('hyrax.dashboard.my.action.collection_deny_add_members') unless current_ability.can?(:deposit, collection)
51
- return t('hyrax.dashboard.my.action.add_to_collection_only') unless member_action == "add" # should never happen
53
+ return t('hyrax.dashboard.my.action.members_no_access') if
54
+ batch_ids.blank?
55
+ return t('hyrax.dashboard.my.action.collection_deny_add_members') unless
56
+ current_ability.can?(:deposit, @collection)
57
+ return t('hyrax.dashboard.my.action.add_to_collection_only') unless
58
+ member_action == "add" # should never happen
52
59
  end
53
60
 
54
61
  def success_return_path
@@ -63,10 +70,6 @@ module Hyrax
63
70
  params[:id]
64
71
  end
65
72
 
66
- def collection
67
- @collection ||= ::Collection.find(collection_id)
68
- end
69
-
70
73
  def batch_ids
71
74
  params[:batch_document_ids]
72
75
  end
@@ -43,7 +43,12 @@ module Hyrax
43
43
  # The search builder to find the collections' members
44
44
  self.membership_service_class = Collections::CollectionMemberSearchService
45
45
 
46
- load_and_authorize_resource except: [:index, :create], instance_name: :collection
46
+ load_and_authorize_resource except: [:index],
47
+ instance_name: :collection,
48
+ class: Hyrax.config.collection_model
49
+
50
+ skip_load_resource only: :create if
51
+ Hyrax.config.collection_class < ActiveFedora::Base
47
52
 
48
53
  def deny_collection_access(exception)
49
54
  if exception.action == :edit
@@ -63,14 +68,14 @@ module Hyrax
63
68
  @collection.collection_type_gid = CollectionType.find(collection_type_id).to_global_id
64
69
  add_breadcrumb t(:'hyrax.controls.home'), root_path
65
70
  add_breadcrumb t(:'hyrax.dashboard.breadcrumbs.admin'), hyrax.dashboard_path
66
- add_breadcrumb t('.header', type_title: @collection.collection_type.title), request.path
67
- @collection.apply_depositor_metadata(current_user.user_key)
71
+ add_breadcrumb t('.header', type_title: collection_type.title), request.path
72
+ @collection.try(:apply_depositor_metadata, current_user.user_key)
68
73
  form
69
74
  end
70
75
 
71
76
  def show
72
77
  # @todo: remove this unused assignment in 4.0.0
73
- @banner_file = presenter.banner_file if @collection.collection_type.brandable?
78
+ @banner_file = presenter.banner_file if collection_type.brandable?
74
79
 
75
80
  presenter
76
81
  query_collection_members
@@ -102,10 +107,11 @@ module Hyrax
102
107
  end
103
108
 
104
109
  def create
110
+ return valkyrie_create if @collection.is_a?(Valkyrie::Resource)
105
111
  # Manual load and authorize necessary because Cancan will pass in all
106
112
  # form attributes. When `permissions_attributes` are present the
107
113
  # collection is saved without a value for `has_model.`
108
- @collection = ::Collection.new
114
+ @collection = Hyrax.config.collection_class.new
109
115
  authorize! :create, @collection
110
116
  # Coming from the UI, a collection type gid should always be present. Coming from the API, if a collection type gid is not specified,
111
117
  # use the default collection type (provides backward compatibility with versions < Hyrax 2.1.0)
@@ -143,6 +149,9 @@ module Hyrax
143
149
  end
144
150
 
145
151
  process_member_changes
152
+
153
+ return valkyrie_update if @collection.is_a?(Valkyrie::Resource)
154
+
146
155
  @collection.visibility = Hydra::AccessControls::AccessRight::VISIBILITY_TEXT_VALUE_PRIVATE unless @collection.discoverable?
147
156
  # we don't have to reindex the full graph when updating collection
148
157
  @collection.reindex_extent = Hyrax::Adapters::NestingIndexAdapter::LIMITED_REINDEX
@@ -175,11 +184,20 @@ module Hyrax
175
184
  end
176
185
 
177
186
  def destroy
178
- if @collection.destroy
187
+ case @collection
188
+ when Valkyrie::Resource
189
+ Hyrax.persister.delete(resource: @collection)
179
190
  after_destroy(params[:id])
180
191
  else
181
- after_destroy_error(params[:id])
192
+ if @collection.destroy
193
+ after_destroy(params[:id])
194
+ else
195
+ after_destroy_error(params[:id])
196
+ end
182
197
  end
198
+ rescue StandardError => err
199
+ Rails.logger.error(err)
200
+ after_destroy_error(params[:id])
183
201
  end
184
202
 
185
203
  def collection
@@ -197,10 +215,36 @@ module Hyrax
197
215
 
198
216
  private
199
217
 
218
+ def valkyrie_create
219
+ form.validate(collection_params) &&
220
+ @collection = transactions['change_set.create_collection']
221
+ .with_step_args(
222
+ 'change_set.set_user_as_depositor' => { user: current_user },
223
+ 'collection_resource.apply_collection_type_permissions' => { user: current_user }
224
+ )
225
+ .call(form)
226
+ .value_or { return after_create_error }
227
+
228
+ add_members_to_collection unless batch.empty?
229
+ @collection
230
+ end
231
+
232
+ def valkyrie_update
233
+ form.validate(collection_params) &&
234
+ @collection = transactions['change_set.update_collection']
235
+ .call(form)
236
+ .value_or { return after_update_error }
237
+ after_update
238
+ end
239
+
200
240
  def default_collection_type
201
241
  Hyrax::CollectionType.find_or_create_default_collection_type
202
242
  end
203
243
 
244
+ def collection_type
245
+ @collection_type ||= CollectionType.find_by_gid!(collection.collection_type_gid)
246
+ end
247
+
204
248
  def link_parent_collection(parent_id)
205
249
  child = collection.respond_to?(:valkyrie_resource) ? collection.valkyrie_resource : collection
206
250
  Hyrax::Collections::CollectionMemberService.add_member(collection_id: parent_id,
@@ -341,8 +385,14 @@ module Hyrax
341
385
  deprecation_deprecate :single_item_search_builder
342
386
 
343
387
  def collection_params
344
- @participants = extract_old_style_permission_attributes(params[:collection])
345
- form_class.model_attributes(params[:collection])
388
+ if Hyrax.config.collection_class < ActiveFedora::Base
389
+ @participants = extract_old_style_permission_attributes(params[:collection])
390
+ form_class.model_attributes(params[:collection])
391
+ else
392
+ params.permit(collection: {})[:collection]
393
+ .merge(params.permit(:collection_type_gid))
394
+ .merge(member_of_collection_ids: Array(params[:parent_id]))
395
+ end
346
396
  end
347
397
 
348
398
  def extract_old_style_permission_attributes(attributes)
@@ -379,28 +429,36 @@ module Hyrax
379
429
  end
380
430
  end
381
431
 
382
- def add_members_to_collection(collection = nil)
383
- collection ||= @collection
384
- Hyrax::Collections::CollectionMemberService.add_members_by_ids(collection_id: collection.id,
385
- new_member_ids: batch,
386
- user: current_user)
432
+ def add_members_to_collection(collection = nil, collection_id: nil)
433
+ collection_id ||= (collection.try(:id) || @collection.id)
434
+
435
+ Hyrax::Collections::CollectionMemberService
436
+ .add_members_by_ids(collection_id: collection_id,
437
+ new_member_ids: batch,
438
+ user: current_user)
387
439
  end
388
440
 
389
441
  def remove_members_from_collection
390
- Hyrax::Collections::CollectionMemberService.remove_members_by_ids(collection_id: @collection.id,
391
- member_ids: batch,
392
- user: current_user)
442
+ Hyrax::Collections::CollectionMemberService
443
+ .remove_members_by_ids(collection_id: @collection.id,
444
+ member_ids: batch,
445
+ user: current_user)
393
446
  end
394
447
 
395
448
  def move_members_between_collections
396
- destination_collection = ::Collection.find(params[:destination_collection_id])
397
449
  remove_members_from_collection
398
- add_members_to_collection(destination_collection)
399
- if destination_collection.save
400
- flash[:notice] = "Successfully moved #{batch.count} files to #{destination_collection.title} Collection."
401
- else
402
- flash[:error] = "An error occured. Files were not moved to #{destination_collection.title} Collection."
403
- end
450
+ add_members_to_collection(collection_id: params[:destination_collection_id])
451
+
452
+ destination_title =
453
+ Hyrax.query_service.find_by(id: params[:destination_collection_id]).title.first ||
454
+ params[:destination_collection_id]
455
+ flash[:notice] = "Successfully moved #{batch.count} files to #{destination_title} Collection."
456
+ rescue StandardError => err
457
+ Rails.logger.error(err)
458
+ destination_title =
459
+ Hyrax.query_service.find_by(id: params[:destination_collection_id]).title.first ||
460
+ destination_id
461
+ flash[:error] = "An error occured. Files were not moved to #{destination_title} Collection."
404
462
  end
405
463
 
406
464
  # Include 'catalog' and 'hyrax/base' in the search path for views, while prefering
@@ -420,7 +478,13 @@ module Hyrax
420
478
  end
421
479
 
422
480
  def form
423
- @form ||= form_class.new(@collection, current_ability, repository)
481
+ @form ||=
482
+ case @collection
483
+ when Valkyrie::Resource
484
+ Hyrax::Forms::ResourceForm.for(@collection)
485
+ else
486
+ form_class.new(@collection, current_ability, repository)
487
+ end
424
488
  end
425
489
 
426
490
  def set_default_permissions
@@ -430,8 +494,8 @@ module Hyrax
430
494
 
431
495
  def query_collection_members
432
496
  member_works
433
- member_subcollections if collection.collection_type.nestable?
434
- parent_collections if collection.collection_type.nestable? && action_name == 'show'
497
+ member_subcollections if collection_type.nestable?
498
+ parent_collections if collection_type.nestable? && action_name == 'show'
435
499
  end
436
500
 
437
501
  # Instantiate the membership query service
@@ -459,7 +523,7 @@ module Hyrax
459
523
  end
460
524
 
461
525
  def collection_object
462
- action_name == 'show' ? ::Collection.find(collection.id) : collection
526
+ @collection
463
527
  end
464
528
 
465
529
  # You can override this method if you need to provide additional