hyrax 5.0.0.rc2 → 5.0.0.rc3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (307) hide show
  1. checksums.yaml +4 -4
  2. data/.circleci/config.yml +14 -0
  3. data/.dassie/app/listeners/hyrax_listener.rb +81 -0
  4. data/.dassie/config/environments/test.rb +0 -5
  5. data/.dassie/config/initializers/hyrax.rb +5 -0
  6. data/.dassie/config/initializers/publisher.rb +3 -0
  7. data/.dassie/config/initializers/riiif.rb +77 -0
  8. data/.gitignore +4 -0
  9. data/.koppie/.env +2 -2
  10. data/.koppie/app/forms/collection_resource_form.rb +1 -0
  11. data/.koppie/app/indexers/collection_resource_indexer.rb +1 -0
  12. data/.koppie/app/listeners/hyrax_listener.rb +81 -0
  13. data/.koppie/app/models/collection.rb +1 -1
  14. data/.koppie/app/models/collection_resource.rb +1 -0
  15. data/.koppie/config/analytics.yml +5 -5
  16. data/.koppie/config/initializers/publisher.rb +3 -0
  17. data/.koppie/config/initializers/riiif.rb +78 -0
  18. data/.koppie/config/metadata/collection_resource.yaml +8 -166
  19. data/.koppie/config/metadata/sample_metadata.yaml +4 -0
  20. data/CONTAINERS.md +39 -2
  21. data/Dockerfile +14 -11
  22. data/Gemfile +8 -7
  23. data/README.md +2 -0
  24. data/app/actors/hyrax/actors/base_actor.rb +6 -3
  25. data/app/actors/hyrax/actors/file_actor.rb +1 -1
  26. data/app/actors/hyrax/actors/lease_actor.rb +3 -6
  27. data/app/assets/javascripts/hyrax/save_work/uploaded_files.es6 +10 -2
  28. data/app/assets/stylesheets/hyrax/sidebar.scss +6 -1
  29. data/app/controllers/concerns/hyrax/collections_controller_behavior.rb +1 -1
  30. data/app/controllers/concerns/hyrax/local_file_downloads_controller_behavior.rb +12 -19
  31. data/app/controllers/concerns/hyrax/stream_file_downloads_controller_behavior.rb +54 -0
  32. data/app/controllers/concerns/hyrax/valkyrie_downloads_controller_behavior.rb +38 -9
  33. data/app/controllers/concerns/hyrax/works_controller_behavior.rb +19 -14
  34. data/app/controllers/hyrax/admin/admin_sets_controller.rb +2 -2
  35. data/app/controllers/hyrax/admin/analytics/work_reports_controller.rb +5 -5
  36. data/app/controllers/hyrax/dashboard/collections_controller.rb +2 -2
  37. data/app/controllers/hyrax/downloads_controller.rb +1 -0
  38. data/app/controllers/hyrax/file_sets_controller.rb +3 -2
  39. data/app/controllers/hyrax/my/collections_controller.rb +1 -1
  40. data/app/forms/concerns/hyrax/basic_metadata_form_fields_behavior.rb +1 -0
  41. data/app/forms/concerns/hyrax/contained_in_works_behavior.rb +24 -0
  42. data/app/forms/concerns/hyrax/deposit_agreement_behavior.rb +12 -0
  43. data/app/forms/concerns/hyrax/leaseability_behavior.rb +49 -0
  44. data/app/forms/concerns/hyrax/permission_behavior.rb +20 -0
  45. data/app/forms/hyrax/forms/administrative_set_form.rb +1 -5
  46. data/app/forms/hyrax/forms/collection_form.rb +19 -0
  47. data/app/forms/hyrax/forms/file_set_form.rb +5 -0
  48. data/app/forms/hyrax/forms/pcdm_collection_form.rb +1 -5
  49. data/app/forms/hyrax/forms/pcdm_object_form.rb +13 -22
  50. data/app/forms/hyrax/forms/resource_batch_edit_form.rb +7 -2
  51. data/app/forms/hyrax/forms/resource_form.rb +30 -100
  52. data/app/forms/hyrax/forms.rb +52 -0
  53. data/app/helpers/hyrax/hyrax_helper_behavior.rb +2 -0
  54. data/app/indexers/{hyrax → concerns/hyrax}/location_indexer.rb +1 -5
  55. data/app/indexers/{hyrax → concerns/hyrax}/permission_indexer.rb +2 -2
  56. data/app/indexers/{hyrax → concerns/hyrax}/visibility_indexer.rb +1 -1
  57. data/app/indexers/hyrax/administrative_set_indexer.rb +5 -17
  58. data/app/indexers/hyrax/indexers/administrative_set_indexer.rb +25 -0
  59. data/app/indexers/hyrax/indexers/file_set_indexer.rb +144 -0
  60. data/app/indexers/hyrax/indexers/pcdm_collection_indexer.rb +27 -0
  61. data/app/indexers/hyrax/indexers/pcdm_object_indexer.rb +72 -0
  62. data/app/indexers/hyrax/indexers/resource_indexer.rb +86 -0
  63. data/app/indexers/hyrax/indexers.rb +54 -0
  64. data/app/indexers/hyrax/pcdm_collection_indexer.rb +5 -18
  65. data/app/indexers/hyrax/valkyrie_collection_indexer.rb +6 -4
  66. data/app/indexers/hyrax/valkyrie_file_set_indexer.rb +5 -136
  67. data/app/indexers/hyrax/valkyrie_indexer.rb +8 -112
  68. data/app/indexers/hyrax/valkyrie_work_indexer.rb +5 -64
  69. data/app/indexers/hyrax/work_indexer.rb +1 -0
  70. data/app/jobs/create_work_job.rb +1 -0
  71. data/app/models/admin_set.rb +20 -1
  72. data/app/models/collection.rb +5 -0
  73. data/app/models/concerns/hyrax/ability/admin_set_ability.rb +13 -28
  74. data/app/models/concerns/hyrax/ability/collection_ability.rb +26 -28
  75. data/app/models/concerns/hyrax/ability/resource_ability.rb +19 -0
  76. data/app/models/concerns/hyrax/ability.rb +11 -9
  77. data/app/models/concerns/hyrax/collection_behavior.rb +8 -0
  78. data/app/models/concerns/hyrax/solr_document_behavior.rb +15 -5
  79. data/app/models/concerns/hyrax/work_behavior.rb +4 -0
  80. data/app/models/featured_work.rb +12 -4
  81. data/app/models/file_set.rb +5 -0
  82. data/app/models/hyrax/administrative_set.rb +1 -1
  83. data/app/models/hyrax/change_set.rb +2 -2
  84. data/app/models/hyrax/file_metadata.rb +34 -7
  85. data/app/models/hyrax/file_set.rb +2 -2
  86. data/app/models/hyrax/group.rb +9 -38
  87. data/app/models/hyrax/group_behavior.rb +58 -0
  88. data/app/models/hyrax/model_registry.rb +111 -0
  89. data/app/models/hyrax/pcdm_collection.rb +1 -7
  90. data/app/models/hyrax/resource.rb +66 -8
  91. data/app/models/hyrax/statistic.rb +1 -1
  92. data/app/models/hyrax/work.rb +1 -7
  93. data/app/presenters/hyrax/collapsable_section_presenter.rb +7 -3
  94. data/app/presenters/hyrax/file_set_presenter.rb +8 -6
  95. data/app/presenters/hyrax/lease_presenter.rb +4 -0
  96. data/app/presenters/hyrax/menu_presenter.rb +14 -2
  97. data/app/presenters/hyrax/pcdm_member_presenter_factory.rb +1 -1
  98. data/app/presenters/hyrax/version_list_presenter.rb +6 -4
  99. data/app/search_builders/hyrax/admin_set_search_builder.rb +1 -1
  100. data/app/search_builders/hyrax/catalog_search_builder.rb +2 -2
  101. data/app/search_builders/hyrax/dashboard/collections_search_builder.rb +5 -3
  102. data/app/search_builders/hyrax/exposed_models_relation.rb +1 -1
  103. data/app/search_builders/hyrax/file_set_search_builder.rb +1 -1
  104. data/app/search_builders/hyrax/filter_by_type.rb +3 -2
  105. data/app/search_builders/hyrax/member_with_files_search_builder.rb +1 -1
  106. data/app/search_builders/hyrax/my/collections_search_builder.rb +2 -2
  107. data/app/search_builders/hyrax/my/find_works_search_builder.rb +8 -3
  108. data/app/services/hyrax/access_control_list.rb +21 -4
  109. data/app/services/hyrax/action/create_valkyrie_work.rb +80 -0
  110. data/app/services/hyrax/admin_set_create_service.rb +7 -3
  111. data/app/services/hyrax/admin_set_service.rb +2 -2
  112. data/app/services/hyrax/collections/collection_member_search_service.rb +2 -0
  113. data/app/services/hyrax/collections/permissions_service.rb +27 -9
  114. data/app/services/hyrax/custom_queries/find_collections_by_type.rb +1 -1
  115. data/app/services/hyrax/custom_queries/find_file_metadata.rb +1 -1
  116. data/app/services/hyrax/custom_queries/navigators/find_files.rb +1 -1
  117. data/app/services/hyrax/custom_queries/navigators/parent_work_navigator.rb +1 -1
  118. data/app/services/hyrax/edit_permissions_service.rb +1 -1
  119. data/app/services/hyrax/embargo_manager.rb +1 -1
  120. data/app/services/hyrax/file_set_file_service.rb +21 -10
  121. data/app/services/hyrax/form_factory.rb +1 -1
  122. data/app/services/hyrax/lease_manager.rb +39 -16
  123. data/app/services/hyrax/lease_service.rb +12 -6
  124. data/app/services/hyrax/listeners/acl_index_listener.rb +1 -1
  125. data/app/services/hyrax/listeners/active_fedora_acl_index_listener.rb +1 -1
  126. data/app/services/hyrax/listeners/member_cleanup_listener.rb +15 -1
  127. data/app/services/hyrax/listeners/object_lifecycle_listener.rb +5 -1
  128. data/app/services/hyrax/listeners/trophy_cleanup_listener.rb +2 -1
  129. data/app/services/hyrax/listeners/workflow_listener.rb +13 -0
  130. data/app/services/hyrax/listeners.rb +2 -1
  131. data/app/services/hyrax/location_service.rb +3 -0
  132. data/app/services/hyrax/multiple_membership_checker.rb +1 -1
  133. data/app/services/hyrax/simple_schema_loader.rb +1 -1
  134. data/app/services/hyrax/solr_service.rb +19 -5
  135. data/app/services/hyrax/statistics/collections/over_time.rb +1 -1
  136. data/app/services/hyrax/statistics/query_service.rb +6 -0
  137. data/app/services/hyrax/valkyrie_persist_derivatives.rb +11 -4
  138. data/app/services/hyrax/valkyrie_upload.rb +1 -1
  139. data/app/services/hyrax/work_uploads_handler.rb +5 -4
  140. data/app/views/_user_util_links.html.erb +1 -1
  141. data/app/views/collections/edit_fields/_based_near.html.erb +11 -7
  142. data/app/views/hyrax/admin/admin_sets/_form_participants.html.erb +67 -67
  143. data/app/views/hyrax/admin/admin_sets/edit.html.erb +1 -1
  144. data/app/views/hyrax/admin/collection_types/_form_participants.html.erb +3 -1
  145. data/app/views/hyrax/base/_attribute_rows.html.erb +1 -0
  146. data/app/views/hyrax/base/_base_form_files_prepend.html.erb +4 -0
  147. data/app/views/hyrax/base/_form_files.html.erb +65 -64
  148. data/app/views/hyrax/base/show.html.erb +2 -3
  149. data/app/views/hyrax/collections/show.html.erb +7 -9
  150. data/app/views/hyrax/dashboard/_sidebar.html.erb +4 -3
  151. data/app/views/hyrax/dashboard/collections/_form_share_table.html.erb +2 -2
  152. data/app/views/hyrax/file_sets/media_display/_audio.html.erb +1 -1
  153. data/app/views/hyrax/file_sets/media_display/_video.html.erb +1 -1
  154. data/app/views/hyrax/my/facet.html.erb +1 -1
  155. data/app/views/layouts/_head_tag_content.html.erb +1 -0
  156. data/app/views/shared/_footer.html.erb +1 -1
  157. data/chart/hyrax/Chart.yaml +3 -3
  158. data/chart/hyrax/values.yaml +9 -1
  159. data/config/initializers/listeners.rb +1 -1
  160. data/config/locales/hyrax.de.yml +5 -0
  161. data/config/locales/hyrax.en.yml +10 -0
  162. data/config/locales/hyrax.es.yml +5 -0
  163. data/config/locales/hyrax.fr.yml +5 -0
  164. data/config/locales/hyrax.it.yml +5 -0
  165. data/config/locales/hyrax.pt-BR.yml +5 -0
  166. data/config/locales/hyrax.zh.yml +5 -0
  167. data/config/metadata/basic_metadata.yaml +1 -0
  168. data/config/metadata/core_metadata.yaml +2 -0
  169. data/config/metadata/file_set_metadata.yaml +2 -0
  170. data/docker-compose-koppie.yml +3 -3
  171. data/docker-compose-sirenia.yml +3 -3
  172. data/documentation/developing-your-hyrax-based-app.md +77 -60
  173. data/hyrax.gemspec +9 -2
  174. data/lib/generators/hyrax/collection_resource/templates/collection_indexer.rb.erb +1 -1
  175. data/lib/generators/hyrax/config_generator.rb +12 -0
  176. data/lib/generators/hyrax/install_generator.rb +37 -7
  177. data/lib/generators/hyrax/listeners_generator.rb +18 -0
  178. data/lib/generators/hyrax/models_generator.rb +1 -10
  179. data/lib/generators/hyrax/riiif_generator.rb +6 -4
  180. data/lib/generators/hyrax/templates/.env +9 -0
  181. data/lib/generators/hyrax/templates/.lando.yml +50 -0
  182. data/lib/generators/hyrax/templates/app/listeners/hyrax_listener.rb +81 -0
  183. data/lib/generators/hyrax/templates/app/models/file_set.rb +1 -2
  184. data/lib/generators/hyrax/templates/config/initializers/1_valkyrie.rb +102 -0
  185. data/lib/generators/hyrax/templates/config/initializers/file_services.rb +6 -0
  186. data/lib/generators/hyrax/templates/config/initializers/hyrax.rb +41 -5
  187. data/lib/generators/hyrax/templates/config/initializers/publisher.rb +3 -0
  188. data/lib/generators/hyrax/templates/config/initializers/riiif.rb +77 -0
  189. data/lib/generators/hyrax/templates/config/locales/hyrax.de.yml +1 -1
  190. data/lib/generators/hyrax/templates/config/locales/hyrax.en.yml +1 -1
  191. data/lib/generators/hyrax/templates/config/locales/hyrax.es.yml +1 -1
  192. data/lib/generators/hyrax/templates/config/locales/hyrax.fr.yml +1 -1
  193. data/lib/generators/hyrax/templates/config/locales/hyrax.it.yml +1 -1
  194. data/lib/generators/hyrax/templates/config/locales/hyrax.pt-BR.yml +1 -1
  195. data/lib/generators/hyrax/templates/config/locales/hyrax.zh.yml +1 -1
  196. data/lib/generators/hyrax/templates/config/redis.yml +3 -6
  197. data/lib/generators/hyrax/templates/config/valkyrie_index.yml +4 -9
  198. data/lib/generators/hyrax/work_resource/templates/indexer.rb.erb +1 -1
  199. data/lib/hyrax/configuration.rb +95 -7
  200. data/lib/hyrax/indexer.rb +1 -1
  201. data/lib/hyrax/publisher.rb +5 -2
  202. data/lib/hyrax/resource_sync/change_list_writer.rb +1 -1
  203. data/lib/hyrax/resource_sync/resource_list_writer.rb +1 -1
  204. data/lib/hyrax/specs/capybara.rb +1 -0
  205. data/lib/hyrax/specs/shared_specs/hydra_works.rb +78 -20
  206. data/lib/hyrax/specs/shared_specs/indexers.rb +1 -1
  207. data/lib/hyrax/transactions/admin_set_destroy.rb +2 -1
  208. data/lib/hyrax/transactions/container.rb +5 -0
  209. data/lib/hyrax/transactions/steps/add_to_parent.rb +1 -0
  210. data/lib/hyrax/transactions/steps/check_for_default_admin_set.rb +32 -0
  211. data/lib/hyrax/transactions/steps/check_for_empty_admin_set.rb +1 -1
  212. data/lib/hyrax/transactions/steps/save.rb +2 -1
  213. data/lib/hyrax/transactions/steps/set_user_as_creator.rb +1 -1
  214. data/lib/hyrax/transactions/steps/update_work_members.rb +2 -0
  215. data/lib/hyrax/version.rb +1 -1
  216. data/lib/hyrax.rb +1 -0
  217. data/lib/tasks/embargo_lease.rake +1 -0
  218. data/lib/valkyrie/indexing/solr/indexing_adapter.rb +21 -7
  219. data/lib/wings/active_fedora_converter/default_work.rb +4 -5
  220. data/lib/wings/active_fedora_converter/file_metadata_node.rb +1 -1
  221. data/lib/wings/model_registry.rb +8 -0
  222. data/lib/wings/model_transformer.rb +19 -2
  223. data/lib/wings/orm_converter.rb +4 -0
  224. data/lib/wings/services/custom_queries/find_ids_by_model.rb +2 -2
  225. data/lib/wings/valkyrie/query_service.rb +5 -2
  226. data/lib/wings.rb +3 -0
  227. data/spec/factories/access_control.rb +12 -0
  228. data/spec/factories/admin_sets.rb +32 -0
  229. data/spec/factories/admin_sets_lw.rb +222 -0
  230. data/spec/factories/administrative_sets.rb +79 -0
  231. data/spec/factories/api_items.rb +92 -0
  232. data/spec/factories/collection_branding_infos.rb +12 -0
  233. data/spec/factories/collection_type_participants.rb +9 -0
  234. data/spec/factories/collection_types.rb +139 -0
  235. data/spec/factories/collections.rb +282 -0
  236. data/spec/factories/collections_factory.rb +107 -0
  237. data/spec/factories/content_blocks.rb +5 -0
  238. data/spec/factories/counter_metrics.rb +12 -0
  239. data/spec/factories/featured_works.rb +5 -0
  240. data/spec/factories/file_sets.rb +45 -0
  241. data/spec/factories/generic_works.rb +200 -0
  242. data/spec/factories/hyrax_collection.rb +92 -0
  243. data/spec/factories/hyrax_default_admin_set.rb +7 -0
  244. data/spec/factories/hyrax_embargo.rb +18 -0
  245. data/spec/factories/hyrax_file_metadata.rb +92 -0
  246. data/spec/factories/hyrax_file_set.rb +129 -0
  247. data/spec/factories/hyrax_lease.rb +18 -0
  248. data/spec/factories/hyrax_resource.rb +15 -0
  249. data/spec/factories/hyrax_work.rb +221 -0
  250. data/spec/factories/object_id.rb +7 -0
  251. data/spec/factories/operations.rb +22 -0
  252. data/spec/factories/permission.rb +7 -0
  253. data/spec/factories/permission_template_accesses.rb +17 -0
  254. data/spec/factories/permission_templates.rb +111 -0
  255. data/spec/factories/proxy_deposit_requests.rb +7 -0
  256. data/spec/factories/single_use_links.rb +14 -0
  257. data/spec/factories/sipity_entities.rb +17 -0
  258. data/spec/factories/uploaded_files.rb +11 -0
  259. data/spec/factories/users.rb +52 -0
  260. data/spec/factories/workflow_actions.rb +7 -0
  261. data/spec/factories/workflow_states.rb +7 -0
  262. data/spec/factories/workflows.rb +7 -0
  263. data/spec/support/book_resource.rb +36 -0
  264. data/spec/support/can_can_overrides.rb +43 -0
  265. data/spec/support/clean_solr.rb +7 -0
  266. data/spec/support/controller_level_helpers.rb +27 -0
  267. data/spec/support/factory_helpers.rb +94 -0
  268. data/spec/support/fakes/fake_actor.rb +22 -0
  269. data/spec/support/fakes/fake_authority.rb +14 -0
  270. data/spec/support/fakes/fake_search_builder_scope.rb +44 -0
  271. data/spec/support/fakes/indexing_adapter.rb +17 -0
  272. data/spec/support/fakes/test_hydra_group_service.rb +55 -0
  273. data/spec/support/features/batch_edit_actions.rb +37 -0
  274. data/spec/support/features/session_helpers.rb +15 -0
  275. data/spec/support/features/workflow.rb +10 -0
  276. data/spec/support/features.rb +11 -0
  277. data/spec/support/form_with_validations.rb +15 -0
  278. data/spec/support/input_support.rb +12 -0
  279. data/spec/support/logging_formatter.rb +67 -0
  280. data/spec/support/matchers/api_responses.rb +27 -0
  281. data/spec/support/matchers/collection_type_property_matchers.rb +30 -0
  282. data/spec/support/matchers/embargo.rb +9 -0
  283. data/spec/support/matchers/lease.rb +9 -0
  284. data/spec/support/matchers/match_valkyrie_ids_with_af_ids.rb +12 -0
  285. data/spec/support/matchers/pcdm_matchers.rb +34 -0
  286. data/spec/support/matchers/permission.rb +31 -0
  287. data/spec/support/matchers/response_matchers.rb +8 -0
  288. data/spec/support/optional_example.rb +17 -0
  289. data/spec/support/rake.rb +42 -0
  290. data/spec/support/selectors.rb +112 -0
  291. data/spec/support/shared_examples_for_collection_presenter.rb +44 -0
  292. data/spec/support/simple_work.rb +28 -0
  293. data/spec/support/spec_statistic.rb +24 -0
  294. data/spec/support/speedup.rb +7 -0
  295. data/spec/support/statistic_helper.rb +10 -0
  296. data/spec/support/valkyrie_indexing.rb +2 -0
  297. data/spec/support/wings_models.rb +9 -0
  298. data/template.rb +1 -3
  299. metadata +112 -30
  300. data/app/indexers/hyrax/resource_indexer.rb +0 -15
  301. data/app/models/concerns/hyrax/riiif_file.rb +0 -30
  302. data/app/services/hyrax/characterization/model_wrapper.rb +0 -0
  303. data/app/services/hyrax/custom_queries/find_by_collection_type.rb +0 -0
  304. data/app/services/hyrax/query_service.rb +0 -0
  305. data/app/services/hyrax/riiif_file_resolver.rb +0 -50
  306. data/lib/hyrax/specs/disable_animations_in_test_environment.rb +0 -53
  307. /data/app/indexers/{hyrax → concerns/hyrax}/thumbnail_indexer.rb +0 -0
