sufia 7.2.0 → 7.3.0.rc1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (259) hide show
  1. checksums.yaml +4 -4
  2. data/.codeclimate.yml +2 -0
  3. data/.rubocop.yml +3 -0
  4. data/.rubocop_todo.yml +1 -2
  5. data/.travis.yml +0 -1
  6. data/Gemfile +2 -1
  7. data/README.md +23 -106
  8. data/app/actors/sufia/apply_permission_template_actor.rb +19 -0
  9. data/app/actors/sufia/create_with_remote_files_actor.rb +2 -2
  10. data/app/actors/sufia/default_admin_set_actor.rb +42 -0
  11. data/app/actors/sufia/interpret_visibility_actor.rb +115 -0
  12. data/app/assets/images/collection.png +0 -0
  13. data/app/assets/javascripts/sufia.js +6 -0
  14. data/app/assets/javascripts/sufia/admin/admin_set/participants.es6 +9 -0
  15. data/app/assets/javascripts/sufia/admin/admin_set/visibility.es6 +134 -0
  16. data/app/assets/javascripts/sufia/admin/admin_set_controls.es6 +11 -0
  17. data/app/assets/javascripts/sufia/app.js +27 -5
  18. data/app/assets/javascripts/sufia/autocomplete.es6 +15 -0
  19. data/app/assets/javascripts/sufia/autocomplete/work.es6 +29 -0
  20. data/app/assets/javascripts/sufia/dashboard_actions.js +2 -4
  21. data/app/assets/javascripts/sufia/save_work/save_work_control.es6 +14 -2
  22. data/app/assets/javascripts/sufia/save_work/uploaded_files.es6 +7 -2
  23. data/app/assets/javascripts/sufia/save_work/visibility_component.es6 +245 -4
  24. data/app/assets/javascripts/sufia/select_work_type.es6 +38 -0
  25. data/app/assets/javascripts/sufia/workflow_actions_affix.js +14 -0
  26. data/app/assets/stylesheets/sufia/_dashboard.scss +50 -29
  27. data/app/assets/stylesheets/sufia/_footer.scss +30 -0
  28. data/app/assets/stylesheets/sufia/_header.scss +3 -4
  29. data/app/assets/stylesheets/sufia/_home-page.scss +10 -8
  30. data/app/assets/stylesheets/sufia/_select_work_type.scss +43 -0
  31. data/app/assets/stylesheets/sufia/_sufia.scss +4 -1
  32. data/app/assets/stylesheets/sufia/_variables.scss +3 -0
  33. data/app/assets/stylesheets/sufia/admin.scss +66 -169
  34. data/app/assets/stylesheets/sufia/blacklight_gallery.scss +17 -0
  35. data/app/authorities/qa/authorities/find_works.rb +15 -0
  36. data/app/controllers/concerns/sufia/batch_edits_controller_behavior.rb +2 -1
  37. data/app/controllers/concerns/sufia/batch_uploads_controller_behavior.rb +26 -13
  38. data/app/controllers/concerns/sufia/collections_controller_behavior.rb +25 -0
  39. data/app/controllers/concerns/sufia/controller.rb +8 -0
  40. data/app/controllers/concerns/sufia/deny_access_override_behavior.rb +1 -1
  41. data/app/controllers/concerns/sufia/file_sets_controller_behavior.rb +5 -14
  42. data/app/controllers/concerns/sufia/homepage_controller_behavior.rb +2 -0
  43. data/app/controllers/concerns/sufia/users_controller_behavior.rb +18 -7
  44. data/app/controllers/concerns/sufia/works_controller_behavior.rb +13 -10
  45. data/app/controllers/my/collections_controller.rb +5 -0
  46. data/app/controllers/my/shares_controller.rb +5 -0
  47. data/app/controllers/my/works_controller.rb +5 -0
  48. data/app/controllers/stats_controller.rb +1 -1
  49. data/app/controllers/sufia/admin/admin_sets_controller.rb +20 -2
  50. data/app/controllers/sufia/admin/permission_template_accesses_controller.rb +15 -0
  51. data/app/controllers/sufia/admin/permission_templates_controller.rb +29 -0
  52. data/app/controllers/sufia/admin_controller.rb +2 -0
  53. data/app/controllers/sufia/trophies_controller.rb +0 -2
  54. data/app/forms/sufia/forms/admin_set_form.rb +19 -0
  55. data/app/forms/sufia/forms/batch_edit_form.rb +16 -6
  56. data/app/forms/sufia/forms/batch_upload_form.rb +3 -2
  57. data/app/forms/sufia/forms/permission_template_form.rb +115 -0
  58. data/app/forms/sufia/forms/work_form.rb +6 -0
  59. data/app/helpers/batch_edits_helper.rb +1 -1
  60. data/app/helpers/sufia/citations_behavior.rb +0 -5
  61. data/app/helpers/sufia/citations_behaviors/formatters.rb +0 -1
  62. data/app/helpers/sufia/sufia_helper_behavior.rb +38 -6
  63. data/app/indexers/sufia/collection_indexer.rb +6 -0
  64. data/app/jobs/batch_create_job.rb +7 -15
  65. data/app/models/batch_upload_item.rb +2 -0
  66. data/app/models/concerns/sufia/ability.rb +12 -1
  67. data/app/models/sufia/permission_template.rb +102 -0
  68. data/app/models/sufia/permission_template_access.rb +18 -0
  69. data/app/presenters/sufia/admin_set_presenter.rb +1 -1
  70. data/app/presenters/sufia/model_icon.rb +7 -0
  71. data/app/presenters/sufia/select_type_list_presenter.rb +37 -0
  72. data/app/presenters/sufia/select_type_presenter.rb +35 -0
  73. data/app/presenters/sufia/work_show_presenter.rb +0 -2
  74. data/app/search_builders/collection_search_builder.rb +0 -2
  75. data/app/search_builders/sufia/admin_set_search_builder.rb +24 -0
  76. data/app/search_builders/sufia/catalog_search_builder.rb +10 -4
  77. data/app/search_builders/sufia/find_works_search_builder.rb +44 -0
  78. data/app/search_builders/sufia/my_search_builder_behavior.rb +0 -4
  79. data/app/search_builders/sufia/my_works_search_builder.rb +1 -1
  80. data/app/services/sufia/actor_factory.rb +6 -2
  81. data/app/services/sufia/admin_set_create_service.rb +22 -0
  82. data/app/services/sufia/admin_set_service.rb +46 -16
  83. data/app/services/sufia/collection_thumbnail_path_service.rb +10 -0
  84. data/app/services/sufia/workflow/abstract_notification.rb +39 -0
  85. data/app/services/sufia/workflow/changes_required_notification.rb +22 -0
  86. data/app/services/sufia/workflow/complete_notification.rb +22 -0
  87. data/app/services/sufia/workflow/pending_review_notification.rb +21 -0
  88. data/app/services/sufia/workflow/workflow_by_admin_set_strategy.rb +15 -0
  89. data/app/views/_masthead.html.erb +4 -4
  90. data/app/views/_toolbar.html.erb +31 -9
  91. data/app/views/_user_util_links.html.erb +7 -7
  92. data/app/views/batch_edits/edit.html.erb +24 -12
  93. data/app/views/catalog/_thumbnail_list_collection.html.erb +1 -1
  94. data/app/views/collections/_form.html.erb +2 -2
  95. data/app/views/collections/_media_display.html.erb +1 -1
  96. data/app/views/curation_concerns/base/_find_work_widget.html.erb +16 -0
  97. data/app/views/curation_concerns/base/_form.html.erb +6 -0
  98. data/app/views/curation_concerns/base/_form_child_work_relationships.html.erb +1 -1
  99. data/app/views/curation_concerns/base/_form_metadata.html.erb +1 -1
  100. data/app/views/curation_concerns/base/_form_parent_work_relationships.html.erb +43 -0
  101. data/app/views/curation_concerns/base/_form_progress.html.erb +7 -4
  102. data/app/views/curation_concerns/base/_form_relationships.html.erb +6 -6
  103. data/app/views/curation_concerns/base/_form_share.html.erb +1 -2
  104. data/app/views/curation_concerns/base/_guts4form.html.erb +1 -1
  105. data/app/views/curation_concerns/base/_social_media.html.erb +1 -1
  106. data/app/views/curation_concerns/base/_workflow_actions_widget.erb +3 -0
  107. data/app/views/curation_concerns/base/edit.html.erb +1 -1
  108. data/app/views/curation_concerns/base/new.html.erb +1 -1
  109. data/app/views/curation_concerns/base/show.html.erb +4 -1
  110. data/app/views/curation_concerns/file_sets/_show_actions.html.erb +0 -3
  111. data/app/views/dashboard/_create_work_action.html.erb +20 -0
  112. data/app/views/dashboard/_index_partials/_heading_actions.html.erb +9 -22
  113. data/app/views/layouts/admin.html.erb +8 -68
  114. data/app/views/layouts/curation_concerns/1_column.html.erb +4 -31
  115. data/app/views/layouts/homepage.html.erb +15 -45
  116. data/app/views/layouts/sufia-dashboard.html.erb +1 -36
  117. data/app/views/layouts/sufia.html.erb +49 -0
  118. data/app/views/my/_document_list.html.erb +1 -1
  119. data/app/views/my/_facet_limit.html.erb +2 -2
  120. data/app/views/my/_index_partials/_default_group.html.erb +10 -10
  121. data/app/views/my/_index_partials/_list_collections.html.erb +1 -1
  122. data/app/views/my/_sort_and_per_page.html.erb +8 -8
  123. data/app/views/records/edit_fields/_rights.html.erb +0 -1
  124. data/app/views/shared/_footer.html.erb +1 -1
  125. data/app/views/shared/_select_work_type_modal.html.erb +34 -0
  126. data/app/views/sufia/admin/_collections.html.erb +31 -0
  127. data/app/views/sufia/admin/_sidebar.html.erb +35 -23
  128. data/app/views/sufia/admin/admin_sets/_form.html.erb +38 -15
  129. data/app/views/sufia/admin/admin_sets/_form_metadata.html.erb +2 -0
  130. data/app/views/sufia/admin/admin_sets/_form_participant_table.html.erb +21 -0
  131. data/app/views/sufia/admin/admin_sets/_form_participants.html.erb +68 -0
  132. data/app/views/sufia/admin/admin_sets/_form_visibility.html.erb +58 -0
  133. data/app/views/sufia/admin/admin_sets/index.html.erb +29 -33
  134. data/app/views/sufia/admin/admin_sets/show.html.erb +3 -0
  135. data/app/views/sufia/admin/show.html.erb +22 -19
  136. data/app/views/sufia/batch_uploads/_form.html.erb +2 -1
  137. data/app/views/sufia/homepage/index.html.erb +11 -3
  138. data/app/views/sufia/uploads/_js_templates.html.erb +15 -11
  139. data/app/views/users/_user_row.html.erb +10 -0
  140. data/app/views/users/index.html.erb +1 -12
  141. data/config/features.rb +2 -0
  142. data/config/locales/sufia.en.yml +122 -37
  143. data/config/routes.rb +4 -1
  144. data/db/migrate/20161021175854_create_permission_template.rb +11 -0
  145. data/db/migrate/20161021180154_create_permission_template_access.rb +11 -0
  146. data/db/migrate/20161116222307_add_release_to_permission_templates.rb +6 -0
  147. data/lib/generators/sufia/install_generator.rb +12 -3
  148. data/lib/generators/sufia/templates/catalog_controller.rb +3 -13
  149. data/lib/generators/sufia/templates/workflow.json.erb +65 -0
  150. data/lib/generators/sufia/upgrade700_generator.rb +1 -1
  151. data/lib/generators/sufia/work/templates/locale.en.yml.erb +37 -0
  152. data/lib/generators/sufia/{work_generator.rb → work/work_generator.rb} +25 -5
  153. data/lib/sufia.rb +0 -1
  154. data/lib/sufia/engine.rb +7 -0
  155. data/lib/sufia/move_all_works_to_admin_set.rb +8 -0
  156. data/lib/sufia/version.rb +1 -1
  157. data/lib/tasks/migrate.rake +8 -0
  158. data/spec/actors/sufia/apply_permission_template_actor_spec.rb +64 -0
  159. data/spec/actors/sufia/create_with_remote_files_actor_spec.rb +8 -0
  160. data/spec/actors/sufia/default_admin_set_actor_spec.rb +43 -0
  161. data/spec/actors/sufia/interpret_visibility_actor_spec.rb +266 -0
  162. data/spec/authorities/qa/authorities/find_works_spec.rb +55 -0
  163. data/spec/controllers/batch_edits_controller_spec.rb +1 -6
  164. data/spec/controllers/citations_controller_spec.rb +49 -10
  165. data/spec/controllers/collections_controller_spec.rb +39 -0
  166. data/spec/controllers/curation_concerns/generic_works_controller_spec.rb +22 -1
  167. data/spec/controllers/dashboard_controller_spec.rb +0 -8
  168. data/spec/controllers/depositors_controller_spec.rb +2 -2
  169. data/spec/controllers/downloads_controller_spec.rb +2 -2
  170. data/spec/controllers/my/collections_controller_spec.rb +5 -0
  171. data/spec/controllers/my/shares_controller_spec.rb +5 -0
  172. data/spec/controllers/my/works_controller_spec.rb +5 -0
  173. data/spec/controllers/stats_controller_spec.rb +1 -1
  174. data/spec/controllers/sufia/admin/admin_sets_controller_spec.rb +33 -5
  175. data/spec/controllers/sufia/admin/permission_template_accesses_controller_spec.rb +36 -0
  176. data/spec/controllers/sufia/admin/permission_templates_controller_spec.rb +46 -0
  177. data/spec/controllers/sufia/admin_controller_spec.rb +6 -0
  178. data/spec/controllers/sufia/batch_uploads_controller_spec.rb +40 -42
  179. data/spec/controllers/sufia/homepage_controller_spec.rb +14 -0
  180. data/spec/controllers/sufia/trophies_controller_spec.rb +17 -4
  181. data/spec/controllers/users_controller_spec.rb +13 -4
  182. data/spec/factories/permission_template_accesses.rb +5 -0
  183. data/spec/factories/permission_templates.rb +5 -0
  184. data/spec/factories/sipity_entities.rb +7 -0
  185. data/spec/factories/users.rb +4 -0
  186. data/spec/factories/workflow_states.rb +6 -0
  187. data/spec/factories/workflows.rb +5 -0
  188. data/spec/features/admin_admin_set_spec.rb +6 -4
  189. data/spec/features/batch_edit_spec.rb +0 -1
  190. data/spec/features/collection_spec.rb +4 -4
  191. data/spec/features/edit_work_spec.rb +1 -0
  192. data/spec/features/work_show_spec.rb +10 -0
  193. data/spec/forms/sufia/forms/admin_set_form_spec.rb +2 -1
  194. data/spec/forms/sufia/forms/batch_edit_form_spec.rb +30 -0
  195. data/spec/forms/sufia/forms/permission_template_form_spec.rb +196 -0
  196. data/spec/forms/sufia/forms/work_form_spec.rb +35 -1
  197. data/spec/helpers/batch_edits_helper_spec.rb +4 -4
  198. data/spec/helpers/blacklight_helper_spec.rb +1 -1
  199. data/spec/helpers/sufia_helper_spec.rb +39 -7
  200. data/spec/indexers/sufia/collection_indexer_spec.rb +12 -0
  201. data/spec/javascripts/autocomplete_spec.js.coffee +46 -6
  202. data/spec/javascripts/visibility_component_spec.js +491 -0
  203. data/spec/jobs/batch_create_job_spec.rb +27 -28
  204. data/spec/lib/sufia/arkivo_spec.rb +14 -0
  205. data/spec/lib/sufia/controlled_vocabulary/importer/downloader_spec.rb +31 -0
  206. data/spec/lib/sufia/move_all_works_to_admin_set_spec.rb +13 -0
  207. data/spec/lib/sufia/zotero_spec.rb +8 -0
  208. data/spec/models/sufia/ability_spec.rb +54 -14
  209. data/spec/models/sufia/permission_template_spec.rb +144 -0
  210. data/spec/models/sufia/user_usage_stats_spec.rb +8 -2
  211. data/spec/presenters/sufia/homepage_presenter_spec.rb +1 -1
  212. data/spec/presenters/sufia/select_type_list_presenter_spec.rb +26 -0
  213. data/spec/presenters/sufia/select_type_presenter_spec.rb +21 -0
  214. data/spec/search_builder/sufia/admin_set_search_builder_spec.rb +57 -0
  215. data/spec/search_builder/sufia/catalog_search_builder_spec.rb +40 -14
  216. data/spec/search_builder/sufia/find_works_search_builder_spec.rb +60 -0
  217. data/spec/search_builder/sufia/my_shares_search_builder_spec.rb +4 -1
  218. data/spec/search_builder/sufia/single_admin_set_search_builder_spec.rb +5 -1
  219. data/spec/services/sufia/actor_factory_spec.rb +13 -5
  220. data/spec/services/sufia/admin_set_create_service_spec.rb +27 -0
  221. data/spec/services/sufia/admin_set_service_spec.rb +104 -17
  222. data/spec/services/sufia/workflow/changes_required_notification_spec.rb +32 -0
  223. data/spec/services/sufia/workflow/complete_notification_spec.rb +32 -0
  224. data/spec/services/sufia/workflow/pending_review_notification_spec.rb +31 -0
  225. data/spec/services/sufia/workflow/workflow_by_admin_set_strategy_spec.rb +22 -0
  226. data/spec/spec_helper.rb +24 -5
  227. data/spec/support/proxies.rb +1 -1
  228. data/spec/test_app_templates/lib/generators/test_app_generator.rb +4 -0
  229. data/spec/views/_toolbar.html.erb_spec.rb +23 -6
  230. data/spec/views/batch_edits/edit.html.erb_spec.rb +7 -1
  231. data/spec/views/collections/_form_for_select_collection.html.erb_spec.rb +1 -3
  232. data/spec/views/curation_concerns/base/_find_work_widget.html.erb_spec.rb +22 -0
  233. data/spec/views/curation_concerns/base/_form.html.erb_spec.rb +7 -0
  234. data/spec/views/curation_concerns/base/_form_child_work_relationships.html.erb_spec.rb +1 -0
  235. data/spec/views/curation_concerns/base/_form_parent_work_relationships.html.erb_spec.rb +114 -0
  236. data/spec/views/curation_concerns/base/_form_progress.html.erb_spec.rb +3 -2
  237. data/spec/views/curation_concerns/base/_social_media.html.erb_spec.rb +1 -1
  238. data/spec/views/curation_concerns/base/edit.html.erb_spec.rb +1 -1
  239. data/spec/views/curation_concerns/base/show.html.erb_spec.rb +5 -1
  240. data/spec/views/curation_concerns/file_sets/_show_actions.html.erb_spec.rb +2 -2
  241. data/spec/views/dashboard/create_work_action.html.erb_spec.rb +27 -0
  242. data/spec/views/dashboard/index_spec.rb +7 -2
  243. data/spec/views/my/_sort_and_per_page.html.erb_spec.rb +33 -0
  244. data/spec/views/shared/select_work_type_modal.html.erb_spec.rb +32 -0
  245. data/spec/views/sufia/admin/admin_sets/_form.html.erb_spec.rb +18 -0
  246. data/spec/views/sufia/admin/admin_sets/_form_participants.html.erb_spec.rb +13 -0
  247. data/spec/views/sufia/admin/admin_sets/_form_visibility.html.erb_spec.rb +23 -0
  248. data/spec/views/sufia/batch_uploads/_form.html.erb_spec.rb +2 -12
  249. data/spec/views/sufia/homepage/index.html.erb_spec.rb +29 -8
  250. data/sufia.gemspec +5 -6
  251. data/tasks/sufia-dev.rake +6 -10
  252. data/template.rb +15 -0
  253. metadata +140 -28
  254. data/app/assets/stylesheets/sufia/widgets.css +0 -288
  255. data/app/helpers/sufia/citations_behaviors/formatters/endnote_formatter.rb +0 -49
  256. data/app/models/domain_term.rb +0 -4
  257. data/app/views/citations/file.html.erb +0 -0
  258. data/app/views/records/_rights_modal.html.erb +0 -1
  259. data/db/migrate/20160328222160_create_local_authorities.rb +0 -50
