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
data/config/routes.rb CHANGED
@@ -144,7 +144,10 @@ Sufia::Engine.routes.draw do
144
144
 
145
145
  resource :admin, controller: 'sufia/admin', only: [:show]
146
146
  scope 'admin', module: 'sufia/admin', as: 'admin' do
147
- resources :admin_sets
147
+ resources :admin_sets do
148
+ resource :permission_template
149
+ end
150
+ resources :permission_template_accesses, only: :destroy
148
151
  resource 'stats', only: [:show]
149
152
  resources :features, only: [:index] do
150
153
  resources :strategies, only: [:update, :destroy]
@@ -0,0 +1,11 @@
1
+ class CreatePermissionTemplate < ActiveRecord::Migration
2
+ def change
3
+ create_table :permission_templates do |t|
4
+ t.string :admin_set_id
5
+ t.string :visibility
6
+ t.string :workflow_name
7
+ t.timestamps
8
+ end
9
+ add_index :permission_templates, :admin_set_id
10
+ end
11
+ end
@@ -0,0 +1,11 @@
1
+ class CreatePermissionTemplateAccess < ActiveRecord::Migration
2
+ def change
3
+ create_table :permission_template_accesses do |t|
4
+ t.references :permission_template, foreign_key: true
5
+ t.string :agent_type
6
+ t.string :agent_id
7
+ t.string :access
8
+ t.timestamps
9
+ end
10
+ end
11
+ end
@@ -0,0 +1,6 @@
1
+ class AddReleaseToPermissionTemplates < ActiveRecord::Migration
2
+ def change
3
+ add_column :permission_templates, :release_date, :date
4
+ add_column :permission_templates, :release_period, :string
5
+ end
6
+ end
@@ -9,7 +9,6 @@ module Sufia
9
9
  2. Installs model-related concerns
10
10
  * Creates several database migrations if they do not exist in /db/migrate
11
11
  * Adds user behavior to the user model
12
- * Generates GenericWork model.
13
12
  * Creates the sufia.rb configuration file
14
13
  * Generates mailboxer
15
14
  3. Adds Sufia's abilities into the Ability class
@@ -99,8 +98,8 @@ module Sufia
99
98
  def inject_routes
100
99
  gsub_file 'config/routes.rb', /root (:to =>|to:) "catalog#index"/, ''
101
100
  gsub_file 'config/routes.rb', /'welcome#index'/, "'sufia/homepage#index'" # Replace the root path injected by CurationConcerns
102
- routing_code = "\n mount Sufia::Engine => '/'\n"
103
- sentinel = /end\Z/
101
+ routing_code = "\n mount Sufia::Engine, at: '/'\n"
102
+ sentinel = /\s+mount CurationConcerns::Engine/
104
103
  inject_into_file 'config/routes.rb', routing_code, before: sentinel, verbose: false
105
104
  end
106
105
 
@@ -125,6 +124,12 @@ module Sufia
125
124
  generate "sufia:assets"
126
125
  end
127
126
 
127
+ def add_sufia_collection_indexer
128
+ inject_into_file 'app/models/collection.rb', after: 'include CurationConcerns::BasicMetadata' do
129
+ "\n self.indexer = Sufia::CollectionIndexer"
130
+ end
131
+ end
132
+
128
133
  def install_batch_edit
129
134
  generate "hydra_batch_edit:install"
130
135
  end
@@ -145,5 +150,9 @@ module Sufia
145
150
  def datatables
146
151
  generate 'jquery:datatables:install bootstrap3'
147
152
  end
153
+
154
+ def create_workflow
155
+ template('workflow.json.erb', "config/workflows/one_step_mediated_deposit_workflow.json")
156
+ end
148
157
  end
149
158
  end
@@ -2,7 +2,6 @@ class CatalogController < ApplicationController
2
2
  include Hydra::Catalog
3
3
  include Hydra::Controller::ControllerBehavior
4
4
  include Sufia::Catalog
5
- include BlacklightAdvancedSearch::Controller
6
5
 
7
6
  # This filter applies the hydra access controls