@@ -33,6 +33,7 @@ module Hyrax
33
33
  loc
34
34
  end
35
35
  end
36
+ based_near << Hyrax::ControlledVocabularies::Location.new if based_near.empty?
36
37
  end
37
38
  end
38
39
  end
@@ -0,0 +1,24 @@
1
+ # frozen_string_literal: true
2
+ module Hyrax
3
+ ##
4
+ # A module of form behaviours for resources which can be contained in works.
5
+ module ContainedInWorksBehavior
6
+ ##
7
+ # @api private
8
+ InWorksPrepopulator = proc do |_options|
9
+ self.in_works_ids =
10
+ if persisted?
11
+ Hyrax.query_service
12
+ .find_inverse_references_by(resource: model, property: :member_ids)
13
+ .select(&:work?)
14
+ .map(&:id)
15
+ else
16
+ []
17
+ end
18
+ end
19
+
20
+ def self.included(descendant)
21
+ descendant.property :in_works_ids, virtual: true, prepopulator: InWorksPrepopulator
22
+ end
23
+ end
24
+ end
@@ -0,0 +1,12 @@
1
+ # frozen_string_literal: true
2
+ module Hyrax
3
+ ##
4
+ # A module of form behaviours for depositors and depositor agreements.
5
+ module DepositAgreementBehavior
6
+ def self.included(descendant)
7
+ descendant.property :depositor
8
+
9
+ descendant.property :agreement_accepted, virtual: true, default: false, prepopulator: proc { |_opts| self.agreement_accepted = !model.new_record }
10
+ end
11
+ end
12
+ end
@@ -0,0 +1,49 @@
1
+ # frozen_string_literal: true
2
+ module Hyrax
3
+ ##
4
+ # A module of form behaviours for embargoes, leases, and resulting
5
+ # visibilities.
6
+ module LeaseabilityBehavior
7
+ def self.included(descendant) # rubocop:disable Metrics/AbcSize
8
+ descendant.property :visibility, default: VisibilityIntention::PRIVATE, populator: :visibility_populator
9
+
10
+ descendant.property :embargo, form: Hyrax::Forms::Embargo, populator: :embargo_populator
11
+ descendant.property :lease, form: Hyrax::Forms::Lease, populator: :lease_populator
12
+
13
+ # virtual properties for embargo/lease;
14
+ descendant.property :embargo_release_date, virtual: true, prepopulator: proc { |_opts| self.embargo_release_date = model.embargo&.embargo_release_date }
15
+ descendant.property :visibility_after_embargo, virtual: true, prepopulator: proc { |_opts| self.visibility_after_embargo = model.embargo&.visibility_after_embargo }
16
+ descendant.property :visibility_during_embargo, virtual: true, prepopulator: proc { |_opts| self.visibility_during_embargo = model.embargo&.visibility_during_embargo }
17
+
18
+ descendant.property :lease_expiration_date, virtual: true, prepopulator: proc { |_opts| self.lease_expiration_date = model.lease&.lease_expiration_date }
19
+ descendant.property :visibility_after_lease, virtual: true, prepopulator: proc { |_opts| self.visibility_after_lease = model.lease&.visibility_after_lease }
20
+ descendant.property :visibility_during_lease, virtual: true, prepopulator: proc { |_opts| self.visibility_during_lease = model.lease&.visibility_during_lease }
21
+ end
22
+
23
+ def embargo_populator(**)
24
+ self.embargo = Hyrax::EmbargoManager.embargo_for(resource: model)
25
+ end
26
+
27
+ def lease_populator(**)
28
+ self.lease = Hyrax::LeaseManager.lease_for(resource: model)
29
+ end
30
+
31
+ def visibility_populator(fragment:, doc:, **)
32
+ case fragment
33
+ when "embargo"
34
+ self.visibility = doc['visibility_during_embargo']
35
+
36
+ doc['embargo'] = doc.slice('visibility_after_embargo',
37
+ 'visibility_during_embargo',
38
+ 'embargo_release_date')
39
+ when "lease"
40
+ self.visibility = doc['visibility_during_lease']
41
+ doc['lease'] = doc.slice('visibility_after_lease',
42
+ 'visibility_during_lease',
43
+ 'lease_expiration_date')
44
+ else
45
+ self.visibility = fragment
46
+ end
47
+ end
48
+ end
49
+ end
@@ -0,0 +1,20 @@
1
+ # frozen_string_literal: true
2
+ module Hyrax
3
+ ##
4
+ # A module of form behaviours for populating permissions.
5
+ module PermissionBehavior
6
+ def self.included(descendant)
7
+ descendant.collection(:permissions,
8
+ virtual: true,
9
+ default: [],
10
+ form: Hyrax::Forms::Permission,
11
+ populator: :permission_populator,
12
+ prepopulator: proc { |_opts| self.permissions = Hyrax::AccessControl.for(resource: model).permissions })
13
+ end
14
+
15
+ # https://trailblazer.to/2.1/docs/reform.html#reform-populators-populator-collections
16
+ def permission_populator(collection:, index:, **)
17
+ Hyrax::Forms::Permission.new(collection[index])
18
+ end
19
+ end
20
+ end
@@ -5,7 +5,7 @@ module Hyrax
5
5
  ##