@@ -0,0 +1,17 @@
1
+ /* These styles are very specific to override the thumbnails from blacklight gallery */
2
+
3
+ .slideshow-documents {
4
+ .grid {
5
+ .document {
6
+ .thumbnail {
7
+ padding: 0;
8
+
9
+ a > img {
10
+ left: 0;
11
+ max-width: 100%;
12
+ top: 0;
13
+ }
14
+ }
15
+ }
16
+ }
17
+ }
@@ -0,0 +1,15 @@
1
+ module Qa::Authorities
2
+ class FindWorks < Qa::Authorities::Base
3
+ def search(_q, controller)
4
+ repo = CatalogController.new.repository
5
+ builder = Sufia::FindWorksSearchBuilder.new(controller)
6
+ response = repo.search(builder)
7
+ docs = response.documents
8
+ docs.map do |doc|
9
+ id = doc.id
10
+ title = doc.title
11
+ { id: id, label: title, value: id }
12
+ end
13
+ end
14
+ end
15
+ end
@@ -48,7 +48,8 @@ module Sufia
48
48
  end
49
49
 
50
50
  def _prefixes
51
- # This allows us to use the templates in curation_concerns/base
51
+ # This allows us to use the templates in curation_concerns/base, while prefering
52
+ # our local paths. Thus we are unable to just override `self.local_prefixes`
52
53
  @_prefixes ||= super + ['curation_concerns/base']
