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.
- checksums.yaml +4 -4
- data/.codeclimate.yml +2 -0
- data/.rubocop.yml +3 -0
- data/.rubocop_todo.yml +1 -2
- data/.travis.yml +0 -1
- data/Gemfile +2 -1
- data/README.md +23 -106
- data/app/actors/sufia/apply_permission_template_actor.rb +19 -0
- data/app/actors/sufia/create_with_remote_files_actor.rb +2 -2
- data/app/actors/sufia/default_admin_set_actor.rb +42 -0
- data/app/actors/sufia/interpret_visibility_actor.rb +115 -0
- data/app/assets/images/collection.png +0 -0
- data/app/assets/javascripts/sufia.js +6 -0
- data/app/assets/javascripts/sufia/admin/admin_set/participants.es6 +9 -0
- data/app/assets/javascripts/sufia/admin/admin_set/visibility.es6 +134 -0
- data/app/assets/javascripts/sufia/admin/admin_set_controls.es6 +11 -0
- data/app/assets/javascripts/sufia/app.js +27 -5
- data/app/assets/javascripts/sufia/autocomplete.es6 +15 -0
- data/app/assets/javascripts/sufia/autocomplete/work.es6 +29 -0
- data/app/assets/javascripts/sufia/dashboard_actions.js +2 -4
- data/app/assets/javascripts/sufia/save_work/save_work_control.es6 +14 -2
- data/app/assets/javascripts/sufia/save_work/uploaded_files.es6 +7 -2
- data/app/assets/javascripts/sufia/save_work/visibility_component.es6 +245 -4
- data/app/assets/javascripts/sufia/select_work_type.es6 +38 -0
- data/app/assets/javascripts/sufia/workflow_actions_affix.js +14 -0
- data/app/assets/stylesheets/sufia/_dashboard.scss +50 -29
- data/app/assets/stylesheets/sufia/_footer.scss +30 -0
- data/app/assets/stylesheets/sufia/_header.scss +3 -4
- data/app/assets/stylesheets/sufia/_home-page.scss +10 -8
- data/app/assets/stylesheets/sufia/_select_work_type.scss +43 -0
- data/app/assets/stylesheets/sufia/_sufia.scss +4 -1
- data/app/assets/stylesheets/sufia/_variables.scss +3 -0
- data/app/assets/stylesheets/sufia/admin.scss +66 -169
- data/app/assets/stylesheets/sufia/blacklight_gallery.scss +17 -0
- data/app/authorities/qa/authorities/find_works.rb +15 -0
- data/app/controllers/concerns/sufia/batch_edits_controller_behavior.rb +2 -1
- data/app/controllers/concerns/sufia/batch_uploads_controller_behavior.rb +26 -13
- data/app/controllers/concerns/sufia/collections_controller_behavior.rb +25 -0
- data/app/controllers/concerns/sufia/controller.rb +8 -0
- data/app/controllers/concerns/sufia/deny_access_override_behavior.rb +1 -1
- data/app/controllers/concerns/sufia/file_sets_controller_behavior.rb +5 -14
- data/app/controllers/concerns/sufia/homepage_controller_behavior.rb +2 -0
- data/app/controllers/concerns/sufia/users_controller_behavior.rb +18 -7
- data/app/controllers/concerns/sufia/works_controller_behavior.rb +13 -10
- data/app/controllers/my/collections_controller.rb +5 -0
- data/app/controllers/my/shares_controller.rb +5 -0
- data/app/controllers/my/works_controller.rb +5 -0
- data/app/controllers/stats_controller.rb +1 -1
- data/app/controllers/sufia/admin/admin_sets_controller.rb +20 -2
- data/app/controllers/sufia/admin/permission_template_accesses_controller.rb +15 -0
- data/app/controllers/sufia/admin/permission_templates_controller.rb +29 -0
- data/app/controllers/sufia/admin_controller.rb +2 -0
- data/app/controllers/sufia/trophies_controller.rb +0 -2
- data/app/forms/sufia/forms/admin_set_form.rb +19 -0
- data/app/forms/sufia/forms/batch_edit_form.rb +16 -6
- data/app/forms/sufia/forms/batch_upload_form.rb +3 -2
- data/app/forms/sufia/forms/permission_template_form.rb +115 -0
- data/app/forms/sufia/forms/work_form.rb +6 -0
- data/app/helpers/batch_edits_helper.rb +1 -1
- data/app/helpers/sufia/citations_behavior.rb +0 -5
- data/app/helpers/sufia/citations_behaviors/formatters.rb +0 -1
- data/app/helpers/sufia/sufia_helper_behavior.rb +38 -6
- data/app/indexers/sufia/collection_indexer.rb +6 -0
- data/app/jobs/batch_create_job.rb +7 -15
- data/app/models/batch_upload_item.rb +2 -0
- data/app/models/concerns/sufia/ability.rb +12 -1
- data/app/models/sufia/permission_template.rb +102 -0
- data/app/models/sufia/permission_template_access.rb +18 -0
- data/app/presenters/sufia/admin_set_presenter.rb +1 -1
- data/app/presenters/sufia/model_icon.rb +7 -0
- data/app/presenters/sufia/select_type_list_presenter.rb +37 -0
- data/app/presenters/sufia/select_type_presenter.rb +35 -0
- data/app/presenters/sufia/work_show_presenter.rb +0 -2
- data/app/search_builders/collection_search_builder.rb +0 -2
- data/app/search_builders/sufia/admin_set_search_builder.rb +24 -0
- data/app/search_builders/sufia/catalog_search_builder.rb +10 -4
- data/app/search_builders/sufia/find_works_search_builder.rb +44 -0
- data/app/search_builders/sufia/my_search_builder_behavior.rb +0 -4
- data/app/search_builders/sufia/my_works_search_builder.rb +1 -1
- data/app/services/sufia/actor_factory.rb +6 -2
- data/app/services/sufia/admin_set_create_service.rb +22 -0
- data/app/services/sufia/admin_set_service.rb +46 -16
- data/app/services/sufia/collection_thumbnail_path_service.rb +10 -0
- data/app/services/sufia/workflow/abstract_notification.rb +39 -0
- data/app/services/sufia/workflow/changes_required_notification.rb +22 -0
- data/app/services/sufia/workflow/complete_notification.rb +22 -0
- data/app/services/sufia/workflow/pending_review_notification.rb +21 -0
- data/app/services/sufia/workflow/workflow_by_admin_set_strategy.rb +15 -0
- data/app/views/_masthead.html.erb +4 -4
- data/app/views/_toolbar.html.erb +31 -9
- data/app/views/_user_util_links.html.erb +7 -7
- data/app/views/batch_edits/edit.html.erb +24 -12
- data/app/views/catalog/_thumbnail_list_collection.html.erb +1 -1
- data/app/views/collections/_form.html.erb +2 -2
- data/app/views/collections/_media_display.html.erb +1 -1
- data/app/views/curation_concerns/base/_find_work_widget.html.erb +16 -0
- data/app/views/curation_concerns/base/_form.html.erb +6 -0
- data/app/views/curation_concerns/base/_form_child_work_relationships.html.erb +1 -1
- data/app/views/curation_concerns/base/_form_metadata.html.erb +1 -1
- data/app/views/curation_concerns/base/_form_parent_work_relationships.html.erb +43 -0
- data/app/views/curation_concerns/base/_form_progress.html.erb +7 -4
- data/app/views/curation_concerns/base/_form_relationships.html.erb +6 -6
- data/app/views/curation_concerns/base/_form_share.html.erb +1 -2
- data/app/views/curation_concerns/base/_guts4form.html.erb +1 -1
- data/app/views/curation_concerns/base/_social_media.html.erb +1 -1
- data/app/views/curation_concerns/base/_workflow_actions_widget.erb +3 -0
- data/app/views/curation_concerns/base/edit.html.erb +1 -1
- data/app/views/curation_concerns/base/new.html.erb +1 -1
- data/app/views/curation_concerns/base/show.html.erb +4 -1
- data/app/views/curation_concerns/file_sets/_show_actions.html.erb +0 -3
- data/app/views/dashboard/_create_work_action.html.erb +20 -0
- data/app/views/dashboard/_index_partials/_heading_actions.html.erb +9 -22
- data/app/views/layouts/admin.html.erb +8 -68
- data/app/views/layouts/curation_concerns/1_column.html.erb +4 -31
- data/app/views/layouts/homepage.html.erb +15 -45
- data/app/views/layouts/sufia-dashboard.html.erb +1 -36
- data/app/views/layouts/sufia.html.erb +49 -0
- data/app/views/my/_document_list.html.erb +1 -1
- data/app/views/my/_facet_limit.html.erb +2 -2
- data/app/views/my/_index_partials/_default_group.html.erb +10 -10
- data/app/views/my/_index_partials/_list_collections.html.erb +1 -1
- data/app/views/my/_sort_and_per_page.html.erb +8 -8
- data/app/views/records/edit_fields/_rights.html.erb +0 -1
- data/app/views/shared/_footer.html.erb +1 -1
- data/app/views/shared/_select_work_type_modal.html.erb +34 -0
- data/app/views/sufia/admin/_collections.html.erb +31 -0
- data/app/views/sufia/admin/_sidebar.html.erb +35 -23
- data/app/views/sufia/admin/admin_sets/_form.html.erb +38 -15
- data/app/views/sufia/admin/admin_sets/_form_metadata.html.erb +2 -0
- data/app/views/sufia/admin/admin_sets/_form_participant_table.html.erb +21 -0
- data/app/views/sufia/admin/admin_sets/_form_participants.html.erb +68 -0
- data/app/views/sufia/admin/admin_sets/_form_visibility.html.erb +58 -0
- data/app/views/sufia/admin/admin_sets/index.html.erb +29 -33
- data/app/views/sufia/admin/admin_sets/show.html.erb +3 -0
- data/app/views/sufia/admin/show.html.erb +22 -19
- data/app/views/sufia/batch_uploads/_form.html.erb +2 -1
- data/app/views/sufia/homepage/index.html.erb +11 -3
- data/app/views/sufia/uploads/_js_templates.html.erb +15 -11
- data/app/views/users/_user_row.html.erb +10 -0
- data/app/views/users/index.html.erb +1 -12
- data/config/features.rb +2 -0
- data/config/locales/sufia.en.yml +122 -37
- data/config/routes.rb +4 -1
- data/db/migrate/20161021175854_create_permission_template.rb +11 -0
- data/db/migrate/20161021180154_create_permission_template_access.rb +11 -0
- data/db/migrate/20161116222307_add_release_to_permission_templates.rb +6 -0
- data/lib/generators/sufia/install_generator.rb +12 -3
- data/lib/generators/sufia/templates/catalog_controller.rb +3 -13
- data/lib/generators/sufia/templates/workflow.json.erb +65 -0
- data/lib/generators/sufia/upgrade700_generator.rb +1 -1
- data/lib/generators/sufia/work/templates/locale.en.yml.erb +37 -0
- data/lib/generators/sufia/{work_generator.rb → work/work_generator.rb} +25 -5
- data/lib/sufia.rb +0 -1
- data/lib/sufia/engine.rb +7 -0
- data/lib/sufia/move_all_works_to_admin_set.rb +8 -0
- data/lib/sufia/version.rb +1 -1
- data/lib/tasks/migrate.rake +8 -0
- data/spec/actors/sufia/apply_permission_template_actor_spec.rb +64 -0
- data/spec/actors/sufia/create_with_remote_files_actor_spec.rb +8 -0
- data/spec/actors/sufia/default_admin_set_actor_spec.rb +43 -0
- data/spec/actors/sufia/interpret_visibility_actor_spec.rb +266 -0
- data/spec/authorities/qa/authorities/find_works_spec.rb +55 -0
- data/spec/controllers/batch_edits_controller_spec.rb +1 -6
- data/spec/controllers/citations_controller_spec.rb +49 -10
- data/spec/controllers/collections_controller_spec.rb +39 -0
- data/spec/controllers/curation_concerns/generic_works_controller_spec.rb +22 -1
- data/spec/controllers/dashboard_controller_spec.rb +0 -8
- data/spec/controllers/depositors_controller_spec.rb +2 -2
- data/spec/controllers/downloads_controller_spec.rb +2 -2
- data/spec/controllers/my/collections_controller_spec.rb +5 -0
- data/spec/controllers/my/shares_controller_spec.rb +5 -0
- data/spec/controllers/my/works_controller_spec.rb +5 -0
- data/spec/controllers/stats_controller_spec.rb +1 -1
- data/spec/controllers/sufia/admin/admin_sets_controller_spec.rb +33 -5
- data/spec/controllers/sufia/admin/permission_template_accesses_controller_spec.rb +36 -0
- data/spec/controllers/sufia/admin/permission_templates_controller_spec.rb +46 -0
- data/spec/controllers/sufia/admin_controller_spec.rb +6 -0
- data/spec/controllers/sufia/batch_uploads_controller_spec.rb +40 -42
- data/spec/controllers/sufia/homepage_controller_spec.rb +14 -0
- data/spec/controllers/sufia/trophies_controller_spec.rb +17 -4
- data/spec/controllers/users_controller_spec.rb +13 -4
- data/spec/factories/permission_template_accesses.rb +5 -0
- data/spec/factories/permission_templates.rb +5 -0
- data/spec/factories/sipity_entities.rb +7 -0
- data/spec/factories/users.rb +4 -0
- data/spec/factories/workflow_states.rb +6 -0
- data/spec/factories/workflows.rb +5 -0
- data/spec/features/admin_admin_set_spec.rb +6 -4
- data/spec/features/batch_edit_spec.rb +0 -1
- data/spec/features/collection_spec.rb +4 -4
- data/spec/features/edit_work_spec.rb +1 -0
- data/spec/features/work_show_spec.rb +10 -0
- data/spec/forms/sufia/forms/admin_set_form_spec.rb +2 -1
- data/spec/forms/sufia/forms/batch_edit_form_spec.rb +30 -0
- data/spec/forms/sufia/forms/permission_template_form_spec.rb +196 -0
- data/spec/forms/sufia/forms/work_form_spec.rb +35 -1
- data/spec/helpers/batch_edits_helper_spec.rb +4 -4
- data/spec/helpers/blacklight_helper_spec.rb +1 -1
- data/spec/helpers/sufia_helper_spec.rb +39 -7
- data/spec/indexers/sufia/collection_indexer_spec.rb +12 -0
- data/spec/javascripts/autocomplete_spec.js.coffee +46 -6
- data/spec/javascripts/visibility_component_spec.js +491 -0
- data/spec/jobs/batch_create_job_spec.rb +27 -28
- data/spec/lib/sufia/arkivo_spec.rb +14 -0
- data/spec/lib/sufia/controlled_vocabulary/importer/downloader_spec.rb +31 -0
- data/spec/lib/sufia/move_all_works_to_admin_set_spec.rb +13 -0
- data/spec/lib/sufia/zotero_spec.rb +8 -0
- data/spec/models/sufia/ability_spec.rb +54 -14
- data/spec/models/sufia/permission_template_spec.rb +144 -0
- data/spec/models/sufia/user_usage_stats_spec.rb +8 -2
- data/spec/presenters/sufia/homepage_presenter_spec.rb +1 -1
- data/spec/presenters/sufia/select_type_list_presenter_spec.rb +26 -0
- data/spec/presenters/sufia/select_type_presenter_spec.rb +21 -0
- data/spec/search_builder/sufia/admin_set_search_builder_spec.rb +57 -0
- data/spec/search_builder/sufia/catalog_search_builder_spec.rb +40 -14
- data/spec/search_builder/sufia/find_works_search_builder_spec.rb +60 -0
- data/spec/search_builder/sufia/my_shares_search_builder_spec.rb +4 -1
- data/spec/search_builder/sufia/single_admin_set_search_builder_spec.rb +5 -1
- data/spec/services/sufia/actor_factory_spec.rb +13 -5
- data/spec/services/sufia/admin_set_create_service_spec.rb +27 -0
- data/spec/services/sufia/admin_set_service_spec.rb +104 -17
- data/spec/services/sufia/workflow/changes_required_notification_spec.rb +32 -0
- data/spec/services/sufia/workflow/complete_notification_spec.rb +32 -0
- data/spec/services/sufia/workflow/pending_review_notification_spec.rb +31 -0
- data/spec/services/sufia/workflow/workflow_by_admin_set_strategy_spec.rb +22 -0
- data/spec/spec_helper.rb +24 -5
- data/spec/support/proxies.rb +1 -1
- data/spec/test_app_templates/lib/generators/test_app_generator.rb +4 -0
- data/spec/views/_toolbar.html.erb_spec.rb +23 -6
- data/spec/views/batch_edits/edit.html.erb_spec.rb +7 -1
- data/spec/views/collections/_form_for_select_collection.html.erb_spec.rb +1 -3
- data/spec/views/curation_concerns/base/_find_work_widget.html.erb_spec.rb +22 -0
- data/spec/views/curation_concerns/base/_form.html.erb_spec.rb +7 -0
- data/spec/views/curation_concerns/base/_form_child_work_relationships.html.erb_spec.rb +1 -0
- data/spec/views/curation_concerns/base/_form_parent_work_relationships.html.erb_spec.rb +114 -0
- data/spec/views/curation_concerns/base/_form_progress.html.erb_spec.rb +3 -2
- data/spec/views/curation_concerns/base/_social_media.html.erb_spec.rb +1 -1
- data/spec/views/curation_concerns/base/edit.html.erb_spec.rb +1 -1
- data/spec/views/curation_concerns/base/show.html.erb_spec.rb +5 -1
- data/spec/views/curation_concerns/file_sets/_show_actions.html.erb_spec.rb +2 -2
- data/spec/views/dashboard/create_work_action.html.erb_spec.rb +27 -0
- data/spec/views/dashboard/index_spec.rb +7 -2
- data/spec/views/my/_sort_and_per_page.html.erb_spec.rb +33 -0
- data/spec/views/shared/select_work_type_modal.html.erb_spec.rb +32 -0
- data/spec/views/sufia/admin/admin_sets/_form.html.erb_spec.rb +18 -0
- data/spec/views/sufia/admin/admin_sets/_form_participants.html.erb_spec.rb +13 -0
- data/spec/views/sufia/admin/admin_sets/_form_visibility.html.erb_spec.rb +23 -0
- data/spec/views/sufia/batch_uploads/_form.html.erb_spec.rb +2 -12
- data/spec/views/sufia/homepage/index.html.erb_spec.rb +29 -8
- data/sufia.gemspec +5 -6
- data/tasks/sufia-dev.rake +6 -10
- data/template.rb +15 -0
- metadata +140 -28
- data/app/assets/stylesheets/sufia/widgets.css +0 -288
- data/app/helpers/sufia/citations_behaviors/formatters/endnote_formatter.rb +0 -49
- data/app/models/domain_term.rb +0 -4
- data/app/views/citations/file.html.erb +0 -0
- data/app/views/records/_rights_modal.html.erb +0 -1
- 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
|
@@ -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
|
103
|
-
sentinel = /
|
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
|
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'
|
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", :
|
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]', '
|
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 "article" or "dataset." 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. "Smith, John."."
|
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
|
-
|
20
|
-
|
21
|
-
|
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
|
-
|
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 = '
|
48
|
+
"\n self.human_readable_type = '#{underscored_name.titleize}'"
|
29
49
|
end
|
30
50
|
end
|
31
51
|
|
data/lib/sufia.rb
CHANGED
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|
|
data/lib/sufia/version.rb
CHANGED
@@ -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
|