6
6
  # @api public
7
7
  # @see https://github.com/samvera/valkyrie/wiki/ChangeSets-and-Dirty-Tracking
8
- class AdministrativeSetForm < Valkyrie::ChangeSet
8
+ class AdministrativeSetForm < Hyrax::Forms::ResourceForm
9
9
  ##
10
10
  # @api private
11
11
  AdminSetMembersPopulator = lambda do |**_options|
@@ -23,10 +23,6 @@ module Hyrax
23
23
  property :title, required: true, primary: true
24
24
  property :description, primary: true
25
25
 
26
- property :human_readable_type, writable: false
27
- property :date_modified, readable: false
28
- property :date_uploaded, readable: false
29
-
30
26
  property :creator
31
27
 
32
28
  validates :title, presence: true
@@ -35,6 +35,12 @@ module Hyrax
35
35
  end
36
36
  end
37
37
 
38
+ # This describes the parameters we are expecting to receive from the client
39
+ # @return [Array] a list of parameters used by sanitize_params
40
+ def self.build_permitted_params
41
+ super + [{ based_near_attributes: [:id, :_destroy] }]
42
+ end
43
+
38
44
  # @param model [::Collection] the collection model that backs this form
39
45
  # @param current_ability [Ability] the capabilities of the current user
40
46
  # @param repository [Blacklight::Solr::Repository] the solr repository