53
54
  end
54
55
 
@@ -5,28 +5,38 @@ module Sufia
5
5
  include CurationConcerns::CurationConcernController
6
6
 
7
7
  included do
8
- self.curation_concern_type = form_class.model_class
8
+ self.work_form_service = BatchUploadFormService
9
+ self.curation_concern_type = work_form_service.form_class.model_class # includes CanCan side-effects
10
+ # We use BatchUploadItem as a null stand-in curation_concern_type.
11
+ # The actual permission is checked dynamically during #create.
9
12
  end
10
13
 
14
+ # The permissions to create a batch are not as important as the permissions for the concern being batched.
15
+ # @note we don't call `authorize!` directly, since `authorized_models` already checks `user.can? :create, ...`
11
16
  def create
12
17
  authenticate_user!
13
- create_update_job
14
- flash[:notice] = t('sufia.works.new.after_create_html', application_name: view_context.application_name)
18
+ unsafe_pc = params.fetch(:batch_upload_item, {})[:payload_concern]
19
+ # Calling constantize on user params is disfavored (per brakeman), so we sanitize by matching it against an authorized model.
20
+ safe_pc = Sufia::SelectTypeListPresenter.new(current_user).authorized_models.map(&:to_s).find { |x| x == unsafe_pc }
21
+ raise CanCan::AccessDenied, "Cannot create an object of class '#{unsafe_pc}'" unless safe_pc
22
+ # authorize! :create, safe_pc
23
+ create_update_job(safe_pc)
24
+ flash[:notice] = t('sufia.works.create.after_create_html', application_name: view_context.application_name)
15
25
  redirect_after_update
