hydra-head 3.0.0pre3 → 3.0.0pre4
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitmodules +0 -3
- data/.rvmrc +6 -0
- data/BLACKLIGHT_CONFIG.textile +76 -0
- data/CREATE_RAILS_APP.textile +323 -0
- data/DEVELOP_PLUGIN.textile +90 -0
- data/GIT_WORKFLOW.textile +84 -0
- data/Gemfile.lock +82 -66
- data/HISTORY.textile +7 -0
- data/HOW_DO_I.textile +107 -0
- data/HOW_TO_DEFINE_A_HYDRA_CONTROLLER.textile +21 -0
- data/HOW_TO_DEFINE_A_HYDRA_MODEL.textile +64 -0
- data/HOW_TO_GET_STARTED.textile +100 -76
- data/INITIAL_APP_MODS.textile +60 -76
- data/INSTALL_PREREQ.textile +19 -0
- data/LICENSE +14 -0
- data/README.textile +89 -17
- data/README_RAKE_TASKS.textile +107 -0
- data/README_SUBTREE.textile +87 -0
- data/README_TERSE.textile +92 -0
- data/TESTING_PLUGIN.textile +134 -0
- data/app/controllers/assets_controller.rb +34 -4
- data/app/controllers/contributors_controller.rb +49 -1
- data/app/controllers/downloads_controller.rb +36 -0
- data/app/controllers/file_assets_controller.rb +43 -21
- data/app/controllers/generic_content_objects_controller.rb +38 -0
- data/app/controllers/get_controller.rb +39 -0
- data/app/controllers/permissions_controller.rb +33 -4
- data/app/controllers/user_sessions_controller.rb +0 -1
- data/app/helpers/application_helper.rb +183 -0
- data/app/helpers/blacklight_helper.rb +13 -8
- data/app/helpers/hydra_assets_helper.rb +6 -15
- data/app/helpers/hydra_fedora_metadata_helper.rb +51 -67
- data/app/helpers/hydra_helper.rb +35 -11
- data/app/helpers/javascript_includes_helper.rb +2 -4
- data/app/helpers/personalization_helper.rb +44 -0
- data/app/models/generic_content.rb +6 -3
- data/app/models/generic_image.rb +3 -1
- data/app/models/mods_asset.rb +12 -1
- data/app/models/user_attribute.rb +25 -0
- data/app/models/uses_default_partials.rb +14 -0
- data/app/views/_add_assets_links.html.erb +1 -0
- data/app/views/catalog/_edit_partials/_default.html.erb +5 -5
- data/app/views/catalog/_home_text.html.erb +2 -2
- data/app/views/catalog/_index_partials/_default_details.html.erb +10 -7
- data/app/views/catalog/_opensearch_response_metadata.html.erb +2 -0
- data/app/views/catalog/_search_form.html.erb +1 -1
- data/app/views/catalog/_show_partials/_default.html.erb +4 -2
- data/app/views/catalog/_show_partials/_default_details.html.erb +10 -7
- data/app/views/catalog/show.html.erb +20 -28
- data/app/views/contributors/_edit_person.html.erb +26 -29
- data/app/views/contributors/_index.html.erb +6 -7
- data/app/views/contributors/_show_conference.html.erb +5 -15
- data/app/views/contributors/_show_organization.html.erb +8 -16
- data/app/views/file_assets/_file_assets_form.html.erb +11 -0
- data/app/views/file_assets/_index.html.erb +21 -6
- data/app/views/file_assets/_new.html.erb +6 -2
- data/app/views/file_assets/_result.html.erb +2 -2
- data/app/views/fluid_infusion/_uploader.html.erb +4 -5
- data/app/views/generic_content_objects/_contributor_form.html.erb +11 -0
- data/app/views/generic_content_objects/_description_form.html.erb +7 -0
- data/app/views/generic_content_objects/_edit_description.html.erb +14 -41
- data/app/views/generic_content_objects/_show_description.html.erb +38 -63
- data/app/views/generic_contents/_edit.html.erb +1 -45
- data/app/views/generic_contents/_edit.html.erb_ +39 -0
- data/app/views/generic_contents/_index.html.erb +1 -3
- data/app/views/generic_contents/_show.html.erb +4 -14
- data/app/views/generic_contents/_show_content.html.erb +7 -4
- data/app/views/generic_images/_edit.html.erb +26 -32
- data/app/views/generic_images/_show.html.erb +7 -10
- data/app/views/generic_images/_show_all.html.erb +1 -1
- data/app/views/generic_images/_show_content.html.erb +7 -7
- data/app/views/layouts/application.html.erb +33 -41
- data/app/views/layouts/hydra-head.html.erb +52 -7
- data/app/views/mods_assets/_additional_info_form.html.erb +44 -0
- data/app/views/mods_assets/_contributor_form.html.erb +14 -0
- data/app/views/mods_assets/_edit.html.erb +8 -32
- data/app/views/mods_assets/_edit.html.erb_ +63 -0
- data/app/views/mods_assets/_edit_description.html.erb +52 -61
- data/app/views/mods_assets/_edit_journal.html.erb +49 -64
- data/app/views/mods_assets/_publication_form.html.erb +13 -0
- data/app/views/mods_assets/_show.html.erb +18 -23
- data/app/views/mods_assets/_show_additional_info.html.erb +17 -0
- data/app/views/mods_assets/_show_contributors.html.erb +7 -0
- data/app/views/mods_assets/_show_description.html.erb +3 -13
- data/app/views/mods_assets/_show_file_assets.html.erb +22 -0
- data/app/views/mods_assets/_show_journal.html.erb +3 -3
- data/app/views/mods_assets/_show_permissions.html.erb +1 -0
- data/app/views/mods_assets/_show_publication.html.erb +8 -0
- data/app/views/permissions/_edit_person_permissions.html.erb +4 -9
- data/app/views/permissions/_index.html.erb +9 -18
- data/app/views/permissions/_new.html.erb +13 -17
- data/app/views/permissions/_permissions_form.html.erb +24 -0
- data/app/views/user_sessions/_login_form.html.erb +1 -1
- data/assets/images/hydra/powered_by_hydra.png +0 -0
- data/assets/images/hydra/search-button.png +0 -0
- data/assets/javascripts/date-picker/booking/index.html +368 -0
- data/assets/javascripts/date-picker/calendarHTML.txt +84 -0
- data/assets/javascripts/date-picker/css/datepicker.css +511 -0
- data/assets/javascripts/date-picker/css/demo.css +229 -0
- data/assets/javascripts/date-picker/index.html +798 -0
- data/assets/javascripts/date-picker/js/datepicker.js +2898 -0
- data/assets/javascripts/date-picker/js/datepicker.packed.js +1 -0
- data/assets/javascripts/date-picker/js/lang/ar.js +9 -0
- data/assets/javascripts/date-picker/js/lang/cs.js +9 -0
- data/assets/javascripts/date-picker/js/lang/da.js +10 -0
- data/assets/javascripts/date-picker/js/lang/de.js +10 -0
- data/assets/javascripts/date-picker/js/lang/en.js +9 -0
- data/assets/javascripts/date-picker/js/lang/eo.js +13 -0
- data/assets/javascripts/date-picker/js/lang/es.js +9 -0
- data/assets/javascripts/date-picker/js/lang/et.js +23 -0
- data/assets/javascripts/date-picker/js/lang/fi.js +7 -0
- data/assets/javascripts/date-picker/js/lang/fr.js +69 -0
- data/assets/javascripts/date-picker/js/lang/he.js +9 -0
- data/assets/javascripts/date-picker/js/lang/hu.js +9 -0
- data/assets/javascripts/date-picker/js/lang/id.js +9 -0
- data/assets/javascripts/date-picker/js/lang/it.js +11 -0
- data/assets/javascripts/date-picker/js/lang/kr.js +9 -0
- data/assets/javascripts/date-picker/js/lang/lt.js +8 -0
- data/assets/javascripts/date-picker/js/lang/lv.js +9 -0
- data/assets/javascripts/date-picker/js/lang/nl.js +9 -0
- data/assets/javascripts/date-picker/js/lang/no.js +9 -0
- data/assets/javascripts/date-picker/js/lang/pl.js +10 -0
- data/assets/javascripts/date-picker/js/lang/pt-br.js +11 -0
- data/assets/javascripts/date-picker/js/lang/pt.js +9 -0
- data/assets/javascripts/date-picker/js/lang/ru.js +11 -0
- data/assets/javascripts/date-picker/js/lang/se.js +9 -0
- data/assets/javascripts/date-picker/js/lang/si.js +9 -0
- data/assets/javascripts/date-picker/js/lang/tr.js +9 -0
- data/assets/javascripts/date-picker/language/index.html +240 -0
- data/assets/javascripts/date-picker/media/Thumbs.db +0 -0
- data/assets/javascripts/date-picker/media/backstripes.gif +0 -0
- data/assets/javascripts/date-picker/media/bg_header.jpg +0 -0
- data/assets/javascripts/date-picker/media/bullet1.gif +0 -0
- data/assets/javascripts/date-picker/media/bullet2.gif +0 -0
- data/assets/javascripts/date-picker/media/cal-grey.gif +0 -0
- data/assets/javascripts/date-picker/media/cal.gif +0 -0
- data/assets/javascripts/date-picker/media/gradient-e5e5e5-ffffff.gif +0 -0
- data/assets/javascripts/hydra/hydra-head.js +195 -0
- data/assets/javascripts/hydra/mediashelf.datepicker.js +39 -0
- data/assets/javascripts/hydra/mediashelf.placeholder.js +67 -0
- data/assets/javascripts/jquery.form.js +675 -0
- data/assets/javascripts/jquery.ui.datepicker.js +1793 -0
- data/assets/javascripts/spin.min.js +2 -0
- data/assets/stylesheets/hydra/html_refactor.css +115 -0
- data/assets/stylesheets/hydra/hydrangea-split-button.css +18 -0
- data/assets/stylesheets/hydra/hydrangea.css +292 -0
- data/assets/stylesheets/hydra/ie-styles.css +240 -0
- data/assets/stylesheets/hydra/styles.css +2224 -0
- data/assets/stylesheets/redmond/images/ui-bg_flat_0_aaaaaa_40x100.png +0 -0
- data/assets/stylesheets/redmond/images/ui-bg_flat_55_fbec88_40x100.png +0 -0
- data/assets/stylesheets/redmond/images/ui-bg_glass_75_d0e5f5_1x400.png +0 -0
- data/assets/stylesheets/redmond/images/ui-bg_glass_85_dfeffc_1x400.png +0 -0
- data/assets/stylesheets/redmond/images/ui-bg_glass_95_fef1ec_1x400.png +0 -0
- data/assets/stylesheets/redmond/images/ui-bg_gloss-wave_55_5c9ccc_500x100.png +0 -0
- data/assets/stylesheets/redmond/images/ui-bg_inset-hard_100_f5f8f9_1x100.png +0 -0
- data/assets/stylesheets/redmond/images/ui-bg_inset-hard_100_fcfdfd_1x100.png +0 -0
- data/assets/stylesheets/redmond/images/ui-icons_217bc0_256x240.png +0 -0
- data/assets/stylesheets/redmond/images/ui-icons_2e83ff_256x240.png +0 -0
- data/assets/stylesheets/redmond/images/ui-icons_469bdd_256x240.png +0 -0
- data/assets/stylesheets/redmond/images/ui-icons_6da8d5_256x240.png +0 -0
- data/assets/stylesheets/redmond/images/ui-icons_cd0a0a_256x240.png +0 -0
- data/assets/stylesheets/redmond/images/ui-icons_d8e7f3_256x240.png +0 -0
- data/assets/stylesheets/redmond/images/ui-icons_f9bd01_256x240.png +0 -0
- data/assets/stylesheets/redmond/jquery-ui-1.8.5.custom.css +572 -0
- data/config/fedora.yml +17 -0
- data/config/role_map_cucumber.yml +10 -0
- data/config/role_map_development.yml +12 -0
- data/config/role_map_production.yml +2 -0
- data/config/role_map_test.yml +14 -0
- data/config/solr.yml +10 -0
- data/config/solr_mappings.yml +22 -0
- data/db/migrate/20101105214243_add_user_attributes_table.rb +15 -0
- data/db/migrate/20101108192527_create_superusers.rb +12 -0
- data/fedora/conf/fedora.fcfg +1021 -0
- data/hydra-head.gemspec +7 -4
- data/init.rb +4 -0
- data/install.rb +1 -0
- data/lib/blacklight/catalog_helper.rb +44 -0
- data/lib/blacklight.rb +40 -0
- data/lib/block_mapper.rb +52 -0
- data/lib/djatoka.rb +59 -0
- data/lib/ead_mapper.rb +7 -0
- data/lib/field_maps.rb +507 -0
- data/lib/generators/hydra/assets_generator.rb +51 -0
- data/lib/generators/hydra/head_generator.rb +23 -4
- data/lib/generators/hydra/templates/config/initializers/blacklight_config.rb +2 -2
- data/lib/generators/hydra/templates/config/initializers/hydra_config.rb +26 -0
- data/lib/hydra/access_controls_enforcement.rb +3 -2
- data/lib/hydra/assets_controller_helper.rb +6 -0
- data/lib/hydra/catalog.rb +7 -3
- data/lib/hydra/controller.rb +27 -0
- data/lib/hydra/file_assets_helper.rb +25 -8
- data/lib/hydra/generic_user_attributes.rb +34 -0
- data/lib/hydra/model_methods.rb +4 -2
- data/lib/hydra/mods_article.rb +5 -2
- data/lib/hydra/submission_workflow.rb +137 -0
- data/lib/hydra-head/controller.rb +30 -0
- data/lib/hydra-head/engine.rb +22 -1
- data/lib/hydra-head/routes.rb +14 -3
- data/lib/hydra-head/version.rb +1 -1
- data/lib/hydra-head.rb +3 -3
- data/lib/hydra.rb +1 -1
- data/lib/jetty_cleaner.rb +27 -0
- data/lib/marc_mapper.rb +131 -0
- data/lib/marc_record_ext.rb +97 -0
- data/lib/mediashelf/active_fedora_helper.rb +7 -1
- data/lib/prev_next_links.rb +22 -0
- data/lib/railties/hydra-fixtures.rake +6 -1
- data/lib/railties/hyhead_cucumber.rake +1 -2
- data/lib/railties/hyhead_rspec.rake +7 -7
- data/lib/stanford_blacklight_extensions.rb +6 -0
- data/lib/user_attributes_loader.rb +17 -0
- data/solr/conf/schema.xml +116 -0
- data/solr/conf/solrconfig.xml +311 -0
- data/solr/solr.xml +35 -0
- data/spec/controllers/catalog_valid_html_spec.rb +128 -0
- data/spec-rails2/helpers/hydra_fedora_metadata_helper_spec.rb +219 -0
- data/spec-rails2/spec_helper.rb +88 -0
- data/tasks/hydra-head.rake +2 -4
- data/test_support/etc/Gemfile +6 -5
- data/test_support/features/absent_model_edit.feature +27 -0
- data/test_support/features/absent_model_search_result.feature +24 -0
- data/test_support/features/absent_model_show.feature +27 -0
- data/test_support/features/button_add_assets.feature +2 -2
- data/test_support/features/contributor_add.feature +21 -16
- data/test_support/features/default_partials_edit.feature +27 -0
- data/test_support/features/default_partials_search_result.feature +22 -0
- data/test_support/features/default_partials_show.feature +24 -0
- data/test_support/features/file_upload.feature +55 -22
- data/test_support/features/generic_content_create.feature +7 -0
- data/test_support/features/generic_content_edit.feature +21 -0
- data/test_support/features/generic_content_search_result.feature +22 -0
- data/test_support/features/generic_content_show.feature +20 -0
- data/test_support/features/generic_image_create.feature +7 -0
- data/test_support/features/generic_image_edit.feature +21 -0
- data/test_support/features/generic_image_search_result.feature +22 -0
- data/test_support/features/generic_image_show.feature +20 -0
- data/test_support/features/html_validity.feature +43 -0
- data/test_support/features/mods_asset_contributors_edit.feature +27 -19
- data/test_support/features/mods_asset_create.feature +13 -8
- data/test_support/features/mods_asset_edit.feature +48 -16
- data/test_support/features/mods_asset_edit_without_permission.feature +6 -1
- data/test_support/features/mods_asset_search_result.feature +15 -15
- data/test_support/features/mods_asset_show.feature +56 -5
- data/test_support/features/permissions_add.feature +5 -4
- data/test_support/features/permissions_edit.feature +9 -7
- data/test_support/features/step_definitions/html_validity_steps.rb +57 -0
- data/test_support/features/step_definitions/show_document_steps.rb +1 -1
- data/test_support/features/step_definitions/user_steps.rb +4 -4
- data/test_support/features/support/paths.rb +4 -1
- data/test_support/fixtures/hydra_test_default_partials.foxml.xml +80 -0
- data/test_support/fixtures/hydra_test_generic_content.foxml.xml +138 -0
- data/test_support/fixtures/hydra_test_generic_image.foxml.xml +395 -0
- data/test_support/fixtures/hydra_test_no_model.foxml.xml +79 -0
- data/test_support/fixtures/hydrus_admin_class1.foxml.xml +176 -0
- data/test_support/fixtures/libra-oa_7.foxml.xml +1735 -0
- data/test_support/spec/controllers/assets_controller_spec.rb +5 -4
- data/test_support/spec/controllers/catalog_controller_spec.rb +2 -2
- data/test_support/spec/controllers/file_assets_controller_spec.rb +16 -10
- data/test_support/spec/controllers/hydra_controller_spec.rb +2 -0
- data/test_support/spec/controllers/permissions_controller_spec.rb +1 -1
- data/test_support/spec/helpers/access_controls_enforcement_spec.rb +20 -219
- data/test_support/spec/helpers/blacklight_helper_spec.rb +3 -1
- data/test_support/spec/helpers/file_assets_helper_spec.rb +13 -10
- data/test_support/spec/helpers/hydra_assets_helper_spec.rb +5 -1
- data/test_support/spec/helpers/hydra_djatoka_helper_spec.rb +3 -1
- data/test_support/spec/helpers/hydra_fedora_metadata_helper_spec.rb +102 -69
- data/test_support/spec/helpers/hydra_helper_spec.rb +15 -0
- data/test_support/spec/lib/hydra_submission_workflow_spec.rb +141 -0
- data/test_support/spec/models/generic_image_spec.rb +6 -1
- data/uninstall.rb +1 -0
- data/vendor/cache/actionmailer-3.0.10.gem +0 -0
- data/vendor/cache/actionpack-3.0.10.gem +0 -0
- data/vendor/cache/activemodel-3.0.10.gem +0 -0
- data/vendor/cache/activerecord-3.0.10.gem +0 -0
- data/vendor/cache/activeresource-3.0.10.gem +0 -0
- data/vendor/cache/activesupport-3.0.10.gem +0 -0
- data/vendor/cache/capybara-1.1.1.gem +0 -0
- data/vendor/cache/childprocess-0.2.2.gem +0 -0
- data/vendor/cache/crack-0.3.1.gem +0 -0
- data/vendor/cache/cucumber-1.1.0.gem +0 -0
- data/vendor/cache/cucumber-rails-1.1.1.gem +0 -0
- data/vendor/cache/diff-lcs-1.1.3.gem +0 -0
- data/vendor/cache/equivalent-xml-0.2.8.gem +0 -0
- data/vendor/cache/factory_girl-2.1.2.gem +0 -0
- data/vendor/cache/gherkin-2.5.2.gem +0 -0
- data/vendor/cache/haml-3.1.3.gem +0 -0
- data/vendor/cache/httparty-0.8.1.gem +0 -0
- data/vendor/cache/json-1.6.1.gem +0 -0
- data/vendor/cache/json_pure-1.6.1.gem +0 -0
- data/vendor/cache/launchy-2.0.5.gem +0 -0
- data/vendor/cache/mediashelf-loggable-0.4.7.gem +0 -0
- data/vendor/cache/metaclass-0.0.1.gem +0 -0
- data/vendor/cache/mocha-0.10.0.gem +0 -0
- data/vendor/cache/multi_json-1.0.3.gem +0 -0
- data/vendor/cache/multi_xml-0.4.1.gem +0 -0
- data/vendor/cache/om-1.4.2.gem +0 -0
- data/vendor/cache/polyglot-0.3.2.gem +0 -0
- data/vendor/cache/rack-1.2.4.gem +0 -0
- data/vendor/cache/{rails-3.0.9.gem → rails-3.0.10.gem} +0 -0
- data/vendor/cache/railties-3.0.10.gem +0 -0
- data/vendor/cache/rcov-0.9.11.gem +0 -0
- data/vendor/cache/rdoc-3.10.gem +0 -0
- data/vendor/cache/rest-client-1.6.7.gem +0 -0
- data/vendor/cache/selenium-webdriver-2.8.0.gem +0 -0
- data/vendor/cache/solrizer-1.1.2.gem +0 -0
- data/vendor/cache/solrizer-fedora-1.1.2.gem +0 -0
- data/vendor/cache/sqlite3-1.3.4.gem +0 -0
- data/vendor/cache/term-ansicolor-1.0.7.gem +0 -0
- data/vendor/cache/treetop-1.4.10.gem +0 -0
- data/vendor/cache/tzinfo-0.3.30.gem +0 -0
- data/vendor/cache/will_paginate-3.0.2.gem +0 -0
- data/vendor/cache/xml-simple-1.1.1.gem +0 -0
- metadata +351 -121
- data/lib/engine.rb +0 -30
- data/test_support/features/file_assets_list.feature +0 -32
- data/vendor/cache/actionmailer-3.0.9.gem +0 -0
- data/vendor/cache/actionpack-3.0.9.gem +0 -0
- data/vendor/cache/activemodel-3.0.9.gem +0 -0
- data/vendor/cache/activerecord-3.0.9.gem +0 -0
- data/vendor/cache/activeresource-3.0.9.gem +0 -0
- data/vendor/cache/activesupport-3.0.9.gem +0 -0
- data/vendor/cache/capybara-1.0.0.gem +0 -0
- data/vendor/cache/childprocess-0.2.0.gem +0 -0
- data/vendor/cache/crack-0.1.8.gem +0 -0
- data/vendor/cache/cucumber-1.0.2.gem +0 -0
- data/vendor/cache/cucumber-rails-1.0.2.gem +0 -0
- data/vendor/cache/diff-lcs-1.1.2.gem +0 -0
- data/vendor/cache/equivalent-xml-0.2.7.gem +0 -0
- data/vendor/cache/factory_girl-1.3.3.gem +0 -0
- data/vendor/cache/gherkin-2.4.5.gem +0 -0
- data/vendor/cache/haml-3.1.2.gem +0 -0
- data/vendor/cache/httparty-0.7.8.gem +0 -0
- data/vendor/cache/json-1.5.3.gem +0 -0
- data/vendor/cache/json_pure-1.5.3.gem +0 -0
- data/vendor/cache/launchy-2.0.4.gem +0 -0
- data/vendor/cache/mediashelf-loggable-0.4.3.gem +0 -0
- data/vendor/cache/mocha-0.9.12.gem +0 -0
- data/vendor/cache/om-1.2.5.gem +0 -0
- data/vendor/cache/polyglot-0.3.1.gem +0 -0
- data/vendor/cache/rack-1.2.3.gem +0 -0
- data/vendor/cache/railties-3.0.9.gem +0 -0
- data/vendor/cache/rcov-0.9.9.gem +0 -0
- data/vendor/cache/rdoc-3.8.gem +0 -0
- data/vendor/cache/selenium-webdriver-0.2.2.gem +0 -0
- data/vendor/cache/solrizer-1.1.0.gem +0 -0
- data/vendor/cache/solrizer-fedora-1.1.0.gem +0 -0
- data/vendor/cache/term-ansicolor-1.0.5.gem +0 -0
- data/vendor/cache/treetop-1.4.9.gem +0 -0
- data/vendor/cache/tzinfo-0.3.29.gem +0 -0
- data/vendor/cache/will_paginate-2.3.15.gem +0 -0
- data/vendor/cache/xml-simple-1.1.0.gem +0 -0
data/hydra-head.gemspec
CHANGED
@@ -12,7 +12,7 @@ Gem::Specification.new do |s|
|
|
12
12
|
s.summary = %q{Hydra-Head Rails Engine (requires Rails3) }
|
13
13
|
s.description = %q{Hydra-Head is a Rails Engine containing the core code for a Hydra application. The full hydra stack includes: Blacklight, Fedora, Solr, active-fedora, solrizer, and om}
|
14
14
|
|
15
|
-
s.add_dependency "rails", '
|
15
|
+
s.add_dependency "rails", '~> 3.0.10'
|
16
16
|
s.add_dependency "blacklight", '3.0.0'
|
17
17
|
s.add_dependency "active-fedora", '>= 2.3.3'
|
18
18
|
s.add_dependency 'builder'
|
@@ -28,6 +28,7 @@ Gem::Specification.new do |s|
|
|
28
28
|
s.add_dependency 'launchy'
|
29
29
|
s.add_dependency 'linecache'
|
30
30
|
s.add_dependency 'mime-types'
|
31
|
+
s.add_dependency 'mediashelf-loggable', "=0.4.7" # Solrizer defines this dependency but its' gemspec needs to be updated. Until then we'll require 0.4.7.
|
31
32
|
s.add_dependency 'multipart-post'
|
32
33
|
s.add_dependency 'nokogiri' # Default to using the version required by Blacklight
|
33
34
|
s.add_dependency 'om', '>=1.2.3'
|
@@ -37,9 +38,10 @@ Gem::Specification.new do |s|
|
|
37
38
|
s.add_dependency 'rcov'
|
38
39
|
s.add_dependency 'RedCloth', '=4.2.3'
|
39
40
|
s.add_dependency 'solr-ruby'
|
41
|
+
s.add_dependency 'mediashelf-loggable', '>=0.4.7' ##This can be removed once this dependency is declared in solrizer
|
40
42
|
s.add_dependency 'solrizer', '>=1.1.0'
|
41
43
|
s.add_dependency 'solrizer-fedora', '>=1.1.0'
|
42
|
-
s.add_dependency 'sqlite3-ruby', '1.2.5'
|
44
|
+
#s.add_dependency 'sqlite3-ruby', '>=1.2.5'
|
43
45
|
s.add_dependency 'term-ansicolor'
|
44
46
|
s.add_dependency 'trollop'
|
45
47
|
s.add_dependency 'will_paginate'
|
@@ -53,13 +55,14 @@ Gem::Specification.new do |s|
|
|
53
55
|
s.add_development_dependency 'ruby-debug-base'
|
54
56
|
s.add_development_dependency 'rspec', '>= 2.0.0'
|
55
57
|
s.add_development_dependency 'rspec-rails', '>= 2.0.0' # rspec-rails 2.0.0 requires Rails 3.
|
58
|
+
s.add_development_dependency 'rest-client'
|
59
|
+
s.add_development_dependency 'sqlite3-ruby', '1.2.5'
|
60
|
+
s.add_development_dependency 'sqlite3'
|
56
61
|
s.add_development_dependency 'mocha'
|
57
62
|
s.add_development_dependency 'cucumber', '>=0.8.5'
|
58
63
|
s.add_development_dependency 'cucumber-rails', '>=1.0.0'
|
59
|
-
# s.add_development_dependency 'capybara'
|
60
64
|
s.add_development_dependency 'gherkin'
|
61
65
|
s.add_development_dependency 'factory_girl'
|
62
|
-
#s.add_development_dependency 'markup_validity'
|
63
66
|
s.add_development_dependency "rake"
|
64
67
|
|
65
68
|
|
data/init.rb
ADDED
data/install.rb
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
# Install hook code here
|
@@ -0,0 +1,44 @@
|
|
1
|
+
# Note: not sure we're still using this in hydrangea...
|
2
|
+
# This is a replica of some methods that are in Blacklight's CatalogController that we wanted to re-use in other controllers
|
3
|
+
module Blacklight::CatalogHelper
|
4
|
+
# calls setup_previous_document then setup_next_document.
|
5
|
+
# used in the show action for single view pagination.
|
6
|
+
def setup_next_and_previous_documents
|
7
|
+
setup_previous_document
|
8
|
+
setup_next_document
|
9
|
+
end
|
10
|
+
|
11
|
+
# gets a document based on its position within a resultset
|
12
|
+
def setup_document_by_counter(counter)
|
13
|
+
return if counter < 1 || session[:search].blank?
|
14
|
+
# need to duplicate search session hash so we aren't modifying the original (and don't get the qt in the Back to search results link)
|
15
|
+
search = session[:search].dup || {}
|
16
|
+
# enforcing search restrictions
|
17
|
+
# if the user is not a reader then use the pulic qt, otherwise use the default qt (using logic from enforce_search_permissions method)
|
18
|
+
if !reader?
|
19
|
+
search[:qt] = Blacklight.config[:public_qt]
|
20
|
+
end
|
21
|
+
get_single_doc_via_search(search.merge({:page => counter}))
|
22
|
+
end
|
23
|
+
|
24
|
+
def setup_previous_document
|
25
|
+
@previous_document = session[:search][:counter] ? setup_document_by_counter(session[:search][:counter].to_i - 1) : nil
|
26
|
+
end
|
27
|
+
|
28
|
+
def setup_next_document
|
29
|
+
@next_document = session[:search][:counter] ? setup_document_by_counter(session[:search][:counter].to_i + 1) : nil
|
30
|
+
end
|
31
|
+
|
32
|
+
# sets up the session[:search] hash if it doesn't already exist
|
33
|
+
def search_session
|
34
|
+
session[:search] ||= {}
|
35
|
+
end
|
36
|
+
|
37
|
+
# sets up the session[:history] hash if it doesn't already exist.
|
38
|
+
# assigns all Search objects (that match the searches in session[:history]) to a variable @searches.
|
39
|
+
def history_session
|
40
|
+
session[:history] ||= []
|
41
|
+
@searches = searches_from_history # <- in ApplicationController
|
42
|
+
end
|
43
|
+
|
44
|
+
end
|
data/lib/blacklight.rb
ADDED
@@ -0,0 +1,40 @@
|
|
1
|
+
require "hydra-head" # This is a hacky way of ensuring that require_plugin_dependency is defined.
|
2
|
+
module Blacklight
|
3
|
+
|
4
|
+
require_plugin_dependency "vendor/plugins/blacklight/lib/blacklight.rb"
|
5
|
+
|
6
|
+
# This method overrides the default Blacklight self.init in order to support the opention of dual default/fulltext indexing
|
7
|
+
# that's supported in hydrangea. This also supports the traditional one index structure of Blacklight.
|
8
|
+
|
9
|
+
def self.init
|
10
|
+
|
11
|
+
solr_config = YAML::load(File.open("#{RAILS_ROOT}/config/solr.yml"))
|
12
|
+
raise "The #{RAILS_ENV} environment settings were not found in the solr.yml config" unless solr_config[RAILS_ENV]
|
13
|
+
|
14
|
+
if solr_config[RAILS_ENV].has_key?("default")
|
15
|
+
Blacklight.solr_config[:url] = solr_config[RAILS_ENV]['default']['url']
|
16
|
+
elsif solr_config[RAILS_ENV].has_key?('url')
|
17
|
+
Blacklight.solr_config[:url] = solr_config[RAILS_ENV]['url']
|
18
|
+
else
|
19
|
+
raise "BLACKLIGHT: Unable to configure solr -- #{solr_config.inspect}"
|
20
|
+
end
|
21
|
+
|
22
|
+
if Gem.available? 'curb'
|
23
|
+
require 'curb'
|
24
|
+
Blacklight.solr = RSolr::Ext.connect(Blacklight.solr_config.merge(:adapter=>:curb))
|
25
|
+
else
|
26
|
+
Blacklight.solr = RSolr::Ext.connect(Blacklight.solr_config)
|
27
|
+
end
|
28
|
+
|
29
|
+
# set the SolrDocument.connection to Blacklight.solr
|
30
|
+
SolrDocument.connection = Blacklight.solr
|
31
|
+
logger.info("BLACKLIGHT: running version #{Blacklight.version}")
|
32
|
+
logger.info("BLACKLIGHT: initialized with Blacklight.solr_config: #{Blacklight.solr_config.inspect}")
|
33
|
+
logger.info("BLACKLIGHT: initialized with Blacklight.solr: #{Blacklight.solr.inspect}")
|
34
|
+
logger.info("BLACKLIGHT: initialized with Blacklight.config: #{Blacklight.config.inspect}")
|
35
|
+
|
36
|
+
end
|
37
|
+
|
38
|
+
|
39
|
+
|
40
|
+
end
|
data/lib/block_mapper.rb
ADDED
@@ -0,0 +1,52 @@
|
|
1
|
+
#
|
2
|
+
# A generic mapping class for "collections"
|
3
|
+
# bm = BlockMapper.new
|
4
|
+
# bm.before_each {|rec,index| # do something here like: rec.extend(MyMethods) }
|
5
|
+
# bm.map :indexer, 'Matt'
|
6
|
+
# bm.map :id do |rec,index|
|
7
|
+
# rec[:id]
|
8
|
+
# end
|
9
|
+
#
|
10
|
+
# mapped_data = bm.run(my_collection_of_somethings)
|
11
|
+
#
|
12
|
+
class BlockMapper
|
13
|
+
|
14
|
+
attr :mappings
|
15
|
+
attr :before_each_source_item_blk
|
16
|
+
attr :after_each_mapped_value_blk
|
17
|
+
|
18
|
+
def initialize
|
19
|
+
@mappings = []
|
20
|
+
end
|
21
|
+
|
22
|
+
def map(output_field_name, value=nil, &blk)
|
23
|
+
raise 'Can provide a value (second arg) or a block, not both' if value and block_given?
|
24
|
+
@mappings << {:field_name=>output_field_name, :value=>value, :blk=>blk}
|
25
|
+
end
|
26
|
+
|
27
|
+
def before_each_source_item(&blk)
|
28
|
+
@before_each_source_item_blk = blk
|
29
|
+
end
|
30
|
+
|
31
|
+
def after_each_mapped_value(&blk)
|
32
|
+
@after_each_mapped_value_blk=blk
|
33
|
+
end
|
34
|
+
|
35
|
+
def run(collection, &blk)
|
36
|
+
docs=[]
|
37
|
+
collection.each_with_index do |rec,index|
|
38
|
+
@before_each_source_item_blk.call(rec,index) if @before_each_source_item_blk
|
39
|
+
doc={}
|
40
|
+
@mappings.each do |m|
|
41
|
+
field = m[:field_name]
|
42
|
+
value = m[:blk] ? m[:blk].call(rec, index) : m[:value].to_s
|
43
|
+
value = @after_each_mapped_value_blk.call(field, value) if @after_each_mapped_value_blk
|
44
|
+
doc[field] = value
|
45
|
+
end
|
46
|
+
yield(doc, index) if block_given?
|
47
|
+
docs << doc
|
48
|
+
end
|
49
|
+
docs
|
50
|
+
end
|
51
|
+
|
52
|
+
end
|
data/lib/djatoka.rb
ADDED
@@ -0,0 +1,59 @@
|
|
1
|
+
require "httparty"
|
2
|
+
class Djatoka
|
3
|
+
include HTTParty
|
4
|
+
# base_uri 'http://salt-dev.stanford.edu:8080/adore-djatoka/resolver'
|
5
|
+
base_uri "http://localhost:8080/adore-djatoka/resolver"
|
6
|
+
default_params :url_ver => 'Z39.88-2004', :svc_val_fmt=> "info:ofi/fmt:kev:mtx:jpeg2000"
|
7
|
+
|
8
|
+
# Uses Djatoka to scale the image from @source_url according to @scale_value
|
9
|
+
# Accepts optional hash that will be passed through to djatoka as-is
|
10
|
+
# scale_value is passed through to djatoka as svc.scale.
|
11
|
+
# From the Djatoka docs:
|
12
|
+
# svc.scale - Request specific output size by scaling extracted resource.
|
13
|
+
# Option 1) Define a long-side dimension (e.g., svc.scale=96)
|
14
|
+
# * Nearest resolution level, rounded up, is used for level parameter
|
15
|
+
# * Uses the aspect ratio to calculate second value
|
16
|
+
# Option 2) Define absolute w,h values (e.g. 1024,768)
|
17
|
+
# * Images is scaled to the dimensions you specify.
|
18
|
+
# * Value must be less than 2X current resolution
|
19
|
+
# Option 3) Define a single dimension (e.g. 1024,0) with or without Level Parameter
|
20
|
+
# * Uses the aspect ratio to calculate second value
|
21
|
+
# Option 4) Use a single decimal scaling factor (e.g. 0.854)
|
22
|
+
# * Current resolution = 1.0
|
23
|
+
# * 50% Resolution = 0.5
|
24
|
+
# * 150% Resolution = 1.5
|
25
|
+
# * Value must be greater than 0 and less than 2
|
26
|
+
def self.scale(source_url, scale_value, options={})
|
27
|
+
options.merge!("svc.scale"=>scale_value)
|
28
|
+
get_image(source_url, options)
|
29
|
+
end
|
30
|
+
|
31
|
+
# Uses Djatoka to retrieve a redion of the image from @source_url according to @scale_value
|
32
|
+
# Accepts optional hash that will be passed through to djatoka as-is
|
33
|
+
# scale_value is passed through to djatoka as svc.scale.
|
34
|
+
# From the Djatoka docs:
|
35
|
+
# svc.region - Y,X,H,W.
|
36
|
+
# * Y is the down inset value (positive) from 0 on the y axis at the max image resolution.
|
37
|
+
# * X is the right inset value (positive) from 0 on the x axis at the max image resolution.
|
38
|
+
# * H is the height of the image provided as response.
|
39
|
+
# * W is the width of the image provided as response.
|
40
|
+
# * All values may either be absolute pixel values (e.g. 100,100,256,256), float values (e.g. 0.1,0.1,0.1,0.1), or a combination (e.g. 0.1,0.1,256,256).
|
41
|
+
def self.region(source_url, region_value, options={})
|
42
|
+
options.merge!("svc.region"=>region_value)
|
43
|
+
get_image(source_url, options)
|
44
|
+
end
|
45
|
+
|
46
|
+
def self.get_image(source_url, options={})
|
47
|
+
options.merge!({:svc_id => "info:lanl-repo/svc/getRegion", :rft_id=>source_url, "svc.format"=>"image/jpeg"})
|
48
|
+
puts "get_region options: #{options.inspect}"
|
49
|
+
get("", :query => options)
|
50
|
+
end
|
51
|
+
|
52
|
+
end
|
53
|
+
|
54
|
+
# url_ver=Z39.88-2004
|
55
|
+
# &rft_id=http://memory.loc.gov/gmd/gmd433/g4330/g4330/np000066.jp2
|
56
|
+
# &svc_id=info:lanl-repo/svc/getRegion
|
57
|
+
# &svc_val_fmt=info:ofi/fmt:kev:mtx:jpeg2000
|
58
|
+
# &svc.format=image/jpeg
|
59
|
+
# &svc.scale=600
|