@@ -123,6 +129,19 @@ module Hyrax
123
129
  collection_member_service.available_member_subcollections.documents
124
130
  end
125
131
 
132
+ protected
133
+
134
+ def initialize_field(key)
135
+ # rubocop:disable Lint/AssignmentInCondition
136
+ if class_name = model_class.properties[key.to_s].try(:class_name)
137
+ # Initialize linked properties such as based_near
138
+ self[key] += [class_name.new]
139
+ else
140
+ super
141
+ end
142
+ # rubocop:enable Lint/AssignmentInCondition
143
+ end
144
+
126
145
  private
127
146
 
128
147
  def all_files_with_access
@@ -12,6 +12,11 @@ module Hyrax
12
12
  # be configurable.
13
13
  include Hyrax::FormFields(:file_set_metadata)
14
14
 
15
+ include Hyrax::DepositAgreementBehavior
16
+ include Hyrax::ContainedInWorksBehavior
17
+ include Hyrax::LeaseabilityBehavior
18
+ include Hyrax::PermissionBehavior
19
+
15
20
  property :representative_id, type: Valkyrie::Types::String, writeable: false
16
21
  property :thumbnail_id, type: Valkyrie::Types::String, writeable: false
17
22
  end
@@ -5,7 +5,7 @@ module Hyrax
5
5
  ##