8
7
  before_action :enforce_show_permissions, only: :show
@@ -16,13 +15,6 @@ class CatalogController < ApplicationController
16
15
  end
17
16
 
18
17
  configure_blacklight do |config|
19
- # default advanced config values
20
- config.advanced_search ||= Blacklight::OpenStructWithHashAccess.new
21
- # config.advanced_search[:qt] ||= 'advanced'
22
- config.advanced_search[:url_key] ||= 'advanced'
23
- config.advanced_search[:query_parser] ||= 'dismax'
24
- config.advanced_search[:form_solr_parameters] ||= {}
25
-
26
18
  config.search_builder_class = Sufia::SearchBuilder
27
19
 
28
20
  # Show gallery view
@@ -33,7 +25,7 @@ class CatalogController < ApplicationController
33
25
  config.default_solr_params = {
34
26
  qt: "search",
35
27
  rows: 10,
36
- qf: "title_tesim name_tesim"
28
+ qf: "title_tesim description_tesim keyword_tesim"
37
29
  }
38
30
 
39
31
  # solr field configuration for document/show views
@@ -118,7 +110,7 @@ class CatalogController < ApplicationController
118
110
  # This one uses all the defaults set by the solr request handler. Which
119
111
  # solr request handler? The one set in config[:default_solr_parameters][:qt],
120
112
  # since we aren't specifying it otherwise.
121
- config.add_search_field('all_fields', label: 'All Fields', include_in_advanced_search: false) do |field|
113
+ config.add_search_field('all_fields', label: 'All Fields') do |field|
122
114
  all_names = config.show_fields.values.map(&:field).join(" ")
123
115
  title_name = solr_name("title", :stored_searchable)