16
26
  end
17
27
 
18
- module ClassMethods
19
- def form_class
28
+ class BatchUploadFormService < CurationConcerns::WorkFormService
29
+ # Gives the class of the form.
30
+ def self.form_class(_curation_concern = nil)
20
31
  ::Sufia::Forms::BatchUploadForm
21
32
  end
22
33
  end
23
34
 
24
35
  protected
25
36
 
26
- # Gives the class of the form.
27
- # This overrides CurationConcerns
28
- def form_class
29
- self.class.form_class
37
+ def build_form
38
+ super
39
+ @form.payload_concern = params[:payload_concern]
30
40
  end
31
41
 
32
42
  def redirect_after_update
@@ -37,14 +47,17 @@ module Sufia
37
47
  end
38
48
  end
39
49
 
40
- def create_update_job
50
+ # @param [String] klass the name of the Sufia Work Class being created by the batch
51
+ # @note Cannot use a proper Class here because it won't serialize
52
+ def create_update_job(klass)
41
53
  log = BatchCreateOperation.create!(user: current_user,
42
54
  operation_type: "Batch Create")
55
+ # ActionController::Parameters are not serializable, so cast to a hash
43
56
  BatchCreateJob.perform_later(current_user,
44
- params[:title],
45
- params[:resource_type],
57
+ params[:title].permit!.to_h,
58
+ params[:resource_type].permit!.to_h,
46
59
  params[:uploaded_files],
47
- attributes_for_actor,
60
+ attributes_for_actor.to_h.merge!(model: klass),
48
61
  log)