6
6
  # @api public
7
7
  # @see https://github.com/samvera/valkyrie/wiki/ChangeSets-and-Dirty-Tracking
8
- class PcdmCollectionForm < Valkyrie::ChangeSet # rubocop:disable Metrics/ClassLength
8
+ class PcdmCollectionForm < Hyrax::Forms::ResourceForm # rubocop:disable Metrics/ClassLength
9
9
  include Hyrax::FormFields(:core_metadata)
10
10
 
11
11
  BannerInfoPrepopulator = lambda do |**_options|
@@ -33,10 +33,6 @@ module Hyrax
33
33
  end
34
34
  end
35
35
 
36
- property :human_readable_type, writable: false
37
- property :date_modified, readable: false
38
- property :date_uploaded, readable: false
39
-
40
36
  property :depositor, required: true
41
37
  property :collection_type_gid, required: true
42
38
  property :visibility, default: VisibilityIntention::PRIVATE
@@ -2,38 +2,25 @@
2
2
 
3
3
  module Hyrax
4
4
  module Forms
5
- ##
6
- # @api public
7
- #
8
- # @example defining a form class using HydraEditor-like configuration
9
- # class MonographForm < Hyrax::Forms::PcdmObjectForm(Monograph)
10
- # self.required_fields = [:title, :creator, :rights_statement]
11
- # # other WorkForm-like configuration here
12
- # end
13
- def self.PcdmObjectForm(work_class)
14
- Class.new(Hyrax::Forms::PcdmObjectForm) do
15
- self.model_class = work_class
16
-
17
- ##
18
- # @return [String]
19
- def self.inspect
20
- return "Hyrax::Forms::PcdmObjectForm(#{model_class})" if name.blank?
21
- super
22
- end
23
- end
24
- end
25
-
26
5
  ##
