hyrax 3.2.0 → 3.4.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.circleci/config.yml +3 -6
- data/.dassie/.env +1 -1
- data/.dassie/Gemfile +7 -3
- data/.dassie/app/models/user.rb +0 -2
- data/.dassie/config/analytics.yml +12 -5
- data/.dassie/config/environments/development.rb +2 -0
- data/.dassie/config/initializers/hyrax.rb +13 -1
- data/.dassie/db/migrate/20210921150120_enable_uuid_extension.valkyrie_engine.rb +7 -0
- data/.dassie/db/migrate/20210921150121_create_orm_resources.valkyrie_engine.rb +19 -0
- data/.dassie/db/migrate/20210921150122_add_model_type_to_orm_resources.valkyrie_engine.rb +7 -0
- data/.dassie/db/migrate/20210921150123_change_model_type_to_internal_model.valkyrie_engine.rb +7 -0
- data/.dassie/db/migrate/20210921150124_create_path_gin_index.valkyrie_engine.rb +7 -0
- data/.dassie/db/migrate/20210921150125_create_internal_resource_index.valkyrie_engine.rb +7 -0
- data/.dassie/db/migrate/20210921150126_create_updated_at_index.valkyrie_engine.rb +7 -0
- data/.dassie/db/migrate/20210921150127_add_optimistic_locking_to_orm_resources.valkyrie_engine.rb +7 -0
- data/.dassie/db/migrate/20211130181150_create_default_administrative_set.rb +8 -0
- data/.dassie/db/schema.rb +20 -1
- data/.dassie/db/seeds.rb +70 -15
- data/.env +7 -4
- data/.github/release.yml +26 -0
- data/.github/workflows/main.yml +17 -0
- data/.github/workflows/release.yml +17 -0
- data/.gitignore +4 -0
- data/.regen +1 -1
- data/.rubocop_fixme.yml +3 -1
- data/CONTAINERS.md +13 -10
- data/Dockerfile +2 -1
- data/README.md +37 -0
- data/app/actors/hyrax/actors/file_actor.rb +6 -4
- data/app/actors/hyrax/actors/transfer_request_actor.rb +3 -7
- data/app/assets/javascripts/hyrax/admin/graphs.es6 +34 -37
- data/app/assets/javascripts/hyrax/analytics_events.js +75 -0
- data/app/assets/javascripts/hyrax/autocomplete/linked_data.es6 +1 -3
- data/app/assets/javascripts/hyrax/collapse.js +24 -0
- data/app/assets/javascripts/hyrax/collections.js +1 -2
- data/app/assets/javascripts/hyrax/ga_events.js +2 -8
- data/app/assets/javascripts/hyrax/reports-buttons.js +33 -0
- data/app/assets/javascripts/hyrax.js +2 -1
- data/app/assets/stylesheets/_bootstrap-default-overrides.scss +9 -0
- data/app/authorities/qa/authorities/collections.rb +4 -5
- data/app/authorities/qa/authorities/find_works.rb +1 -1
- data/app/controllers/concerns/hyrax/breadcrumbs_for_collection_analytics.rb +26 -0
- data/app/controllers/concerns/hyrax/breadcrumbs_for_works_analytics.rb +26 -0
- data/app/controllers/concerns/hyrax/controller.rb +43 -0
- data/app/controllers/concerns/hyrax/works_controller_behavior.rb +83 -59
- data/app/controllers/hyrax/admin/admin_sets_controller.rb +105 -19
- data/app/controllers/hyrax/admin/analytics/analytics_controller.rb +40 -0
- data/app/controllers/hyrax/admin/analytics/collection_reports_controller.rb +61 -0
- data/app/controllers/hyrax/admin/analytics/work_reports_controller.rb +122 -0
- data/app/controllers/hyrax/admin/permission_template_accesses_controller.rb +12 -19
- data/app/controllers/hyrax/batch_edits_controller.rb +12 -3
- data/app/controllers/hyrax/batch_uploads_controller.rb +4 -0
- data/app/controllers/hyrax/citations_controller.rb +1 -1
- data/app/controllers/hyrax/collections_controller.rb +4 -1
- data/app/controllers/hyrax/dashboard/collections_controller.rb +34 -16
- data/app/controllers/hyrax/dashboard_controller.rb +8 -0
- data/app/controllers/hyrax/stats_controller.rb +3 -1
- data/app/forms/hyrax/forms/administrative_set_form.rb +19 -1
- data/app/forms/hyrax/forms/batch_edit_form.rb +1 -1
- data/app/forms/hyrax/forms/dashboard/nest_collection_form.rb +21 -6
- data/app/forms/hyrax/forms/pcdm_collection_form.rb +4 -0
- data/app/forms/hyrax/forms/permission_template_form.rb +17 -9
- data/app/forms/hyrax/forms/resource_form.rb +9 -5
- data/app/helpers/hyrax/collections_helper.rb +14 -0
- data/app/helpers/hyrax/membership_helper.rb +1 -1
- data/app/helpers/hyrax/trophy_helper.rb +1 -1
- data/app/helpers/hyrax/url_helper.rb +1 -1
- data/app/indexers/hyrax/administrative_set_indexer.rb +8 -2
- data/app/indexers/hyrax/deep_indexing_service.rb +1 -1
- data/app/indexers/hyrax/file_set_indexer.rb +1 -0
- data/app/indexers/hyrax/pcdm_collection_indexer.rb +3 -1
- data/app/indexers/hyrax/thumbnail_indexer.rb +31 -0
- data/app/indexers/hyrax/valkyrie_file_set_indexer.rb +7 -7
- data/app/indexers/hyrax/valkyrie_indexer.rb +4 -2
- data/app/indexers/hyrax/valkyrie_work_indexer.rb +13 -0
- data/app/inputs/controlled_vocabulary_input.rb +2 -0
- data/app/jobs/change_depositor_event_job.rb +47 -0
- data/app/jobs/characterize_job.rb +66 -3
- data/app/jobs/concerns/hyrax/members_permission_job_behavior.rb +1 -1
- data/app/jobs/content_depositor_change_event_job.rb +2 -1
- data/app/jobs/hyrax/propagate_change_depositor_job.rb +32 -0
- data/app/jobs/inherit_permissions_job.rb +1 -1
- data/app/jobs/valkyrie_create_derivatives_job.rb +25 -0
- data/app/jobs/valkyrie_ingest_job.rb +124 -0
- data/app/models/admin_set.rb +2 -2
- data/app/models/collection_branding_info.rb +8 -6
- data/app/models/concerns/hyrax/ability.rb +26 -5
- data/app/models/concerns/hyrax/collection_behavior.rb +2 -2
- data/app/models/concerns/hyrax/file_set/characterization.rb +7 -1
- data/app/models/concerns/hyrax/solr_document/metadata.rb +2 -0
- data/app/models/concerns/hyrax/solr_document_behavior.rb +9 -3
- data/app/models/file_download_stat.rb +4 -4
- data/app/models/hyrax/administrative_set.rb +36 -1
- data/app/models/hyrax/collection_type.rb +2 -2
- data/app/models/hyrax/default_administrative_set.rb +42 -0
- data/app/models/hyrax/file_metadata.rb +5 -1
- data/app/models/hyrax/file_set.rb +42 -1
- data/app/models/hyrax/pcdm_collection.rb +56 -0
- data/app/models/hyrax/permission_template.rb +11 -5
- data/app/models/hyrax/statistic.rb +31 -4
- data/app/models/hyrax/work.rb +91 -0
- data/app/models/proxy_deposit_request.rb +1 -1
- data/app/presenters/hyrax/admin/dashboard_presenter.rb +8 -6
- data/app/presenters/hyrax/admin/repository_growth_presenter.rb +10 -5
- data/app/presenters/hyrax/admin/user_activity_presenter.rb +8 -12
- data/app/presenters/hyrax/admin_set_presenter.rb +2 -2
- data/app/presenters/hyrax/file_set_presenter.rb +2 -0
- data/app/presenters/hyrax/menu_presenter.rb +4 -0
- data/app/presenters/hyrax/pcdm_member_presenter_factory.rb +3 -3
- data/app/presenters/hyrax/work_show_presenter.rb +9 -2
- data/app/presenters/hyrax/work_usage.rb +1 -0
- data/app/search_builders/hyrax/README.md +1 -1
- data/app/search_builders/hyrax/dashboard/collections_search_builder.rb +2 -2
- data/app/search_builders/hyrax/dashboard/managed_search_filters.rb +44 -4
- data/app/search_builders/hyrax/dashboard/nested_collections_search_builder.rb +2 -2
- data/app/search_builders/hyrax/my/collections_search_builder.rb +12 -5
- data/app/services/hyrax/access_control_list.rb +13 -0
- data/app/services/hyrax/admin_set_create_service.rb +94 -48
- data/app/services/hyrax/analytics/google/events.rb +37 -0
- data/app/services/hyrax/analytics/google/events_daily.rb +72 -0
- data/app/services/hyrax/analytics/google/visits.rb +44 -0
- data/app/services/hyrax/analytics/google/visits_daily.rb +49 -0
- data/app/services/hyrax/analytics/google.rb +204 -0
- data/app/services/hyrax/analytics/matomo.rb +193 -0
- data/app/services/hyrax/analytics/results.rb +79 -0
- data/app/services/hyrax/analytics.rb +12 -82
- data/app/services/hyrax/change_content_depositor_service.rb +2 -2
- data/app/services/hyrax/change_depositor_service.rb +70 -0
- data/app/services/hyrax/characterization/valkyrie_characterization_service.rb +134 -0
- data/app/services/hyrax/collections/nested_collection_query_service.rb +32 -15
- data/app/services/hyrax/custom_queries/navigators/child_file_sets_navigator.rb +45 -0
- data/app/services/hyrax/custom_queries/navigators/child_filesets_navigator.rb +7 -2
- data/app/services/hyrax/custom_queries/navigators/parent_work_navigator.rb +54 -0
- data/app/services/hyrax/default_middleware_stack.rb +3 -0
- data/app/services/hyrax/file_set_derivatives_service.rb +21 -2
- data/app/services/hyrax/file_set_type_service.rb +2 -5
- data/app/services/hyrax/listeners/acl_index_listener.rb +3 -1
- data/app/services/hyrax/listeners/active_fedora_acl_index_listener.rb +3 -1
- data/app/services/hyrax/listeners/batch_notification_listener.rb +3 -1
- data/app/services/hyrax/listeners/file_metadata_listener.rb +38 -0
- data/app/services/hyrax/listeners/file_set_lifecycle_listener.rb +6 -2
- data/app/services/hyrax/listeners/file_set_lifecycle_notification_listener.rb +6 -2
- data/app/services/hyrax/listeners/member_cleanup_listener.rb +26 -3
- data/app/services/hyrax/listeners/metadata_index_listener.rb +48 -3
- data/app/services/hyrax/listeners/object_lifecycle_listener.rb +9 -3
- data/app/services/hyrax/listeners/proxy_deposit_listener.rb +16 -8
- data/app/services/hyrax/listeners/trophy_cleanup_listener.rb +3 -0
- data/app/services/hyrax/listeners/workflow_listener.rb +3 -1
- data/app/services/hyrax/listeners.rb +8 -0
- data/app/services/hyrax/location_service.rb +33 -0
- data/app/services/hyrax/multiple_membership_checker.rb +44 -1
- data/app/services/hyrax/resource_visibility_propagator.rb +1 -1
- data/app/services/hyrax/restriction_service.rb +4 -0
- data/app/services/hyrax/simple_schema_loader.rb +5 -1
- data/app/services/hyrax/solr_query_service.rb +12 -7
- data/app/services/hyrax/statistics/users/over_time.rb +8 -5
- data/app/services/hyrax/statistics/works/over_time.rb +10 -0
- data/app/services/hyrax/thumbnail_path_service.rb +1 -1
- data/app/services/hyrax/work_uploads_handler.rb +2 -9
- data/app/utils/hyrax/data_destroyers/collection_branding_destroyer.rb +29 -0
- data/app/utils/hyrax/data_destroyers/collection_types_destroyer.rb +26 -0
- data/app/utils/hyrax/data_destroyers/default_admin_set_id_cache_destroyer.rb +26 -0
- data/app/utils/hyrax/data_destroyers/featured_works_destroyer.rb +27 -0
- data/app/utils/hyrax/data_destroyers/permission_templates_destroyer.rb +30 -0
- data/app/utils/hyrax/data_destroyers/repository_metadata_destroyer.rb +42 -0
- data/app/utils/hyrax/data_destroyers/stats_destroyer.rb +33 -0
- data/app/utils/hyrax/data_maintenance.rb +51 -0
- data/app/utils/hyrax/required_data_seeder.rb +21 -0
- data/app/utils/hyrax/required_data_seeders/collection_seeder.rb +26 -0
- data/app/utils/hyrax/required_data_seeders/collection_type_seeder.rb +36 -0
- data/app/utils/hyrax/test_data_seeder.rb +24 -0
- data/app/utils/hyrax/test_data_seeders/collection_seeder.rb +91 -0
- data/app/utils/hyrax/test_data_seeders/collection_type_seeder.rb +72 -0
- data/app/utils/hyrax/test_data_seeders/user_seeder.rb +52 -0
- data/app/validators/hyrax/collection_membership_validator.rb +38 -0
- data/app/views/catalog/_index_header_list_hyrax_pcdm_collection.html.erb +4 -0
- data/app/views/hyrax/admin/admin_sets/_form_participant_table.html.erb +2 -2
- data/app/views/hyrax/admin/admin_sets/_form_participants.html.erb +2 -2
- data/app/views/hyrax/admin/admin_sets/_form_visibility.html.erb +2 -2
- data/app/views/hyrax/admin/admin_sets/_form_workflow.erb +1 -1
- data/app/views/hyrax/admin/analytics/_date_range_form.html.erb +11 -0
- data/app/views/hyrax/admin/analytics/collection_reports/_custom_range.html.erb +39 -0
- data/app/views/hyrax/admin/analytics/collection_reports/_monthly_summary.html.erb +48 -0
- data/app/views/hyrax/admin/analytics/collection_reports/_summary.html.erb +55 -0
- data/app/views/hyrax/admin/analytics/collection_reports/_top_collections.html.erb +55 -0
- data/app/views/hyrax/admin/analytics/collection_reports/index.html.erb +70 -0
- data/app/views/hyrax/admin/analytics/collection_reports/show.html.erb +94 -0
- data/app/views/hyrax/admin/analytics/work_reports/_custom_range.html.erb +43 -0
- data/app/views/hyrax/admin/analytics/work_reports/_monthly_summary.html.erb +35 -0
- data/app/views/hyrax/admin/analytics/work_reports/_summary.html.erb +60 -0
- data/app/views/hyrax/admin/analytics/work_reports/_top_file_set_downloads.html.erb +33 -0
- data/app/views/hyrax/admin/analytics/work_reports/_top_works.html.erb +40 -0
- data/app/views/hyrax/admin/analytics/work_reports/_work_counts.html.erb +18 -0
- data/app/views/hyrax/admin/analytics/work_reports/_work_files.html.erb +41 -0
- data/app/views/hyrax/admin/analytics/work_reports/index.html.erb +77 -0
- data/app/views/hyrax/admin/analytics/work_reports/show.html.erb +90 -0
- data/app/views/hyrax/admin/collection_types/index.html.erb +1 -1
- data/app/views/hyrax/admin/stats/show.html.erb +1 -1
- data/app/views/hyrax/base/_form.html.erb +1 -1
- data/app/views/hyrax/base/_form_child_work_relationships.html.erb +1 -1
- data/app/views/hyrax/base/_relationships_parent_row.html.erb +0 -1
- data/app/views/hyrax/base/show.html.erb +6 -0
- data/app/views/hyrax/collections/show.html.erb +4 -0
- data/app/views/hyrax/dashboard/_repository_growth.html.erb +5 -5
- data/app/views/hyrax/dashboard/_resource_type_graph.html.erb +41 -0
- data/app/views/hyrax/dashboard/_sidebar.html.erb +4 -1
- data/app/views/hyrax/dashboard/_tabs.html.erb +11 -0
- data/app/views/hyrax/dashboard/_user_activity.html.erb +17 -23
- data/app/views/hyrax/dashboard/_user_activity_graph.html.erb +55 -0
- data/app/views/hyrax/dashboard/_visibility_graph.html.erb +31 -0
- data/app/views/hyrax/dashboard/_work_type_graph.html.erb +41 -0
- data/app/views/hyrax/dashboard/collections/_default_group.html.erb +2 -2
- data/app/views/hyrax/dashboard/collections/_form.html.erb +23 -16
- data/app/views/hyrax/dashboard/collections/_form_discovery.html.erb +6 -3
- data/app/views/hyrax/dashboard/collections/_form_share.html.erb +2 -2
- data/app/views/hyrax/dashboard/collections/_form_share_table.html.erb +3 -3
- data/app/views/hyrax/dashboard/collections/_list_collections.html.erb +2 -2
- data/app/views/hyrax/dashboard/show_admin.html.erb +24 -45
- data/app/views/hyrax/dashboard/sidebar/_activity.html.erb +22 -0
- data/app/views/hyrax/dashboard/works/_default_group.html.erb +1 -1
- data/app/views/hyrax/dashboard/works/_list_works.html.erb +1 -1
- data/app/views/hyrax/file_sets/_actions.html.erb +4 -3
- data/app/views/hyrax/file_sets/show.html.erb +6 -0
- data/app/views/hyrax/my/_facet_pagination.html.erb +12 -9
- data/app/views/hyrax/my/_work_action_menu.html.erb +8 -9
- data/app/views/hyrax/my/collections/_default_group.html.erb +2 -2
- data/app/views/hyrax/my/collections/_list_collections.html.erb +2 -2
- data/app/views/hyrax/my/collections/index.html.erb +4 -3
- data/app/views/hyrax/my/works/_default_group.html.erb +1 -1
- data/app/views/hyrax/my/works/_list_works.html.erb +1 -2
- data/app/views/hyrax/my/works/index.html.erb +4 -2
- data/app/views/hyrax/stats/_downloads.html.erb +18 -0
- data/app/views/hyrax/stats/_pageviews.html.erb +18 -0
- data/app/views/hyrax/stats/work.html.erb +17 -9
- data/app/views/layouts/_head_tag_content.html.erb +7 -2
- data/app/views/{_ga.html.erb → shared/_ga.html.erb} +3 -7
- data/app/views/shared/_matomo.html.erb +15 -0
- data/chart/hyrax/Chart.yaml +2 -2
- data/chart/hyrax/README.md +22 -1
- data/chart/hyrax/values.yaml +1 -1
- data/config/i18n-tasks.yml +2 -2
- data/config/initializers/listeners.rb +5 -6
- data/config/locales/hyrax.de.yml +200 -5
- data/config/locales/hyrax.en.yml +201 -21
- data/config/locales/hyrax.es.yml +204 -9
- data/config/locales/hyrax.fr.yml +196 -1
- data/config/locales/hyrax.it.yml +197 -2
- data/config/locales/hyrax.pt-BR.yml +196 -1
- data/config/locales/hyrax.zh.yml +196 -1
- data/config/metadata/basic_metadata.yaml +2 -0
- data/config/metadata/core_metadata.yaml +1 -1
- data/config/routes.rb +4 -0
- data/docker-compose.yml +48 -42
- data/documentation/developing-your-hyrax-based-app.md +2 -2
- data/documentation/legacyREADME.md +1 -1
- data/hyrax.gemspec +3 -1
- data/lib/generators/hyrax/templates/config/analytics.yml +13 -7
- data/lib/generators/hyrax/templates/config/initializers/hyrax.rb +0 -13
- data/lib/generators/hyrax/templates/db/migrate/20211130181150_create_default_administrative_set.rb.erb +8 -0
- data/lib/generators/hyrax/work/templates/feature_spec.rb.erb +3 -1
- data/lib/hyrax/administrative_set_name.rb +18 -0
- data/lib/hyrax/collection_name.rb +2 -0
- data/lib/hyrax/configuration.rb +77 -5
- data/lib/hyrax/controlled_vocabularies/location.rb +9 -2
- data/lib/hyrax/controlled_vocabularies/resource_label_caching.rb +42 -0
- data/lib/hyrax/controlled_vocabularies.rb +1 -0
- data/lib/hyrax/engine.rb +7 -6
- data/lib/hyrax/publisher.rb +49 -0
- data/lib/hyrax/schema.rb +16 -13
- data/lib/hyrax/specs/capybara.rb +1 -1
- data/lib/hyrax/specs/shared_specs/hydra_works.rb +11 -4
- data/lib/hyrax/specs/shared_specs/indexers.rb +117 -3
- data/lib/hyrax/transactions/admin_set_create.rb +23 -0
- data/lib/hyrax/transactions/admin_set_destroy.rb +22 -0
- data/lib/hyrax/transactions/admin_set_update.rb +21 -0
- data/lib/hyrax/transactions/collection_destroy.rb +22 -0
- data/lib/hyrax/transactions/collection_update.rb +3 -2
- data/lib/hyrax/transactions/container.rb +97 -22
- data/lib/hyrax/transactions/create_work.rb +3 -0
- data/lib/hyrax/transactions/destroy_work.rb +3 -0
- data/lib/hyrax/transactions/steps/apply_collection_permission_template.rb +2 -0
- data/lib/hyrax/transactions/steps/apply_permission_template.rb +2 -0
- data/lib/hyrax/transactions/steps/apply_visibility.rb +2 -0
- data/lib/hyrax/transactions/steps/change_depositor.rb +46 -0
- data/lib/hyrax/transactions/steps/check_for_empty_admin_set.rb +36 -0
- data/lib/hyrax/transactions/steps/delete_access_control.rb +32 -0
- data/lib/hyrax/transactions/steps/delete_resource.rb +19 -3
- data/lib/hyrax/transactions/steps/destroy_work.rb +3 -1
- data/lib/hyrax/transactions/steps/ensure_permission_template.rb +2 -0
- data/lib/hyrax/transactions/steps/save.rb +24 -6
- data/lib/hyrax/transactions/steps/save_access_control.rb +2 -2
- data/lib/hyrax/transactions/steps/save_work.rb +3 -0
- data/lib/hyrax/transactions/steps/set_user_as_creator.rb +41 -0
- data/lib/hyrax/transactions/steps/update_work_members.rb +51 -0
- data/lib/hyrax/transactions/update_work.rb +4 -3
- data/lib/hyrax/transactions/work_create.rb +1 -1
- data/lib/hyrax/transactions/work_destroy.rb +2 -1
- data/lib/hyrax/transactions/work_update.rb +19 -0
- data/lib/hyrax/version.rb +1 -1
- data/lib/tasks/regenerate_derivatives.rake +1 -1
- data/lib/wings/attribute_transformer.rb +5 -1
- data/lib/wings/setup.rb +18 -1
- data/lib/wings/valkyrie/persister.rb +18 -0
- data/lib/wings/valkyrie/query_service.rb +2 -1
- data/lib/wings/valkyrie/storage.rb +7 -1
- data/template.rb +1 -1
- data/vendor/assets/javascripts/morris/morris.min.js +1 -7
- data/vendor/assets/stylesheets/morris.js/0.5.1/morris.css +1 -1
- metadata +124 -11
- data/app/views/hyrax/dashboard/_repository_objects.html.erb +0 -28
@@ -11,15 +11,55 @@ module Hyrax
|
|
11
11
|
|
12
12
|
# Override to exclude 'public' and 'registered' groups from read access.
|
13
13
|
def apply_group_permissions(permission_types, ability = current_ability)
|
14
|
+
search_terms = add_managing_role_search_filter(ability: ability)
|
14
15
|
groups = ability.user_groups
|
15
|
-
return
|
16
|
-
permission_types.
|
16
|
+
return search_terms if groups.empty?
|
17
|
+
permission_types.each do |type|
|
17
18
|
field = solr_field_for(type, 'group')
|
18
|
-
|
19
|
+
delete_groups = [::Ability.public_group_name, ::Ability.registered_group_name]
|
20
|
+
user_groups = type == 'read' ? groups - delete_groups : groups
|
19
21
|
next if user_groups.empty?
|
20
|
-
|
22
|
+
# parens required to properly OR the clauses together:
|
23
|
+
search_terms << "({!terms f=#{field}}#{user_groups.join(',')})"
|
21
24
|
end
|
25
|
+
search_terms
|
22
26
|
end
|
27
|
+
|
28
|
+
# Look for a user's managing role and add filters for all admin sets that have permission
|
29
|
+
# templates that include managing roles.
|
30
|
+
#
|
31
|
+
# rubocop:disable Metrics/MethodLength
|
32
|
+
# rubocop:disable Metrics/PerceivedComplexity
|
33
|
+
# rubocop:disable Metrics/CyclomaticComplexity
|
34
|
+
def add_managing_role_search_filter(ability:, search_terms: [])
|
35
|
+
search_terms ||= []
|
36
|
+
# Look for managing role assignement
|
37
|
+
managing_role = Sipity::Role.find_by(name: Hyrax::RoleRegistry::MANAGING)
|
38
|
+
return search_terms if managing_role.blank?
|
39
|
+
agent = ability.current_user.to_sipity_agent
|
40
|
+
return search_terms if agent.workflow_responsibilities.blank?
|
41
|
+
managing_workflow_roles = []
|
42
|
+
agent.workflow_responsibilities.each do |workflow_responsibility|
|
43
|
+
wfr = Sipity::WorkflowRole.find_by(id: workflow_responsibility.workflow_role_id)
|
44
|
+
managing_workflow_roles << wfr if wfr.role_id == managing_role.id
|
45
|
+
end
|
46
|
+
return search_terms if managing_workflow_roles.empty?
|
47
|
+
# if the user has managing responsibilties, then look up the associated admin set ids
|
48
|
+
admin_set_ids = managing_workflow_roles.map do |wfr|
|
49
|
+
wf = Sipity::Workflow.find_by(id: wfr.workflow_id)
|
50
|
+
pt = Hyrax::PermissionTemplate.find_by(id: wf.permission_template_id)
|
51
|
+
pt.source_id
|
52
|
+
end
|
53
|
+
admin_set_ids.uniq!
|
54
|
+
# create search terms for works that are in managed admin sets
|
55
|
+
admin_set_ids.each do |id|
|
56
|
+
search_terms << "isPartOf_ssim:#{id}"
|
57
|
+
end
|
58
|
+
search_terms
|
59
|
+
end
|
60
|
+
# rubocop:enable Metrics/MethodLength
|
61
|
+
# rubocop:enable Metrics/PerceivedComplexity
|
62
|
+
# rubocop:enable Metrics/CyclomaticComplexity
|
23
63
|
end
|
24
64
|
end
|
25
65
|
end
|
@@ -37,7 +37,7 @@ module Hyrax
|
|
37
37
|
|
38
38
|
def limit_ids
|
39
39
|
# exclude current collection from returned list
|
40
|
-
limit_ids = [@collection.id]
|
40
|
+
limit_ids = [@collection.id.to_s]
|
41
41
|
# cannot add a parent that is already a parent
|
42
42
|
limit_ids += @nesting_attributes.parents if @nesting_attributes.parents && @nest_direction == :as_parent
|
43
43
|
limit_ids
|
@@ -91,7 +91,7 @@ module Hyrax
|
|
91
91
|
|
92
92
|
def exclude_if_already_parent
|
93
93
|
# 2) Exclude any of Collection F's direct children
|
94
|
-
"-" + ActiveFedora::SolrQueryBuilder.construct_query(Samvera::NestingIndexer.configuration.solr_field_name_for_storing_parent_ids => @collection.id)
|
94
|
+
"-" + ActiveFedora::SolrQueryBuilder.construct_query(Samvera::NestingIndexer.configuration.solr_field_name_for_storing_parent_ids => @collection.id.to_s)
|
95
95
|
end
|
96
96
|
end
|
97
97
|
end
|
@@ -10,10 +10,7 @@ class Hyrax::My::CollectionsSearchBuilder < ::Hyrax::CollectionSearchBuilder
|
|
10
10
|
# the current user has deposited
|
11
11
|
# @param [Hash] solr_parameters
|
12
12
|
def show_only_collections_deposited_by_current_user(solr_parameters)
|
13
|
-
clauses = [
|
14
|
-
ActiveFedora::SolrQueryBuilder.construct_query_for_rel(depositor: current_user_key),
|
15
|
-
ActiveFedora::SolrQueryBuilder.construct_query_for_rel(has_model: ::AdminSet.to_s, creator: current_user_key)
|
16
|
-
]
|
13
|
+
clauses = [query_for_my_collections]
|
17
14
|
solr_parameters[:fq] ||= []
|
18
15
|
solr_parameters[:fq] += ["(#{clauses.join(' OR ')})"]
|
19
16
|
end
|
@@ -21,6 +18,16 @@ class Hyrax::My::CollectionsSearchBuilder < ::Hyrax::CollectionSearchBuilder
|
|
21
18
|
# This overrides the models in FilterByType
|
22
19
|
# @return [Array<Class>] a list of classes to include
|
23
20
|
def models
|
24
|
-
[::AdminSet, Hyrax::AdministrativeSet, Hyrax.config.
|
21
|
+
[::AdminSet, Hyrax::AdministrativeSet, ::Collection, Hyrax.config.collection_class].uniq.compact
|
22
|
+
end
|
23
|
+
|
24
|
+
private
|
25
|
+
|
26
|
+
def query_for_my_collections
|
27
|
+
query_service = Hyrax::SolrQueryService.new
|
28
|
+
query_service.with_field_pairs(field_pairs: { depositor_ssim: current_user_key }, type: 'terms')
|
29
|
+
query_service.with_field_pairs(field_pairs: { has_model_ssim: Hyrax.config.admin_set_model,
|
30
|
+
creator_ssim: current_user_key }, type: 'terms')
|
31
|
+
query_service.build(join_with: 'OR')
|
25
32
|
end
|
26
33
|
end
|
@@ -174,6 +174,19 @@ module Hyrax
|
|
174
174
|
true
|
175
175
|
end
|
176
176
|
|
177
|
+
##
|
178
|
+
# @api public
|
179
|
+
#
|
180
|
+
# Deletes the ACL for the resource
|
181
|
+
#
|
182
|
+
# @return [Boolean]
|
183
|
+
def destroy
|
184
|
+
persister.delete(resource: change_set.resource) if change_set.resource.persisted?
|
185
|
+
@change_set = nil
|
186
|
+
|
187
|
+
true
|
188
|
+
end
|
189
|
+
|
177
190
|
private
|
178
191
|
|
179
192
|
##
|
@@ -13,8 +13,9 @@ module Hyrax
|
|
13
13
|
DEFAULT_ID = 'admin_set/default'
|
14
14
|
DEFAULT_TITLE = ['Default Admin Set'].freeze
|
15
15
|
|
16
|
-
class_attribute :permissions_create_service
|
16
|
+
class_attribute :permissions_create_service, :default_admin_set_persister
|
17
17
|
self.permissions_create_service = Hyrax::Collections::PermissionsCreateService
|
18
|
+
self.default_admin_set_persister = Hyrax::DefaultAdministrativeSet
|
18
19
|
|
19
20
|
class << self
|
20
21
|
# @api public
|
@@ -40,16 +41,15 @@ module Hyrax
|
|
40
41
|
# @see Hyrax::AdministrativeSet
|
41
42
|
# @raise [RuntimeError] if admin set cannot be persisted
|
42
43
|
def find_or_create_default_admin_set
|
43
|
-
|
44
|
-
rescue Valkyrie::Persistence::ObjectNotFoundError
|
45
|
-
create_default_admin_set!
|
44
|
+
find_default_admin_set || create_default_admin_set!
|
46
45
|
end
|
47
46
|
|
48
47
|
# @api public
|
49
|
-
#
|
50
|
-
# @
|
48
|
+
# @param id [#to_s] id of the admin set to check
|
49
|
+
# @return [Boolean] true if the id is for the default admin set; otherwise, false
|
51
50
|
def default_admin_set?(id:)
|
52
|
-
id.
|
51
|
+
return false if id.blank?
|
52
|
+
id.to_s == default_admin_set_id
|
53
53
|
end
|
54
54
|
|
55
55
|
# @api public
|
@@ -64,7 +64,7 @@ module Hyrax
|
|
64
64
|
Deprecation.warn("'##{__method__}' will be removed in Hyrax 4.0. " \
|
65
65
|
"Warning: This method may hide runtime errors. " \
|
66
66
|
"Instead, use 'Hyrax::AdminSetCreateService.call!'. ")
|
67
|
-
call!(admin_set: admin_set, creating_user: creating_user, **kwargs).present?
|
67
|
+
call!(admin_set: admin_set_resource(admin_set), creating_user: creating_user, **kwargs).present?
|
68
68
|
rescue RuntimeError => err
|
69
69
|
raise err if default_admin_set?(id: admin_set.id)
|
70
70
|
false
|
@@ -88,18 +88,89 @@ module Hyrax
|
|
88
88
|
# TODO: Parameters admin_set_id and title are defined to support .create_default_admin_set
|
89
89
|
# which is deprecated. When it is removed, the parameters will no longer be required.
|
90
90
|
def create_default_admin_set!(admin_set_id: DEFAULT_ID, title: DEFAULT_TITLE)
|
91
|
-
admin_set =
|
92
|
-
new(admin_set: admin_set, creating_user: nil).create!
|
91
|
+
admin_set = create_admin_set(suggested_id: admin_set_id, title: title)
|
92
|
+
admin_set = new(admin_set: admin_set, creating_user: nil, default_admin_set: true).create!
|
93
|
+
default_admin_set_persister.update(default_admin_set_id: admin_set.id) if save_default?
|
94
|
+
admin_set
|
95
|
+
end
|
96
|
+
|
97
|
+
def save_default?
|
98
|
+
default_admin_set_persister.save_supported?
|
99
|
+
end
|
100
|
+
|
101
|
+
# Create an instance of `Hyrax::AdministrativeSet` with the suggested_id if supported.
|
102
|
+
# @return [Hyrax::AdministrativeSet] the new admin set
|
103
|
+
def create_admin_set(suggested_id:, title:)
|
104
|
+
if suggested_id.blank? || Hyrax.config.disable_wings || !Hyrax.metadata_adapter.is_a?(Wings::Valkyrie::MetadataAdapter)
|
105
|
+
# allow persister to assign id
|
106
|
+
Hyrax::AdministrativeSet.new(title: Array.wrap(title))
|
107
|
+
else
|
108
|
+
# use suggested_id
|
109
|
+
Hyrax::AdministrativeSet.new(id: suggested_id, title: Array.wrap(title))
|
110
|
+
end
|
111
|
+
end
|
112
|
+
|
113
|
+
# Find default AdministrativeSet using saved id
|
114
|
+
# @return [Hyrax::AdministrativeSet] the default admin set; nil if id not saved
|
115
|
+
# @raise [RuntimeError] if an admin set with the saved id doesn't exist
|
116
|
+
def find_default_admin_set
|
117
|
+
id = default_admin_set_id
|
118
|
+
return if id.blank?
|
119
|
+
Hyrax.query_service.find_by(id: id)
|
120
|
+
rescue Valkyrie::Persistence::ObjectNotFoundError
|
121
|
+
# The default ID is DEFAULT_ID when saving is not supported. It is ok
|
122
|
+
# for this default id to be known but not found. The admin set will be
|
123
|
+
# created with DEFAULT_ID by find_or_create_default_admin_set.
|
124
|
+
return unless save_default?
|
125
|
+
|
126
|
+
# id is saved in the default_admin_set_persister's table but doesn't exist
|
127
|
+
# NOTE: This is a corrupt state and shouldn't happen. Manual intervention
|
128
|
+
# is required to determine the correct value for the default admin
|
129
|
+
# set id. The saved id either needs to be updated to the correct
|
130
|
+
# value or deleted to allow a new default admin set to be found
|
131
|
+
# (i.e. an admin set with id DEFAULT_ID) or generated.
|
132
|
+
raise "Corrupt default admin set. Persisted admin set with saved default_admin_set_id doesn't exist."
|
133
|
+
end
|
134
|
+
|
135
|
+
# Find default AdministrativeSet using DEFAULT_ID.
|
136
|
+
# @note Use of hardcoded ID is being deprecated as some Valkyrie adapters
|
137
|
+
# do not support hardcoded IDs (e.g. postgres)
|
138
|
+
# @return [Hyrax::AdministrativeSet] the default admin set; nil if not found
|
139
|
+
def find_unsaved_default_admin_set
|
140
|
+
admin_set = Hyrax.query_service.find_by(id: DEFAULT_ID)
|
141
|
+
default_admin_set_persister.update(default_admin_set_id: DEFAULT_ID) if save_default?
|
142
|
+
admin_set
|
143
|
+
rescue Valkyrie::Persistence::ObjectNotFoundError
|
144
|
+
# a default admin set hasn't been created yet
|
145
|
+
end
|
146
|
+
|
147
|
+
# @return [String | nil] the default admin set id; returns nil if not set
|
148
|
+
# @note For general use, it is better to use `Hyrax.config.default_admin_set_id`.
|
149
|
+
def default_admin_set_id
|
150
|
+
return DEFAULT_ID unless save_default?
|
151
|
+
id = default_admin_set_persister.first&.default_admin_set_id
|
152
|
+
id = find_unsaved_default_admin_set&.id&.to_s if id.blank?
|
153
|
+
id
|
154
|
+
end
|
155
|
+
|
156
|
+
def admin_set_resource(admin_set)
|
157
|
+
case admin_set
|
158
|
+
when Valkyrie::Resource
|
159
|
+
admin_set
|
160
|
+
else
|
161
|
+
admin_set.valkyrie_resource
|
162
|
+
end
|
93
163
|
end
|
94
164
|
end
|
95
165
|
|
96
166
|
# @param admin_set [Hyrax::AdministrativeSet | AdminSet] the admin set to operate on
|
97
167
|
# @param creating_user [User] the user who created the admin set (if any).
|
98
168
|
# @param workflow_importer [#call] imports the workflow
|
99
|
-
def initialize(admin_set:, creating_user:, workflow_importer: default_workflow_importer)
|
100
|
-
@admin_set = admin_set
|
169
|
+
def initialize(admin_set:, creating_user:, workflow_importer: default_workflow_importer, default_admin_set: false)
|
170
|
+
@admin_set = Hyrax::AdminSetCreateService.send(:admin_set_resource, admin_set)
|
101
171
|
@creating_user = creating_user
|
102
172
|
@workflow_importer = workflow_importer
|
173
|
+
@default_admin_set = default_admin_set
|
103
174
|
end
|
104
175
|
|
105
176
|
attr_reader :creating_user, :admin_set, :workflow_importer
|
@@ -120,31 +191,15 @@ module Hyrax
|
|
120
191
|
# @return [Hyrax::AdministrativeSet] The fully created admin set.
|
121
192
|
# @raise [RuntimeError] if admin set cannot be persisted
|
122
193
|
def create!
|
123
|
-
admin_set.respond_to?(:valkyrie_resource) ? active_fedora_create! : valkyrie_create!
|
124
|
-
end
|
125
|
-
|
126
|
-
private
|
127
|
-
|
128
|
-
def default_admin_set?(id:)
|
129
|
-
self.class.default_admin_set?(id: id)
|
130
|
-
end
|
131
|
-
|
132
|
-
def admin_group_name
|
133
|
-
::Ability.admin_group_name
|
134
|
-
end
|
135
|
-
|
136
|
-
# Creates an admin set, setting the creator and the default access controls.
|
137
|
-
# @return [Hyrax::AdministrativeSet] The fully created admin set.
|
138
|
-
# @raise [RuntimeError] if admin set cannot be persisted
|
139
|
-
def valkyrie_create!
|
140
194
|
admin_set.creator = [creating_user.user_key] if creating_user
|
141
195
|
updated_admin_set = Hyrax.persister.save(resource: admin_set).tap do |result|
|
142
196
|
if result
|
143
197
|
ActiveRecord::Base.transaction do
|
144
|
-
permission_template =
|
198
|
+
permission_template = PermissionTemplate.find_by(source_id: result.id.to_s) ||
|
199
|
+
permissions_create_service.create_default(collection: result,
|
145
200
|
creating_user: creating_user)
|
146
201
|
workflow = create_workflows_for(permission_template: permission_template)
|
147
|
-
create_default_access_for(permission_template: permission_template, workflow: workflow) if default_admin_set?
|
202
|
+
create_default_access_for(permission_template: permission_template, workflow: workflow) if default_admin_set?
|
148
203
|
end
|
149
204
|
end
|
150
205
|
end
|
@@ -152,23 +207,14 @@ module Hyrax
|
|
152
207
|
updated_admin_set
|
153
208
|
end
|
154
209
|
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
|
160
|
-
|
161
|
-
|
162
|
-
|
163
|
-
permission_template = permissions_create_service.create_default(collection: admin_set,
|
164
|
-
creating_user: creating_user)
|
165
|
-
workflow = create_workflows_for(permission_template: permission_template)
|
166
|
-
create_default_access_for(permission_template: permission_template, workflow: workflow) if default_admin_set?(id: admin_set.id)
|
167
|
-
end
|
168
|
-
end
|
169
|
-
end
|
170
|
-
raise 'Admin set failed to persist.' unless admin_set.persisted?
|
171
|
-
admin_set.valkyrie_resource
|
210
|
+
private
|
211
|
+
|
212
|
+
def default_admin_set?
|
213
|
+
@default_admin_set
|
214
|
+
end
|
215
|
+
|
216
|
+
def admin_group_name
|
217
|
+
::Ability.admin_group_name
|
172
218
|
end
|
173
219
|
|
174
220
|
def create_workflows_for(permission_template:)
|
@@ -0,0 +1,37 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
module Hyrax
|
3
|
+
module Analytics
|
4
|
+
module Google
|
5
|
+
module Events
|
6
|
+
extend Legato::Model
|
7
|
+
|
8
|
+
metrics :total_events
|
9
|
+
dimensions :event_category, :event_action, :event_label
|
10
|
+
|
11
|
+
# Filter by event id
|
12
|
+
filter :for_id, &->(id) { matches(:eventLabel, id) }
|
13
|
+
|
14
|
+
# Filter by event action
|
15
|
+
filter(:work_view) { |_event_action| matches(:eventAction, 'work-view') }
|
16
|
+
filter(:work_in_collection_view) { |_event_action| matches(:eventAction, 'work-in-collection-view') }
|
17
|
+
filter(:collection_page_view) { |_event_action| matches(:eventAction, 'collection-page-view') }
|
18
|
+
filter(:file_set_download) { |_event_action| matches(:eventAction, 'file-set-download') }
|
19
|
+
filter(:work_in_collection_download) { |_event_action| matches(:eventAction, 'work-in-collection-download') }
|
20
|
+
filter(:file_set_in_work_download) { |_event_action| matches(:eventAction, 'file-set-in-work-download') }
|
21
|
+
filter(:collection_file_download) { |_event_action| matches(:eventAction, 'file-set-in-collection-download') }
|
22
|
+
|
23
|
+
def self.list(profile, start_date, end_date, action)
|
24
|
+
action = action.underscore
|
25
|
+
results = []
|
26
|
+
Events.results(profile,
|
27
|
+
start_date: start_date,
|
28
|
+
end_date: end_date,
|
29
|
+
sort: ['-totalEvents']).send(action).each do |result|
|
30
|
+
results.push([result.eventLabel, result.totalEvents.to_i])
|
31
|
+
end
|
32
|
+
results
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
@@ -0,0 +1,72 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
module Hyrax
|
3
|
+
module Analytics
|
4
|
+
module Google
|
5
|
+
module EventsDaily
|
6
|
+
extend Legato::Model
|
7
|
+
|
8
|
+
metrics :total_events
|
9
|
+
dimensions :date, :event_category, :event_action
|
10
|
+
|
11
|
+
# Filter by event id
|
12
|
+
filter :for_id, &->(id) { matches(:eventLabel, id) }
|
13
|
+
|
14
|
+
# Filter by event action
|
15
|
+
filter(:work_view) { |_event_action| matches(:eventAction, 'work-view') }
|
16
|
+
filter(:work_in_collection_view) { |_event_action| matches(:eventAction, 'work-in-collection-view') }
|
17
|
+
filter(:collection_page_view) { |_event_action| matches(:eventAction, 'collection-page-view') }
|
18
|
+
filter(:file_set_download) { |_event_action| matches(:eventAction, 'file-set-download') }
|
19
|
+
filter(:work_in_collection_download) { |_event_action| matches(:eventAction, 'work-in-collection-download') }
|
20
|
+
filter(:file_set_in_work_download) { |_event_action| matches(:eventAction, 'file-set-in-work-download') }
|
21
|
+
filter(:collection_file_download) { |_event_action| matches(:eventAction, 'file-set-in-collection-download') }
|
22
|
+
|
23
|
+
# returns a daily number of events for a specific action
|
24
|
+
def self.summary(profile, start_date, end_date, action)
|
25
|
+
action = action.underscore
|
26
|
+
response = EventsDaily.results(profile,
|
27
|
+
start_date: start_date,
|
28
|
+
end_date: end_date).send(action)
|
29
|
+
dates = (start_date.to_date...end_date.to_date)
|
30
|
+
results_array(response, dates)
|
31
|
+
end
|
32
|
+
|
33
|
+
# returns a daily number of events for a specific action
|
34
|
+
def self.by_id(profile, start_date, end_date, id, action)
|
35
|
+
action = action.underscore
|
36
|
+
response = EventsDaily.results(profile,
|
37
|
+
start_date: start_date,
|
38
|
+
end_date: end_date).for_id(id).send(action)
|
39
|
+
dates = (start_date.to_date...end_date.to_date)
|
40
|
+
results_array(response, dates)
|
41
|
+
end
|
42
|
+
|
43
|
+
# def self.pageviews(profile, start_date, end_date, ref)
|
44
|
+
# ref = ref.underscore
|
45
|
+
# response = PageviewsDaily.results(profile,
|
46
|
+
# start_date: start_date,
|
47
|
+
# end_date: end_date).send(ref)
|
48
|
+
# dates = (start_date.to_date...end_date.to_date)
|
49
|
+
# results_array(response, dates)
|
50
|
+
# end
|
51
|
+
|
52
|
+
# takes all the dates in between the date range and generate an array [date, totalEvents]
|
53
|
+
def self.results_array(response, dates)
|
54
|
+
results = []
|
55
|
+
response.to_a.each do |result|
|
56
|
+
results.push([result.date.to_date, result.totalEvents.to_i])
|
57
|
+
end
|
58
|
+
new_results = []
|
59
|
+
dates.each do |date|
|
60
|
+
match = results.detect { |a, _b| a == date }
|
61
|
+
if match
|
62
|
+
new_results.push(match)
|
63
|
+
else
|
64
|
+
new_results.push([date, 0])
|
65
|
+
end
|
66
|
+
end
|
67
|
+
Hyrax::Analytics::Results.new(new_results)
|
68
|
+
end
|
69
|
+
end
|
70
|
+
end
|
71
|
+
end
|
72
|
+
end
|
@@ -0,0 +1,44 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
module Hyrax
|
3
|
+
module Analytics
|
4
|
+
module Google
|
5
|
+
module Visits
|
6
|
+
extend Legato::Model
|
7
|
+
|
8
|
+
dimensions :user_type
|
9
|
+
metrics :sessions
|
10
|
+
|
11
|
+
def self.results_array(response)
|
12
|
+
results = []
|
13
|
+
response.to_a.each do |result|
|
14
|
+
results.push([result.date.to_date, result.result.sessions.to_i])
|
15
|
+
end
|
16
|
+
Hyrax::Analytics::Results.new(results)
|
17
|
+
end
|
18
|
+
|
19
|
+
def self.new_visits(profile, start_date, end_date)
|
20
|
+
x = Visits.results(profile,
|
21
|
+
start_date: start_date,
|
22
|
+
end_date: end_date).to_a
|
23
|
+
x.first.sessions.to_i
|
24
|
+
end
|
25
|
+
|
26
|
+
def self.return_visits(profile, start_date, end_date)
|
27
|
+
x = Visits.results(profile,
|
28
|
+
start_date: start_date,
|
29
|
+
end_date: end_date).to_a
|
30
|
+
x.last.sessions.to_i
|
31
|
+
end
|
32
|
+
|
33
|
+
def self.total_visits(profile, start_date, end_date)
|
34
|
+
x = Visits.results(profile,
|
35
|
+
start_date: start_date,
|
36
|
+
end_date: end_date).to_a
|
37
|
+
new_visits = x.first.sessions.to_i
|
38
|
+
returning_visits = x.last.sessions.to_i
|
39
|
+
new_visits + returning_visits
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
@@ -0,0 +1,49 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
module Hyrax
|
3
|
+
module Analytics
|
4
|
+
module Google
|
5
|
+
module VisitsDaily
|
6
|
+
extend Legato::Model
|
7
|
+
|
8
|
+
dimensions :date, :user_type
|
9
|
+
metrics :sessions
|
10
|
+
|
11
|
+
filter(:returning) { |_user_type| matches(:userType, 'Returning Visitor') }
|
12
|
+
filter(:new_visit) { |_user_type| matches(:userType, 'New Visitor') }
|
13
|
+
|
14
|
+
def self.new_visits(profile, start_date, end_date)
|
15
|
+
response = VisitsDaily.results(profile,
|
16
|
+
start_date: start_date,
|
17
|
+
end_date: end_date).new_visit.to_a
|
18
|
+
dates = (start_date.to_date...end_date.to_date)
|
19
|
+
results_array(response, dates)
|
20
|
+
end
|
21
|
+
|
22
|
+
def self.return_visits(profile, start_date, end_date)
|
23
|
+
response = VisitsDaily.results(profile,
|
24
|
+
start_date: start_date,
|
25
|
+
end_date: end_date).returning.to_a
|
26
|
+
dates = (start_date.to_date...end_date.to_date)
|
27
|
+
results_array(response, dates)
|
28
|
+
end
|
29
|
+
|
30
|
+
def self.results_array(response, dates)
|
31
|
+
results = []
|
32
|
+
response.to_a.each do |result|
|
33
|
+
results.push([result.date.to_date, result.sessions.to_i])
|
34
|
+
end
|
35
|
+
new_results = []
|
36
|
+
dates.each do |date|
|
37
|
+
match = results.detect { |a, _b| a == date }
|
38
|
+
if match
|
39
|
+
new_results.push(match)
|
40
|
+
else
|
41
|
+
new_results.push([date, 0])
|
42
|
+
end
|
43
|
+
end
|
44
|
+
Hyrax::Analytics::Results.new(new_results)
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|