49
62
  end
50
63
 
@@ -14,6 +14,31 @@ module Sufia
14
14
 
15
15
  protected
16
16
 
17
+ def after_destroy(id)
18
+ respond_to do |wants|
19
+ wants.html do
20
+ redirect_to sufia.dashboard_collections_path,
21
+ notice: "Collection #{id} was successfully deleted"
22
+ end
23
+ wants.json do
24
+ render json: { id: id, description: "Collection #{id} was successfully deleted" }
25
+ end
26
+ end
27
+ end
28
+
29
+ def after_destroy_error(id)
30
+ respond_to do |wants|
31
+ wants.html do
32
+ flash[:notice] = "Collection #{id} could not be deleted"
33
+ render :edit, status: :unprocessable_entity
34
+ end
35
+ wants.json do
36
+ render json: { id: id, description: "Collection #{id} could not be deleted" },
37
+ status: :unprocessable_entity
38
+ end
39
+ end
40
+ end
41
+
17
42
  def add_breadcrumb_for_controller
18
43
  add_breadcrumb I18n.t('sufia.dashboard.my.collections'), sufia.dashboard_collections_path
19
44
  end
@@ -2,8 +2,11 @@ module Sufia::Controller
2
2
  extend ActiveSupport::Concern
3
3
 
4
4
  included do