27
6
  # A form for PCDM objects: resources which have collection relationships and
28
7
  # generally resemble +Hyrax::Work+.
8
+ #
9
+ # Although File Sets are technically also PCDM objects, they use a separate
10
+ # form class: +Hyrax::Forms::FileSetForm+.
29
11
  class PcdmObjectForm < Hyrax::Forms::ResourceForm
30
12
  include Hyrax::FormFields(:core_metadata)
31
13
 
14
+ include Hyrax::ContainedInWorksBehavior
15
+ include Hyrax::DepositAgreementBehavior
16
+ include Hyrax::LeaseabilityBehavior
17
+ include Hyrax::PermissionBehavior
18
+
32
19
  property :on_behalf_of
33
20
  property :proxy_depositor
34
21
 
35
22
  # pcdm relationships
36
- property :admin_set_id, prepopulator: proc { |_opts| self.admin_set_id = Hyrax::AdminSetCreateService.find_or_create_default_admin_set.id.to_s }
23
+ property :admin_set_id, prepopulator: :admin_set_prepopulator
37
24
  property :member_ids, default: [], type: Valkyrie::Types::Array
38
25
  property :member_of_collection_ids, default: [], type: Valkyrie::Types::Array
39
26
  property :member_of_collections_attributes, virtual: true, populator: :in_collections_populator
@@ -49,6 +36,10 @@ module Hyrax
49
36
 
50
37
  private
51
38
 
39
+ def admin_set_prepopulator
40
+ self.admin_set_id ||= Hyrax::AdminSetCreateService.find_or_create_default_admin_set.id.to_s
41
+ end
42
+
52
43
  def in_collections_populator(fragment:, **_options)
53
44
  adds = []
54
45
  deletes = []
@@ -4,6 +4,11 @@ module Hyrax
4
4
  class ResourceBatchEditForm < Hyrax::Forms::ResourceForm
5
5
  include Hyrax::FormFields(:basic_metadata)
6
6
 
7
+ include Hyrax::ContainedInWorksBehavior
8
+ include Hyrax::DepositAgreementBehavior
9
+ include Hyrax::LeaseabilityBehavior
10
+ include Hyrax::PermissionBehavior
11
+
7
12
  self.required_fields = []
8
13
  self.model_class = Hyrax.primary_work_type
9
14
 
@@ -22,9 +27,9 @@ module Hyrax
22
27
  @batch_document_ids = batch_document_ids
23
28
  if @batch_document_ids.present?
24
29
  combined_fields = model_attributes(model, initialize_combined_fields)
25
- super(model.class.new(combined_fields))
30
+ super(resource: model.class.new(combined_fields))
26
31
  else
27
- super(model)
32
+ super(resource: model)
28
33
  end
29
34
  end
30
35
 
@@ -2,50 +2,11 @@
2
2
 
3
3
  module Hyrax
4
4
  module Forms
5
- ##
6
- # @api public
7
- #
8
- # Returns the form class associated with a given model.
9
- #
10
- # @note The default case assumes that the provided model class is for a
11
- # PCDM object and returns a +Hyrax::Forms::PcdmObjectForm+. This is for
12
- # backwards‐compatibility with existing Hyrax instances. However, a
13
- # different +Hyrax::Forms::ResourceForm+ subclass will be returned in
14
- # some known cases where that is preferable.
15
- def self.ResourceForm(model_class)
16
- @resource_forms ||= {}.compare_by_identity
17
- @resource_forms[model_class] ||=
18
- if model_class <= Hyrax::AdministrativeSet
19
- Hyrax::Forms::AdministrativeSetForm
20
- elsif model_class <= Hyrax::FileSet
21
- Hyrax::Forms::FileSetForm
22
- elsif model_class <= Hyrax::PcdmCollection
23
- Hyrax::Forms::PcdmCollectionForm
24
- else
25
- "Hyrax::Forms::PcdmObjectForm".constantize # autoload
26
- Hyrax::Forms::PcdmObjectForm(model_class)
27
- end
28
- end
29
-
30
5
  ##
31
6
  # @api public
32
7
  #
33
8
  # This form wraps +Hyrax::ChangeSet+ in the +HydraEditor::Form+ interface.
34
9
  class ResourceForm < Hyrax::ChangeSet # rubocop:disable Metrics/ClassLength
35
- ##
36
- # @api private
37
- InWorksPrepopulator = proc do |_options|
38
- self.in_works_ids =
39
- if persisted?
40
- Hyrax.query_service
41
- .find_inverse_references_by(resource: model, property: :member_ids)
42
- .select(&:work?)
43
- .map(&:id)
44
- else
45
- []
46
- end
47
- end
48
-
49
10
  ##
50
11
  # @api private
51
12
  #