124
116
  field.solr_parameters = {
@@ -212,7 +204,6 @@ class CatalogController < ApplicationController
212
204
  end
213
205
 
214
206
  config.add_search_field('format') do |field|
215
- field.include_in_advanced_search = false
216
207
  solr_name = solr_name("format", :stored_searchable)
217
208
  field.solr_local_parameters = {
218
209
  qf: solr_name,
@@ -221,7 +212,6 @@ class CatalogController < ApplicationController
221
212
  end
222
213
 
223
214
  config.add_search_field('identifier') do |field|
224
- field.include_in_advanced_search = false
225
215
  solr_name = solr_name("id", :stored_searchable)
226
216
  field.solr_local_parameters = {
227
217
  qf: solr_name,
@@ -247,7 +237,7 @@ class CatalogController < ApplicationController
247
237
  end
248
238
 
249
239
  config.add_search_field('depositor') do |field|
250
- solr_name = solr_name("depositor", :stored_searchable)
240
+ solr_name = solr_name("depositor", :symbol)
251
241
  field.solr_local_parameters = {
252
242
  qf: solr_name,
253
243
  pf: solr_name
@@ -0,0 +1,65 @@
1
+ {
2
+ "workflows": [
3
+ {
4
+ "name": "one_step_mediated_deposit",
5
+ "label": "One-step mediated deposit workflow",
6
+ "description": "A single-step workflow for mediated deposit in which all deposits must be approved by a reviewer. Reviewer may also send deposits back to the depositor.",
7
+ "actions": [
8
+ {
9
+ "name": "deposit",
10
+ "from_states": [],
11
+ "transition_to": "pending_review",
12
+ "notifications": [
13
+ {
14
+ "notification_type": "email",
15
+ "name": "Sufia::Workflow::PendingReviewNotification",
16
+ "to": ["approving"]
17
+ }
18
+ ],
19
+ "methods": [
20
+ "CurationConcerns::Workflow::DeactivateObject"
21
+ ]
22
+ }, {
23
+ "name": "request_changes",
24
+ "from_states": [{"names": ["complete", "pending_review"], "roles": ["approving"]}],
25
+ "transition_to": "changes_required",
26
+ "notifications": [
27
+ {
28
+ "notification_type": "email",
29
+ "name": "Sufia::Workflow::ChangesRequiredNotification",
30
+ "to": ["approving"]
31
+ }
32
+ ],
33
+ "methods": [
34
+ "CurationConcerns::Workflow::DeactivateObject"
35
+ ]
36
+ }, {
37
+ "name": "approve",
38
+ "from_states": [{"names": ["pending_review"], "roles": ["approving"]}],
39
+ "transition_to": "complete",
40
+ "notifications": [
41
+ {
42
+ "notification_type": "email",
43
+ "name": "Sufia::Workflow::CompleteNotification",
44
+ "to": ["approving"]
45
+ }
46
+ ],
47
+ "methods": [
48
+ "CurationConcerns::Workflow::ActivateObject"
49
+ ]
50
+ }, {
51
+ "name": "request_review",
52
+ "from_states": [{"names": ["changes_required"], "roles": ["depositing"]}],
53
+ "transition_to": "pending_review",
54
+ "notifications": [
55
+ {
56
+ "notification_type": "email",
57
+ "name": "Sufia::Workflow::PendingReviewNotification",
58
+ "to": ["approving"]
59
+ }
60
+ ]
61
+ }
62
+ ]
63
+ }
64
+ ]
65
+ }
@@ -16,7 +16,7 @@ This generator for upgrading sufia from 6.0.0 to 7.0 makes the following changes
16
16
  # The engine routes have to come after the devise routes so that /users/sign_in will work
17
17
  def update_catalog_controller
18
18
  # Nuke old search_params_logic
19
- gsub_file 'app/controllers/catalog_controller.rb', '[:add_access_controls_to_solr_params, :add_advanced_parse_q_to_solr]', '[:add_advanced_parse_q_to_solr] + search_params_logic + [:add_access_controls_to_solr_params]'
19
+ gsub_file 'app/controllers/catalog_controller.rb', '[:add_access_controls_to_solr_params, :add_advanced_parse_q_to_solr]', 'search_params_logic + [:add_access_controls_to_solr_params]'
20
20
  end
21
21
 
22
22
  def qa_routes
@@ -0,0 +1,37 @@
1
+ en:
2
+ sufia:
3
+ icons:
4
+ <%= file_name %>: 'fa fa-file-text-o'
5
+ select_type:
6
+ <%= file_name %>:
7
+ name: "<%= human_name.titleize %>"
8
+ description: "<%= human_name %> works"
9
+ simple_form:
10
+ labels:
11
+ <%= file_name %>:
12
+ based_near: "Location"
13
+ description: "Abstract or Summary"
14
+ keyword: "Keyword"
15
+ date_created: "Date Created"
16
+ related_url: "Related URL"
17
+ files: "Upload a new version of this file from your computer"
18
+ collection_ids: "Add as member of collection"
19
+ admin_set_id: "Add as member of administrative set"
20
+
21
+ hints:
22
+ <%= file_name %>:
23
+ resource: "Pre-defined categories to describe the type of content being uploaded, such as &quot;article&quot; or &quot;dataset.&quot; More than one type may be selected."
24
+ title: "A name to aid in identifying a work."
25
+ keyword: "Words or phrases you select to describe what the work is about. These are used to search for content."
26
+ subject: "Headings or index terms describing what the work is about; these do need to conform to an existing vocabulary."
27
+ creator: "The person or group responsible for the work. Usually this is the author of the content. Personal names should be entered with the last name first, e.g. &quot;Smith, John.&quot;."
28
+ related_url: "A link to a website or other specific content (audio, video, PDF document) related to the work. An example is the URL of a research project from which the work was derived."
29
+ based_near: "A place name related to the work, such as its site of publication, or the city, state, or country the work contents are about. Calls upon the <a href='http://www.geonames.org'>GeoNames web service</a>."
30
+ contributor: "A person or group you want to recognize for playing a role in the creation of the work, but not the primary role."
31
+ date_created: "The date on which the work was generated."
32
+ description: "Free-text notes about the work. Examples include abstracts of a paper or citation information for a journal article."
33
+ identifier: "A unique handle identifying the work. An example would be a DOI for a journal article, or an ISBN or OCLC number for a book."
34
+ language: "The language of the work's content."
35
+ publisher: "The person or group making the work available. Generally this is the institution."
36
+ rights: "Licensing and distribution information governing access to the work. Select from the provided drop-down list."
37
+
@@ -3,6 +3,12 @@ require 'generators/curation_concerns/work/work_generator'
3
3
  module Sufia
4
4
  class WorkGenerator < CurationConcerns::WorkGenerator
5
5
  source_root CurationConcerns::WorkGenerator.source_root
6
+
7
+ # Allows us to pull templates from sufia as well as from curation_concerns
8
+ def self.source_paths
9
+ [File.expand_path('../templates/', __FILE__)]
10
+ end
11
+
6
12
  desc """
7
13
  This generator makes the following changes to your application:
8
14
  1. Generates work model
@@ -15,17 +21,31 @@ module Sufia
15
21
  super
16
22
  end
17
23
 
24
+ def create_i18n
25
+ template 'locale.en.yml.erb', "config/locales/#{file_name}.en.yml"
26
+ end
27
+
28
+ # Inserts after the last registering work, or at the top of the config block
18
29
  def register_work
19
- inject_into_file 'config/initializers/sufia.rb', after: "Sufia.config do |config|\n" do
20
- " # Injected via `rails g sufia:work #{class_name}`\n" \
21
- " config.register_curation_concern :#{file_name}\n"
30
+ config = 'config/initializers/sufia.rb'
31
+ lastmatch = nil
32
+ File.open(config).each_line do |line|
33
+ lastmatch = line if line =~ /^\s*config.register_curation_concern :.*\n$/
34
+ end
35
+ content = " # Injected via `rails g sufia:work #{class_name}`\n" \
36
+ " config.register_curation_concern :#{file_name}\n"
37
+ content = " # Note: order of registration affects Zotero/Arkivo\n#{content}" unless lastmatch
38
+ anchor = lastmatch || "Sufia.config do |config|\n"
39
+ inject_into_file config, after: anchor do
40
+ content
22
41
  end
23
42
  end
24
43
 
25
44
  def inject_sufia_work_behavior
26
- insert_into_file "app/models/#{name.underscore}.rb", after: 'include ::CurationConcerns::BasicMetadata' do
45
+ underscored_name = name.underscore
46
+ insert_into_file "app/models/#{underscored_name}.rb", after: 'include ::CurationConcerns::BasicMetadata' do
27
47
  "\n include Sufia::WorkBehavior" \
28
- "\n self.human_readable_type = 'Work'"
48
+ "\n self.human_readable_type = '#{underscored_name.titleize}'"
29
49
  end
30
50
  end
31
51
 
data/lib/sufia.rb CHANGED
@@ -8,7 +8,6 @@ require 'font-awesome-rails'
8
8
  require 'tinymce-rails'
9
9
  require 'tinymce-rails-imageupload'
10
10
  require 'blacklight'
11
- require 'blacklight_advanced_search'
12
11
  require 'blacklight/gallery'
13
12
  require 'active_fedora/noid'
14
13
  require 'hydra/head'
data/lib/sufia/engine.rb CHANGED
@@ -53,6 +53,13 @@ module Sufia
53
53
  end
54
54
 
55
55
  CurationConcerns::CurationConcern.actor_factory = Sufia::ActorFactory
56
+ CurationConcerns::Workflow::WorkflowFactory.workflow_strategy = Sufia::Workflow::WorkflowByAdminSetStrategy
57
+ CurationConcerns::MemberPresenterFactory.file_presenter_class = Sufia::FileSetPresenter
58
+
59
+ # Don't try to load this class until the application has been generated
60
+ if defined? ::SearchBuilder
61
+ CurationConcerns::AdminSetService.default_search_builder = Sufia::AdminSetSearchBuilder
62
+ end
56
63
  end
57
64
 
58
65
  initializer 'sufia.assets.precompile' do |app|
@@ -0,0 +1,8 @@
1
+ # If you want to move all your works to an admin set run this.
2
+ class MoveAllWorksToAdminSet
3
+ def self.run(admin_set)
4
+ CurationConcerns::WorkRelation.new.find_each do |w|
5
+ w.update(admin_set: admin_set)
6
+ end
7
+ end
8
+ end
data/lib/sufia/version.rb CHANGED
@@ -1,3 +1,3 @@
1
1
  module Sufia
2
- VERSION = '7.2.0'.freeze
2
+ VERSION = '7.3.0.rc1'.freeze
3
3
  end
@@ -0,0 +1,8 @@
1
+ namespace :sufia do
2
+ namespace :migrate do
3
+ task move_all_works_to_admin_set: :environment do
4
+ require 'sufia/move_all_works_to_admin_set'
5
+ MoveAllWorksToAdminSet.run(AdminSet.find(Sufia::DefaultAdminSetActor::DEFAULT_ID))
6
+ end
7
+ end
8
+ end
@@ -0,0 +1,64 @@
1
+ require 'spec_helper'
2
+
3
+ RSpec.describe Sufia::ApplyPermissionTemplateActor do
4
+ let(:create_actor) do
5
+ double('create actor', create: true,
6
+ curation_concern: work,
7
+ update: true,
8
+ user: depositor)
9
+ end
10
+ let(:actor) do
11
+ CurationConcerns::Actors::ActorStack.new(work, depositor, [described_class])
12
+ end
13
+ let(:depositor) { create(:user) }
14
+ let(:work) { build(:generic_work) }
15
+ let(:attributes) { { admin_set_id: admin_set.id } }
16
+ let(:admin_set) { create(:admin_set) }
17
+ let(:permission_template) { create(:permission_template, admin_set_id: admin_set.id) }
18
+
19
+ describe "create" do
20
+ context "when admin_set_id is blank" do
21
+ let(:attributes) { { admin_set_id: '' } }
22
+
23
+ it "returns true" do
24
+ expect(actor.create(attributes)).to be true
25
+ end
26
+ end
27
+
28
+ context "when admin_set_id is provided" do
29
+ let(:attributes) { { admin_set_id: admin_set.id } }
30
+ before do
31
+ create(:permission_template_access,
32
+ permission_template: permission_template,
33
+ agent_type: 'user',
34
+ agent_id: 'hannah',
35
+ access: 'manage')
36
+ create(:permission_template_access,
37
+ permission_template: permission_template,
38
+ agent_type: 'group',
39
+ agent_id: 'librarians',
40
+ access: 'manage')
41
+ create(:permission_template_access,
42
+ permission_template: permission_template,
43
+ agent_type: 'user',
44
+ agent_id: 'gary',
45
+ access: 'view')
46
+ create(:permission_template_access,
47
+ permission_template: permission_template,
48
+ agent_type: 'group',
49
+ agent_id: 'readers',
50
+ access: 'view')
51
+ allow(CurationConcerns::Actors::RootActor).to receive(:new).and_return(create_actor)
52
+ allow(create_actor).to receive(:create).and_return(true)
53
+ end
54
+
55
+ it "adds the template users to the work" do
56
+ expect(actor.create(attributes)).to be true
57
+ expect(work.edit_users).to include 'hannah'
58
+ expect(work.edit_groups).to include 'librarians'
59
+ expect(work.read_users).to include 'gary'
60
+ expect(work.read_groups).to include 'readers'
61
+ end
62
+ end
63
+ end
64
+ end
@@ -55,5 +55,13 @@ describe Sufia::CreateWithRemoteFilesActor do
55
55
  expect(IngestLocalFileJob).to receive(:perform_later).with(FileSet, "/local/file/here.txt", user)
56
56
  expect(actor.create(attributes)).to be true
57
57
  end
58
+
59
+ context "with spaces" do
60
+ let(:file) { "file:///local/file/ pigs .txt" }
61
+ it "attaches files" do
62
+ expect(IngestLocalFileJob).to receive(:perform_later).with(FileSet, "/local/file/ pigs .txt", user)
63
+ expect(actor.create(attributes)).to be true
64
+ end
65
+ end
58
66
  end
59
67
  end