5
+ class_attribute :create_work_presenter_class
6
+ self.create_work_presenter_class = Sufia::SelectTypeListPresenter
5
7
  # Adds Hydra behaviors into the application controller
6
8
  include Hydra::Controller::ControllerBehavior
9
+ helper_method :create_work_presenter
7
10
  end
8
11
 
9
12
  def current_ability
@@ -14,4 +17,9 @@ module Sufia::Controller
14
17
  def after_sign_in_path_for(_resource)
15
18
  sufia.dashboard_index_path
16
19
  end
20
+
21
+ # A presenter for selecting a work type to create
22
+ def create_work_presenter
23
+ @create_work_presenter ||= create_work_presenter_class.new(current_user)
24
+ end
17
25
  end
@@ -1,6 +1,6 @@
1
1
  module Sufia
2
2
  module DenyAccessOverrideBehavior
3
- # Overriding the default behavior from Hydra::Core::ContorllerBehavior
3
+ # Overriding the default behavior from Hydra::Core::ControllerBehavior
4
4
  def deny_access(exception)
5
5
  if current_user && current_user.persisted?
6
6
  redirect_to root_path, alert: exception.message
@@ -4,15 +4,6 @@ module Sufia
4
4
  include Sufia::Breadcrumbs
5
5
 
6
6
  included do
7
- include Blacklight::Configurable
8
-
9
- with_themed_layout '1_column'
10
-
11
- copy_blacklight_config_from(CatalogController)
12
-
13
- # actions: index, create, new, edit, show, update,
14
- # destroy, permissions, citation, stats
15
-
16
7
  # prepend this hook so that it comes before load_and_authorize
17
8
  prepend_before_action :authenticate_user!, except: [:show, :citation, :stats]
18
9
  before_action :build_breadcrumbs, only: [:show, :edit, :stats]
@@ -44,12 +35,12 @@ module Sufia
44
35
  end
45
36
  end
46
37
 
47
- protected
38
+ # This allows us to use the templates in curation_concerns/file_sets
39
+ def self.local_prefixes
40
+ ['curation_concerns/file_sets']
41
+ end
48
42
 
49
- def _prefixes
50
- # This allows us to use the templates in curation_concerns/file_sets
51
- @_prefixes ||= ['curation_concerns/file_sets'] + super
52
- end
43
+ protected
53
44
 
54
45
  def initialize_edit_form
55
46
  @version_list = version_list
@@ -34,6 +34,8 @@ module Sufia::HomepageControllerBehavior
34
34
  .rows(5)
35
35
  response = repository.search(builder)
36
36
  response.documents
37
+ rescue Blacklight::Exceptions::ECONNREFUSED
38
+ []
37
39
  end
38
40
 
39
41
  def recent
@@ -12,13 +12,7 @@ module Sufia::UsersControllerBehavior
12
12
  end
13
13
 
14
14
  def index
15
- query = params[:uq].blank? ? nil : "%" + params[:uq].downcase + "%"
16
- base = User.where(*base_query)
17
- unless query.blank?
18
- base = base.where("#{Devise.authentication_keys.first} like lower(?) OR display_name like lower(?)", query, query)
19
- end
20
- @users = base.references(:trophies).order(sort_value).page(params[:page]).per(10)
21
-
15
+ @users = search(params[:uq])
22
16
  respond_to do |format|