@@ -68,35 +29,8 @@ module Hyrax
68
29
  class_attribute :model_class
69
30
 
70
31
  property :human_readable_type, writable: false
71
-
72
- property :depositor
73
-
74
- property :visibility, default: VisibilityIntention::PRIVATE, populator: :visibility_populator
75
-
76
32
  property :date_modified, readable: false
77
33
  property :date_uploaded, readable: false
78
- property :agreement_accepted, virtual: true, default: false, prepopulator: proc { |_opts| self.agreement_accepted = !model.new_record }
79
-
80
- collection(:permissions,
81
- virtual: true,
82
- default: [],
83
- form: Hyrax::Forms::Permission,
84
- populator: :permission_populator,
85
- prepopulator: proc { |_opts| self.permissions = Hyrax::AccessControl.for(resource: model).permissions })
86
-
87
- property :embargo, form: Hyrax::Forms::Embargo, populator: :embargo_populator
88
- property :lease, form: Hyrax::Forms::Lease, populator: :lease_populator
89
-
90
- # virtual properties for embargo/lease;
91
- property :embargo_release_date, virtual: true, prepopulator: proc { |_opts| self.embargo_release_date = model.embargo&.embargo_release_date }
92
- property :visibility_after_embargo, virtual: true, prepopulator: proc { |_opts| self.visibility_after_embargo = model.embargo&.visibility_after_embargo }
93
- property :visibility_during_embargo, virtual: true, prepopulator: proc { |_opts| self.visibility_during_embargo = model.embargo&.visibility_during_embargo }
94
-
95
- property :lease_expiration_date, virtual: true, prepopulator: proc { |_opts| self.lease_expiration_date = model.lease&.lease_expiration_date }
96
- property :visibility_after_lease, virtual: true, prepopulator: proc { |_opts| self.visibility_after_lease = model.lease&.visibility_after_lease }
97
- property :visibility_during_lease, virtual: true, prepopulator: proc { |_opts| self.visibility_during_lease = model.lease&.visibility_during_lease }
98
-
99
- property :in_works_ids, virtual: true, prepopulator: InWorksPrepopulator
100
34
 
101
35
  # provide a lock token for optimistic locking; we name this `version` for
102
36
  # backwards compatibility
@@ -108,6 +42,24 @@ module Hyrax
108
42
  # @see https://github.com/samvera/valkyrie/wiki/Optimistic-Locking
109
43
  property :version, virtual: true, prepopulator: LockKeyPrepopulator
110
44
 
45
+ ##
46
+ # @api public
47
+ #
48
+ # Forms should be initialized with an explicit +resource:+ parameter to
49
+ # match indexers.
50
+ def initialize(deprecated_resource = nil, resource: nil)
51
+ if resource.nil?
52
+ if !deprecated_resource.nil?
53
+ Deprecation.warn "Initializing Valkyrie forms without an explicit resource parameter is deprecated. Pass the resource with `resource:` instead."
54
+ super(deprecated_resource)
55
+ else
56
+ super()
57
+ end
58
+ else
59
+ super(resource)
60
+ end
61
+ end
62
+
111
63
  class << self
112
64
  ##
113
65
  # @api public
@@ -116,11 +68,20 @@ module Hyrax
116
68
  #
117
69
  # @example
118
70
  # monograph = Monograph.new
119
- # change_set = Hyrax::Forms::ResourceForm.for(monograph)
120
- def for(resource)
71
+ # change_set = Hyrax::Forms::ResourceForm.for(resource: monograph)
72
+ def for(deprecated_resource = nil, resource: nil)
73
+ if resource.nil? && !deprecated_resource.nil?
74
+ Deprecation.warn "Initializing Valkyrie forms without an explicit resource parameter is deprecated. Pass the resource with `resource:` instead."
75
+ return self.for(resource: deprecated_resource)
76
+ end
121
77
  klass = "#{resource.class.name}Form".safe_constantize
122
78
  klass ||= Hyrax::Forms::ResourceForm(resource.class)
123
- klass.new(resource)
79
+ begin
80
+ klass.new(resource: resource)
81
+ rescue ArgumentError
82
+ Deprecation.warn "Initializing Valkyrie forms without an explicit resource parameter is deprecated. #{klass} should be updated accordingly."
83
+ klass.new(resource)
84
+ end
124
85
  end
125
86
 
126
87
  ##
@@ -187,37 +148,6 @@ module Hyrax
187
148
 
188
149
  private
189
150
 
190
- def embargo_populator(**)
191
- self.embargo = Hyrax::EmbargoManager.embargo_for(resource: model)
192
- end
193
-
194
- def lease_populator(**)
195
- self.lease = Hyrax::LeaseManager.lease_for(resource: model)
196
- end
197
-
198
- # https://trailblazer.to/2.1/docs/reform.html#reform-populators-populator-collections
199
- def permission_populator(collection:, index:, **)
200
- Hyrax::Forms::Permission.new(collection[index])
201
- end
202
-
203
- def visibility_populator(fragment:, doc:, **)
204
- case fragment
205
- when "embargo"
206
- self.visibility = doc['visibility_during_embargo']
207
-
208
- doc['embargo'] = doc.slice('visibility_after_embargo',
209
- 'visibility_during_embargo',
210
- 'embargo_release_date')
211
- when "lease"
212
- self.visibility = doc['visibility_during_lease']
213
- doc['lease'] = doc.slice('visibility_after_lease',
214
- 'visibility_during_lease',
215
- 'lease_expiration_date')
216
- else
217
- self.visibility = fragment
218
- end
219
- end
220
-
221
151
  def _form_field_definitions
222
152
  self.class.definitions
223
153
  end