23
17
  format.html
24
18
  format.json { render json: @users.to_json }
@@ -68,6 +62,23 @@ module Sufia::UsersControllerBehavior
68
62
 
69
63
  protected
70
64
 
65
+ # TODO: this should move to a service.
66
+ # Returns a list of users excluding the system users and guest_users
67
+ # @param query [String] the query string
68
+ def search(query)
69
+ clause = query.blank? ? nil : "%" + query.downcase + "%"
70
+ base = User.where(*base_query)
71
+ unless clause.blank?
72
+ base = base.where("#{Devise.authentication_keys.first} like lower(?) OR display_name like lower(?)", clause, clause)
73
+ end
74
+ base.where("#{Devise.authentication_keys.first} not in (?)",
75
+ [User.batch_user_key, User.audit_user_key])
76
+ .where(guest: false)
77
+ .references(:trophies)
78
+ .order(sort_value)
79
+ .page(params[:page]).per(10)
80
+ end
81
+
71
82
  def user_params
72
83
  params.require(:user).permit(:avatar, :facebook_handle, :twitter_handle,
73
84
  :googleplus_handle, :linkedin_handle, :remove_avatar, :orcid)
@@ -9,8 +9,8 @@ module Sufia
9
9
  end
10
10
 
11
11
  module ClassMethods
12
- # We don't want the breadcrumb action to occur until after the concern has
13
- # been loaded and authorized
12
+ # We don't want the actions to occur until after the concern has been loaded and authorized
13
+ # @note this is a terribly side-effecty kludge
14
14
  def curation_concern_type=(curation_concern_type)
15
15
  super
16
16
  before_action :build_breadcrumbs, only: [:edit, :show]
@@ -52,7 +52,7 @@ module Sufia
52
52
  def after_create_response
53
53
  respond_to do |wants|
54
54
  wants.html do
55
- flash[:notice] = t('sufia.works.new.after_create_html', application_name: view_context.application_name)
55
+ flash[:notice] = t('sufia.works.create.after_create_html', application_name: view_context.application_name)
56
56
  redirect_to [main_app, curation_concern]
57
57
  end
58
58
  wants.json { render :show, status: :created, location: polymorphic_path([main_app, curation_concern]) }
@@ -62,13 +62,15 @@ module Sufia
62
62
  def after_update_response
63
63
  if permissions_changed? && curation_concern.file_sets.present?
64
64
  redirect_to sufia.confirm_access_curation_concerns_permission_path(curation_concern)
65
- elsif curation_concern.visibility_changed? && curation_concern.file_sets.present?
66
- redirect_to main_app.confirm_curation_concerns_permission_path(curation_concern)
67
65
  else
68
- respond_to do |wants|
69
- wants.html { redirect_to [main_app, curation_concern] }
70
- wants.json { render :show, status: :ok, location: polymorphic_path([main_app, curation_concern]) }
71
- end
66
+ super
67
+ end
68
+ end
69
+
70
+ def after_destroy_response(title)
71
+ respond_to do |wants|
72
+ wants.html { redirect_to sufia.dashboard_works_path, notice: "Deleted #{title}" }
73
+ wants.json { render_json_response(response_type: :deleted, message: "Deleted #{curation_concern.id}") }
72
74
  end
73
75
  end
74
76
 
@@ -88,7 +90,8 @@ module Sufia
88
90
  def add_breadcrumb_for_action
89
91
  case action_name
90
92
  when 'edit'.freeze
91
- add_breadcrumb I18n.t("sufia.work.browse_view"), main_app.polymorphic_path(curation_concern)
93
+ add_breadcrumb curation_concern.to_s, main_app.polymorphic_path(curation_concern)
94
+ add_breadcrumb t('sufia.works.edit.breadcrumb'), request.path
92
95
  when 'show'.freeze
93
96
  add_breadcrumb presenter.to_s, main_app.polymorphic_path(presenter)
94
97
  end
@@ -14,5 +14,10 @@ module My
14
14
  def search_action_url(*args)
15
15
  sufia.dashboard_collections_url(*args)
16
16
  end
17
+
18
+ # The url of the "more" link for additional facet values
19
+ def search_facet_path(args = {})
20
+ sufia.dashboard_collections_facet_path(args[:id])
21
+ end
17
22
  end
18
23
  end
@@ -14,5 +14,10 @@ module My
14
14
  def search_action_url(*args)
15
15
  sufia.dashboard_shares_url(*args)
16
16
  end
17
+
18
+ # The url of the "more" link for additional facet values
19
+ def search_facet_path(args = {})
20
+ sufia.dashboard_shares_facet_path(args[:id])
21
+ end
17
22
  end
18
23
  end
@@ -14,5 +14,10 @@ module My
14
14
  def search_action_url(*args)
15
15
  sufia.dashboard_works_url(*args)
16
16
  end
17
+
18
+ # The url of the "more" link for additional facet values
19
+ def search_facet_path(args = {})
20
+ sufia.dashboard_works_facet_path(args[:id])
21
+ end
17
22
  end
18
23
  end
@@ -23,7 +23,7 @@ class StatsController < ApplicationController
23
23
  when 'file'.freeze
24
24
  add_breadcrumb I18n.t("sufia.file_set.browse_view"), main_app.curation_concerns_file_set_path(params["id"])
25
25
  when 'work'.freeze
26
- add_breadcrumb I18n.t("sufia.work.browse_view"), polymorphic_path(@work)
26
+ add_breadcrumb @work.to_s, polymorphic_path(@work)
27
27
  end
28
28
  end
29
29
  end
@@ -43,6 +43,7 @@ module Sufia
43
43
 
44
44
  def update
45
45
  if @admin_set.update(admin_set_params)
46
+ permission_template.update(permission_template_params)
46
47
  redirect_to sufia.admin_admin_sets_path
47
48
  else
48
49
  setup_form
@@ -52,6 +53,9 @@ module Sufia
52
53
 
53
54
  def create
54
55
  if create_admin_set
56
+ permission_template_holder = permission_template
57
+ permission_template_holder.attributes = permission_template_params
58
+ permission_template_holder.save! # to create permission template on create
55
59
  redirect_to sufia.admin_admin_sets_path
56
60
  else
57
61
  setup_form
@@ -59,6 +63,11 @@ module Sufia
59
63
  end
60
64
  end
61
65
 
66
+ def destroy
67
+ @admin_set.destroy
68
+ redirect_to sufia.admin_admin_sets_path, notice: t(:'sufia.admin.admin_sets.delete.notification')
69
+ end
70
+
62
71
  # for the AdminSetService
63
72
  def repository
64
73
  repository_class.new(blacklight_config)
@@ -83,7 +92,7 @@ module Sufia
83
92
  end
84
93
 
85
94
  def create_admin_set
86
- AdminSetService.new(@admin_set, current_user).create
95
+ AdminSetCreateService.new(@admin_set, current_user).create
87
96
  end
88
97
 
89
98
  def setup_form
@@ -91,7 +100,12 @@ module Sufia
91
100
  add_breadcrumb t(:'sufia.toolbar.admin.menu'), sufia.admin_path
92
101
  add_breadcrumb t(:'sufia.admin.sidebar.admin_sets'), sufia.admin_admin_sets_path
93
102
  add_breadcrumb action_breadcrumb, request.path
94
- @form = form_class.new(@admin_set)
103
+ @form = form_class.new(@admin_set, permission_template)
104
+ end
105
+
106
+ # Find or create the permission_template object for this admin set
107
+ def permission_template
108
+ PermissionTemplate.find_or_initialize_by(admin_set_id: @admin_set.id)
95
109
  end
96
110
 
97
111
  def action_breadcrumb
@@ -110,5 +124,9 @@ module Sufia
110
124
  def repository_class
111
125
  blacklight_config.repository_class
112
126
  end
127
+
128
+ def permission_template_params
129
+ { "workflow_name" => params[:admin_set][:workflow_name] }
130
+ end
113
131
  end
114
132
  end
@@ -0,0 +1,15 @@
1
+ module Sufia
2
+ module Admin
3
+ class PermissionTemplateAccessesController < ApplicationController
4
+ load_and_authorize_resource class: 'Sufia::PermissionTemplateAccess'
5
+
6
+ def destroy
7
+ @permission_template_access.destroy
8
+
9
+ redirect_to sufia.edit_admin_admin_set_path(@permission_template_access.permission_template.admin_set_id,
10
+ anchor: 'participants'),
11
+ notice: 'Permissions updated'
12
+ end
13
+ end
14
+ end
15
+ end
@@ -0,0 +1,29 @@
1
+ module Sufia
2
+ module Admin
3
+ class PermissionTemplatesController < ApplicationController
4
+ before_action :load_template_for_admin_set
5
+
6
+ def update
7
+ authorize! :update, @permission_template
8
+ Forms::PermissionTemplateForm.new(@permission_template).update(update_params)
9
+ # Ensure we redirect to active tab
10
+ current_tab = params[:sufia_permission_template][:access_grants_attributes].present? ? 'participants' : 'visibility'
11
+ redirect_to sufia.edit_admin_admin_set_path(params[:admin_set_id], anchor: current_tab),
12
+ notice: 'Permissions updated'
13
+ end
14
+
15
+ private
16
+
17
+ # This sets the @permission_template so that CanCanCan doesn't have to.
18
+ def load_template_for_admin_set
19
+ @permission_template = Sufia::PermissionTemplate.find_by(admin_set_id: params[:admin_set_id])
20
+ end
21
+
22
+ def update_params
23
+ params.require(:sufia_permission_template)
24
+ .permit(:release_date, :release_period, :release_varies, :release_embargo, :visibility,
25
+ access_grants_attributes: [:access, :agent_id, :agent_type, :id])
26
+ end
27
+ end
28
+ end
29
+ end