@@ -0,0 +1,52 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Hyrax
4
+ module Forms
5
+ ##
6
+ # @api public
7
+ #
8
+ # @example defining a form class using HydraEditor-like configuration
9
+ # class MonographForm < Hyrax::Forms::PcdmObjectForm(Monograph)
10
+ # self.required_fields = [:title, :creator, :rights_statement]
11
+ # # other WorkForm-like configuration here
12
+ # end
13
+ def self.PcdmObjectForm(work_class) # rubocop:disable Naming/MethodName
14
+ Class.new(Hyrax::Forms::PcdmObjectForm) do
15
+ self.model_class = work_class
16
+
17
+ ##
18
+ # @return [String]
19
+ def self.inspect
20
+ return "Hyrax::Forms::PcdmObjectForm(#{model_class})" if name.blank?
21
+ super
22
+ end
23
+ end
24
+ end
25
+
26
+ ##
27
+ # @api public
28
+ #
29
+ # Returns the form class associated with a given model.
30
+ def self.ResourceForm(model_class) # rubocop:disable Metrics/MethodLength, Metrics/PerceivedComplexity, Naming/MethodName
31
+ @resource_forms ||= {}.compare_by_identity
32
+ @resource_forms[model_class] ||=
33
+ # +#respond_to?+ needs to be used here, not +#try+, because Dry::Types
34
+ # overrides the latter??
35
+ if model_class.respond_to?(:pcdm_collection?) && model_class.pcdm_collection?
36
+ if model_class <= Hyrax::AdministrativeSet
37
+ Hyrax.config.administrative_set_form
38
+ else
39
+ Hyrax.config.pcdm_collection_form
40
+ end
41
+ elsif model_class.respond_to?(:pcdm_object?) && model_class.pcdm_object?
42
+ if model_class.respond_to?(:file_set?) && model_class.file_set?
43
+ Hyrax.config.file_set_form
44
+ else
45
+ Hyrax.config.pcdm_object_form_builder.call(model_class)
46
+ end
47
+ else
48
+ Hyrax::Forms::ResourceForm
49
+ end
50
+ end
51
+ end
52
+ end
@@ -294,6 +294,8 @@ module Hyrax
294
294
  solr_field = solr_docs.first["title_tesim"]
295
295
  return nil if solr_field.nil?
296
296
  solr_field.first
297
+ rescue Blacklight::Exceptions::RecordNotFound
298
+ nil
297
299
  end
298
300
 
299
301
  ##
@@ -14,11 +14,7 @@ module Hyrax
14
14
 
15
15
  def based_near_label_lookup(locations)
16
16
  locations.map do |loc|
17
- if URI.parse(loc)
18
- location_service.full_label(loc)
19
- else
20
- loc
21
- end
17
+ location_service.full_label(loc)
22
18
  end
23
19
  end
24
20
 
@@ -6,14 +6,14 @@ module Hyrax
6
6
  # permissions being up-to-date in the index to support `Hyrax::Ability`.
7
7
  #
8
8
  # @example
9
- # class MyIndexer < Hyrax::ValkyrieIndexer
9
+ # class MyIndexer < Hyrax::Indexers::ResourceIndexer
10
10
  # include Hyrax::PermissionIndexer
11
11
  # end
12
12
  module PermissionIndexer
13
13
  def to_solr
14
14
  super.tap do |index_document|
15
15
  config = Hydra.config.permissions
16
- permissions = Hyrax::PermissionManager.new(resource: resource)
16
+ permissions = resource.permission_manager || Hyrax::PermissionManager.new(resource: resource)
17
17
 
18
18
  index_document[config.edit.group] = permissions.edit_groups.to_a
19
19
  index_document[config.edit.individual] = permissions.edit_users.to_a
@@ -7,7 +7,7 @@ module Hyrax
7
7
  # views.
8
8
  #
9
9
  # @example
10
- # class MyIndexer < Hyrax::ValkyrieIndexer
10
+ # class MyIndexer < Hyrax::Indexers::ResourceIndexer
11
11
  # include Hyrax::VisibilityIndexer
12
12
  # end
13
13
  module VisibilityIndexer
@@ -2,23 +2,11 @@
2
2
 
3
3
  module Hyrax
4
4
  ##
5
- # Indexes Hyrax::AdministrativeSet objects
6
- class AdministrativeSetIndexer < Hyrax::ValkyrieIndexer
7
- include Hyrax::ResourceIndexer
8
- include Hyrax::PermissionIndexer
9
- include Hyrax::VisibilityIndexer
10
- include Hyrax::Indexer(:core_metadata)
11
-
12
- def to_solr # rubocop:disable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/MethodLength
13
- super.tap do |solr_doc|
14
- solr_doc[Hyrax.config.collection_type_index_field.to_sym] = Array(resource.try(:collection_type_gid)&.to_s)
15
- solr_doc[:alternative_title_tesim] = resource.alternative_title
16
- solr_doc[:creator_ssim] = [resource.creator]
17
- solr_doc[:creator_tesim] = [resource.creator]
18
- solr_doc[:description_tesim] = resource.description
19
- solr_doc[:generic_type_sim] = ['Admin Set']
20
- solr_doc[:thumbnail_path_ss] = Hyrax::CollectionThumbnailPathService.call(resource)
21
- end
5
+ # @deprecated use +Hyrax::Indexers::AdministrativeSetIndexer+ instead
6
+ class AdministrativeSetIndexer < Hyrax::Indexers::AdministrativeSetIndexer
7
+ def initialize(*args, **kwargs)
8
+ Deprecation.warn "`Hyrax::AdministrativeSetIndexer` is deprecated. Use `Hyrax::Indexers::AdministrativeSetIndexer` instead."
9
+ super
22
10
  end
23
11
  end
24
12
  end
@@ -0,0 +1,25 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Hyrax
4
+ module Indexers
5
+ ##
6
+ # Indexes Hyrax::AdministrativeSet objects
7
+ class AdministrativeSetIndexer < Hyrax::Indexers::ResourceIndexer
8
+ include Hyrax::PermissionIndexer
9
+ include Hyrax::VisibilityIndexer
10
+ include Hyrax::Indexer(:core_metadata)
11
+
12
+ def to_solr # rubocop:disable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/MethodLength
13
+ super.tap do |solr_doc|
14
+ solr_doc[Hyrax.config.collection_type_index_field.to_sym] = Array(resource.try(:collection_type_gid)&.to_s)
15
+ solr_doc[:alternative_title_tesim] = resource.alternative_title
16
+ solr_doc[:creator_ssim] = [resource.creator]
17
+ solr_doc[:creator_tesim] = [resource.creator]
18
+ solr_doc[:description_tesim] = resource.description
19
+ solr_doc[:generic_type_sim] = ['Admin Set']
20
+ solr_doc[:thumbnail_path_ss] = Hyrax::CollectionThumbnailPathService.call(resource)
21
+ end
22
+ end
23
+ end
24
+ end
25
+ end