curate 0.6.5 → 0.6.6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (431) hide show
  1. checksums.yaml +4 -4
  2. data/Rakefile +9 -0
  3. data/app/assets/javascripts/curate.js +2 -0
  4. data/app/assets/javascripts/curate/link_groups.js.coffee +123 -0
  5. data/app/assets/javascripts/curate/link_users.js.coffee +29 -10
  6. data/app/assets/stylesheets/curate.css.scss +1 -0
  7. data/app/assets/stylesheets/curate/linkedGroups.css.scss +16 -0
  8. data/app/assets/stylesheets/curate/linkedUsers.css.scss +4 -0
  9. data/app/assets/stylesheets/modules.scss +2 -1
  10. data/app/assets/stylesheets/modules/forms.css.scss +5 -0
  11. data/app/assets/stylesheets/modules/profile.css.scss +51 -0
  12. data/app/controllers/catalog_controller.rb +37 -7
  13. data/app/controllers/curate/collections_controller.rb +15 -0
  14. data/app/controllers/curate/people_controller.rb +17 -4
  15. data/app/controllers/curation_concern/generic_works_controller.rb +26 -2
  16. data/app/controllers/curation_concern/linked_resources_controller.rb +1 -1
  17. data/app/controllers/curation_concern/permissions_controller.rb +2 -1
  18. data/app/controllers/hydramata/groups_controller.rb +119 -0
  19. data/app/controllers/registrations_controller.rb +33 -0
  20. data/app/controllers/users_controller.rb +23 -0
  21. data/app/helpers/curate/catalog_helper.rb +14 -0
  22. data/app/helpers/curate/collections_helper.rb +20 -9
  23. data/app/helpers/curate_helper.rb +12 -5
  24. data/app/helpers/hydramata/groups_helper.rb +12 -0
  25. data/app/models/account.rb +17 -0
  26. data/app/models/concerns/curate/ability.rb +1 -5
  27. data/app/models/curate/user_behavior/base.rb +6 -5
  28. data/app/repository_datastreams/group_metadata_datastream.rb +20 -0
  29. data/app/repository_models/collection.rb +49 -1
  30. data/app/repository_models/curation_concern/model.rb +5 -1
  31. data/app/repository_models/curation_concern/with_generic_files.rb +4 -3
  32. data/app/repository_models/curation_concern/work.rb +38 -1
  33. data/app/repository_models/curation_concern/work_permission.rb +54 -0
  34. data/app/repository_models/hydramata/group.rb +87 -0
  35. data/app/repository_models/hydramata/group_membership_form.rb +72 -0
  36. data/app/repository_models/person.rb +37 -1
  37. data/app/repository_models/profile_section.rb +0 -1
  38. data/app/services/curation_concern/work_permission_action_parser.rb +78 -0
  39. data/app/services/hydramata/group_membership_action_parser.rb +65 -0
  40. data/app/views/catalog/_facets.html.erb +3 -1
  41. data/app/views/catalog/index.html.erb +3 -0
  42. data/app/views/curate/collections/_form.html.erb +10 -0
  43. data/app/views/curate/collections/show.html.erb +1 -0
  44. data/app/views/curate/people/_profile_image.html.erb +2 -2
  45. data/app/views/curate/people/show.html.erb +46 -34
  46. data/app/views/curation_concern/articles/_attributes.html.erb +1 -0
  47. data/app/views/curation_concern/base/_form.html.erb +1 -0
  48. data/app/views/curation_concern/base/_form_descriptive_fields.erb +9 -0
  49. data/app/views/curation_concern/base/_linked_editors.html.erb +47 -0
  50. data/app/views/curation_concern/base/_linked_groups.html.erb +45 -0
  51. data/app/views/curation_concern/base/_persons_edit_access.html.erb +44 -0
  52. data/app/views/curation_concern/documents/_attributes.html.erb +1 -0
  53. data/app/views/curation_concern/etds/_attributes.html.erb +1 -0
  54. data/app/views/curation_concern/etds/_form_descriptive_fields.erb +2 -0
  55. data/app/views/curation_concern/generic_works/_attributes.html.erb +1 -0
  56. data/app/views/{curate/organizations/_organization.html.erb → curation_concern/hydramata/groups/_group.html.erb} +6 -6
  57. data/app/views/curation_concern/images/_attributes.html.erb +1 -0
  58. data/app/views/curation_concern/images/_form_descriptive_fields.erb +2 -0
  59. data/app/views/hydramata/groups/_button_create_group.html.erb +1 -0
  60. data/app/views/{curate/organizations → hydramata/groups}/_document_list.html.erb +0 -0
  61. data/app/views/{curate/organizations → hydramata/groups}/_form.html.erb +28 -10
  62. data/app/views/hydramata/groups/_group.html.erb +24 -0
  63. data/app/views/hydramata/groups/_linked_members.html.erb +96 -0
  64. data/app/views/hydramata/groups/edit.html.erb +4 -0
  65. data/app/views/hydramata/groups/index.html.erb +11 -0
  66. data/app/views/{curate/organizations → hydramata/groups}/new.html.erb +1 -1
  67. data/app/views/hydramata/groups/show.html.erb +36 -0
  68. data/app/views/layouts/boilerplate.html.erb +1 -1
  69. data/app/views/registrations/_form_account_deactivation.html.erb +1 -1
  70. data/app/views/registrations/_form_attributes.html.erb +3 -5
  71. data/app/views/registrations/_form_password_management.html.erb +11 -9
  72. data/app/views/registrations/edit.html.erb +8 -5
  73. data/app/views/shared/_add_content.html.erb +1 -1
  74. data/app/views/shared/_my_actions.html.erb +1 -0
  75. data/lib/curate/configuration.rb +6 -0
  76. data/lib/curate/rails/routes.rb +7 -1
  77. data/lib/curate/spec_support.rb +1 -1
  78. data/lib/curate/version.rb +1 -1
  79. data/lib/generators/curate/application_template.rb +10 -2
  80. data/lib/generators/curate/curate_generator.rb +16 -0
  81. data/lib/generators/curate/predicate_mapping/predicate_mappings.yml +64 -0
  82. data/lib/generators/curate/search_config/search_config_generator.rb +177 -0
  83. data/lib/generators/curate/soft_delete/active_fedora_soft_delete_monkey_patch.rb +14 -4
  84. data/spec/abilities/generic_file_abilities_spec.rb +1 -0
  85. data/spec/abilities/generic_work_abilities_spec.rb +1 -0
  86. data/spec/controllers/catalog_controller_spec.rb +21 -0
  87. data/spec/controllers/curate/collections_controller_spec.rb +1 -1
  88. data/spec/controllers/curation_concern/linked_resources_controller_spec.rb +1 -1
  89. data/spec/controllers/curation_concern/permissions_controller_spec.rb +1 -1
  90. data/spec/controllers/hydamata/groups_controller_spec.rb +133 -0
  91. data/spec/factories/group_factory.rb +20 -0
  92. data/spec/features/article_spec.rb +3 -2
  93. data/spec/features/catalog_search_spec.rb +19 -2
  94. data/spec/features/collections_spec.rb +23 -7
  95. data/spec/features/dataset_spec.rb +3 -2
  96. data/spec/features/end_to_end_spec.rb +9 -8
  97. data/spec/features/etd_spec.rb +3 -2
  98. data/spec/features/generic_work_spec.rb +6 -3
  99. data/spec/features/image_spec.rb +3 -2
  100. data/spec/features/manager_profile_workflow_spec.rb +56 -0
  101. data/spec/features/person_profile_spec.rb +4 -4
  102. data/spec/features/user_profile_workflow_spec.rb +1 -7
  103. data/spec/fixtures/cassettes/remotely_identified_doi_mint_generic_work.yml +3 -3
  104. data/spec/fixtures/cassettes/remotely_identified_doi_mint_spam.yml +47 -0
  105. data/spec/helpers/curate/catalog_helper.rb +29 -0
  106. data/spec/internal/Gemfile +23 -4
  107. data/spec/internal/Gemfile.lock +410 -14
  108. data/spec/internal/app/assets/images/blacklight/bg.png +0 -0
  109. data/spec/internal/app/assets/images/blacklight/border.png +0 -0
  110. data/spec/internal/app/assets/images/blacklight/bul_sq_gry.gif +0 -0
  111. data/spec/internal/app/assets/images/blacklight/checkmark.gif +0 -0
  112. data/spec/internal/app/assets/images/blacklight/logo.png +0 -0
  113. data/spec/internal/app/assets/images/blacklight/magnifying_glass.gif +0 -0
  114. data/spec/internal/app/assets/images/blacklight/remove.gif +0 -0
  115. data/spec/internal/app/assets/images/blacklight/separator.gif +0 -0
  116. data/spec/internal/app/assets/images/blacklight/start_over.gif +0 -0
  117. data/spec/internal/app/assets/javascripts/application.js +4 -0
  118. data/spec/internal/app/assets/stylesheets/application.css +1 -0
  119. data/spec/internal/app/controllers/application_controller.rb +9 -0
  120. data/spec/internal/app/controllers/curation_concern/spams_controller.rb +6 -0
  121. data/spec/internal/app/models/ability.rb +20 -0
  122. data/spec/internal/app/models/solr_document.rb +38 -0
  123. data/spec/internal/app/models/user.rb +23 -0
  124. data/spec/internal/app/repository_datastreams/spam_rdf_datastream.rb +78 -0
  125. data/spec/internal/app/repository_models/spam.rb +47 -0
  126. data/spec/internal/app/services/curation_concern/spam_actor.rb +6 -0
  127. data/spec/internal/app/views/curation_concern/spams/_spam.html.erb +2 -0
  128. data/spec/internal/config/SolrMarc/config-test.properties +37 -0
  129. data/spec/internal/config/SolrMarc/config.properties +37 -0
  130. data/spec/internal/config/SolrMarc/index.properties +97 -0
  131. data/spec/internal/config/SolrMarc/index_scripts/dewey.bsh +47 -0
  132. data/spec/internal/config/SolrMarc/index_scripts/format.bsh +126 -0
  133. data/spec/internal/config/SolrMarc/translation_maps/README_MAPS +1 -0
  134. data/spec/internal/config/SolrMarc/translation_maps/callnumber_map.properties +407 -0
  135. data/spec/internal/config/SolrMarc/translation_maps/composition_era_map.properties +56 -0
  136. data/spec/internal/config/SolrMarc/translation_maps/country_map.properties +379 -0
  137. data/spec/internal/config/SolrMarc/translation_maps/format_map.properties +50 -0
  138. data/spec/internal/config/SolrMarc/translation_maps/instrument_map.properties +101 -0
  139. data/spec/internal/config/SolrMarc/translation_maps/language_map.properties +490 -0
  140. data/spec/internal/config/application.rb +6 -0
  141. data/spec/internal/config/doi.yml +5 -0
  142. data/spec/internal/config/environments/test.rb +2 -1
  143. data/spec/internal/config/fedora.yml +14 -0
  144. data/spec/internal/config/initializers/action_dispatch_http_upload_monkey_patch.rb +12 -0
  145. data/spec/internal/config/initializers/curate_config.rb +30 -0
  146. data/spec/internal/config/initializers/devise.rb +256 -0
  147. data/spec/internal/config/initializers/hydra-remote_identifier_config.rb +29 -0
  148. data/spec/internal/config/initializers/hydra_config.rb +28 -0
  149. data/spec/internal/config/initializers/mailboxer.rb +17 -0
  150. data/spec/internal/config/initializers/mime_types.rb +8 -1
  151. data/spec/internal/config/initializers/redis_config.rb +32 -0
  152. data/spec/internal/config/initializers/resque_admin.rb +10 -0
  153. data/spec/internal/config/initializers/resque_config.rb +5 -0
  154. data/spec/internal/config/initializers/secret_token.rb +1 -1
  155. data/spec/internal/config/initializers/sufia.rb +81 -0
  156. data/spec/internal/config/jetty.yml +5 -0
  157. data/spec/internal/config/locales/devise.en.yml +59 -0
  158. data/spec/internal/config/locales/en.yml +11 -20
  159. data/spec/internal/config/manager_usernames.yml +9 -0
  160. data/spec/internal/config/predicate_mappings.yml +64 -0
  161. data/spec/internal/config/recipients_list.yml +2 -0
  162. data/spec/internal/config/redis.yml +6 -0
  163. data/spec/internal/config/role_map_cucumber.yml +10 -0
  164. data/spec/internal/config/role_map_development.yml +12 -0
  165. data/spec/internal/config/role_map_production.yml +2 -0
  166. data/spec/internal/config/role_map_test.yml +15 -0
  167. data/spec/internal/config/routes.rb +8 -0
  168. data/spec/internal/config/search_config.yml +9 -0
  169. data/spec/internal/config/solr.yml +10 -0
  170. data/spec/internal/db/development.sqlite3 +0 -0
  171. data/spec/internal/db/migrate/20140328183252_devise_create_users.rb +42 -0
  172. data/spec/internal/db/migrate/20140328183257_add_devise_guests_to_users.rb +15 -0
  173. data/spec/internal/db/migrate/20140328183258_create_searches.rb +16 -0
  174. data/spec/internal/db/migrate/20140328183259_create_bookmarks.rb +18 -0
  175. data/spec/internal/db/migrate/20140328183260_remove_editable_fields_from_bookmarks.rb +12 -0
  176. data/spec/internal/db/migrate/20140328183261_add_user_types_to_bookmarks_searches.rb +16 -0
  177. data/spec/internal/db/migrate/20140328183262_acts_as_follower_migration.rb +17 -0
  178. data/spec/internal/db/migrate/20140328183263_add_social_to_users.rb +13 -0
  179. data/spec/internal/db/migrate/20140328183264_create_single_use_links.rb +12 -0
  180. data/spec/internal/db/migrate/20140328183265_add_ldap_attrs_to_user.rb +27 -0
  181. data/spec/internal/db/migrate/20140328183266_add_avatars_to_users.rb +9 -0
  182. data/spec/internal/db/migrate/20140328183267_create_checksum_audit_logs.rb +20 -0
  183. data/spec/internal/db/migrate/20140328183268_create_version_committers.rb +15 -0
  184. data/spec/internal/db/migrate/20140328183269_add_groups_to_users.rb +11 -0
  185. data/spec/internal/db/migrate/20140328183270_create_local_authorities.rb +50 -0
  186. data/spec/internal/db/migrate/20140328183271_create_trophies.rb +10 -0
  187. data/spec/internal/db/migrate/20140328183331_create_mailboxer.mailboxer_engine.rb +62 -0
  188. data/spec/internal/db/migrate/20140328183332_add_notified_object.mailboxer_engine.rb +18 -0
  189. data/spec/internal/db/migrate/20140328183333_add_notification_code.mailboxer_engine.rb +14 -0
  190. data/spec/internal/db/migrate/20140328183334_add_attachments.mailboxer_engine.rb +10 -0
  191. data/spec/internal/db/migrate/20140328183335_rename_receipts_read.mailboxer_engine.rb +10 -0
  192. data/spec/internal/db/migrate/20140328183336_add_global_notification_support.mailboxer_engine.rb +10 -0
  193. data/spec/internal/db/migrate/20140328183340_add_terms_of_service_to_user.curate_engine.rb +6 -0
  194. data/spec/internal/db/migrate/20140328183341_add_user_force_update_profile.curate_engine.rb +9 -0
  195. data/spec/internal/db/migrate/20140328183342_create_help_requests.curate_engine.rb +23 -0
  196. data/spec/internal/db/migrate/20140328183343_add_repository_id_to_user.curate_engine.rb +7 -0
  197. data/spec/internal/db/migrate/20140328183344_create_curate_proxy_deposit_rights.curate_engine.rb +12 -0
  198. data/spec/internal/db/migrate/20140328183345_change_display_name_to_name.curate_engine.rb +7 -0
  199. data/spec/internal/db/schema.rb +216 -1
  200. data/spec/internal/db/test.sqlite3 +0 -0
  201. data/spec/internal/fedora_conf/conf/development/fedora.fcfg +953 -0
  202. data/spec/internal/fedora_conf/conf/test/fedora.fcfg +953 -0
  203. data/spec/internal/lib/generators/test_app_generator.rb +23 -2
  204. data/spec/internal/log/development.log +322 -4
  205. data/spec/internal/log/test.log +117837 -0
  206. data/spec/internal/solr_conf/conf/schema.xml +273 -0
  207. data/spec/internal/solr_conf/conf/solrconfig.xml +167 -0
  208. data/spec/internal/solr_conf/solr.xml +35 -0
  209. data/spec/internal/spec/controllers/curation_concern/spams_controller_spec.rb +7 -0
  210. data/spec/internal/spec/factories/spams_factory.rb +40 -0
  211. data/spec/internal/spec/repository_models/spam_spec.rb +16 -0
  212. data/spec/internal/spec/services/curation_concern/spam_actor_spec.rb +7 -0
  213. data/spec/internal/test/models/user_test.rb +7 -0
  214. data/spec/internal/tmp/cache/assets/test/sass/0f223a129cc26de35ff59298da93dd57d598447a/_blacklight_base.css.scssc +0 -0
  215. data/spec/internal/tmp/cache/assets/test/sass/0f223a129cc26de35ff59298da93dd57d598447a/_bookmark.css.scssc +0 -0
  216. data/spec/internal/tmp/cache/assets/test/sass/0f223a129cc26de35ff59298da93dd57d598447a/_catalog.css.scssc +0 -0
  217. data/spec/internal/tmp/cache/assets/test/sass/0f223a129cc26de35ff59298da93dd57d598447a/_dropdown.css.scssc +0 -0
  218. data/spec/internal/tmp/cache/assets/test/sass/0f223a129cc26de35ff59298da93dd57d598447a/_facets.css.scssc +0 -0
  219. data/spec/internal/tmp/cache/assets/test/sass/0f223a129cc26de35ff59298da93dd57d598447a/_footer.css.scssc +0 -0
  220. data/spec/internal/tmp/cache/assets/test/sass/0f223a129cc26de35ff59298da93dd57d598447a/_group.css.scssc +0 -0
  221. data/spec/internal/tmp/cache/assets/test/sass/0f223a129cc26de35ff59298da93dd57d598447a/_header.css.scssc +0 -0
  222. data/spec/internal/tmp/cache/assets/test/sass/0f223a129cc26de35ff59298da93dd57d598447a/_layout.css.scssc +0 -0
  223. data/spec/internal/tmp/cache/assets/test/sass/0f223a129cc26de35ff59298da93dd57d598447a/_modal.css.scssc +0 -0
  224. data/spec/internal/tmp/cache/assets/test/sass/0f223a129cc26de35ff59298da93dd57d598447a/_print.css.scssc +0 -0
  225. data/spec/internal/tmp/cache/assets/test/sass/0f223a129cc26de35ff59298da93dd57d598447a/_responsive.css.scssc +0 -0
  226. data/spec/internal/tmp/cache/assets/test/sass/0f223a129cc26de35ff59298da93dd57d598447a/_search_history.css.scssc +0 -0
  227. data/spec/internal/tmp/cache/assets/test/sass/0f223a129cc26de35ff59298da93dd57d598447a/blacklight.css.scssc +0 -0
  228. data/spec/internal/tmp/cache/assets/test/sass/0f223a129cc26de35ff59298da93dd57d598447a/blacklight_defaults.css.scssc +0 -0
  229. data/spec/internal/tmp/cache/assets/test/sass/108fdfe10ba83060a2164fe91a5d70f57ff08f38/linkedGroups.css.scssc +0 -0
  230. data/spec/internal/tmp/cache/assets/test/sass/108fdfe10ba83060a2164fe91a5d70f57ff08f38/linkedUsers.css.scssc +0 -0
  231. data/spec/internal/tmp/cache/assets/test/sass/2c6be7e0f6fa11a075d87959732f91fde3df1f13/accessibility.css.scssc +0 -0
  232. data/spec/internal/tmp/cache/assets/test/sass/2c6be7e0f6fa11a075d87959732f91fde3df1f13/accordion.css.scssc +0 -0
  233. data/spec/internal/tmp/cache/assets/test/sass/2c6be7e0f6fa11a075d87959732f91fde3df1f13/attributes.css.scssc +0 -0
  234. data/spec/internal/tmp/cache/assets/test/sass/2c6be7e0f6fa11a075d87959732f91fde3df1f13/classify_work.css.scssc +0 -0
  235. data/spec/internal/tmp/cache/assets/test/sass/2c6be7e0f6fa11a075d87959732f91fde3df1f13/collections.css.scssc +0 -0
  236. data/spec/internal/tmp/cache/assets/test/sass/2c6be7e0f6fa11a075d87959732f91fde3df1f13/emphatic_action_area.css.scssc +0 -0
  237. data/spec/internal/tmp/cache/assets/test/sass/2c6be7e0f6fa11a075d87959732f91fde3df1f13/forms.css.scssc +0 -0
  238. data/spec/internal/tmp/cache/assets/test/sass/2c6be7e0f6fa11a075d87959732f91fde3df1f13/multi_value_fields.css.scssc +0 -0
  239. data/spec/internal/tmp/cache/assets/test/sass/2c6be7e0f6fa11a075d87959732f91fde3df1f13/pagination.css.scssc +0 -0
  240. data/spec/internal/tmp/cache/assets/test/sass/2c6be7e0f6fa11a075d87959732f91fde3df1f13/profile.css.scssc +0 -0
  241. data/spec/internal/tmp/cache/assets/test/sass/2c6be7e0f6fa11a075d87959732f91fde3df1f13/search_results.css.scssc +0 -0
  242. data/spec/internal/tmp/cache/assets/test/sass/2c6be7e0f6fa11a075d87959732f91fde3df1f13/site_actions.css.scssc +0 -0
  243. data/spec/internal/tmp/cache/assets/test/sass/2c6be7e0f6fa11a075d87959732f91fde3df1f13/site_search.css.scssc +0 -0
  244. data/spec/internal/tmp/cache/assets/test/sass/3540212d3e8f12f14e3d57e312ff13dc248a7b03/bootstrap-modal.cssc +0 -0
  245. data/spec/internal/tmp/cache/assets/test/sass/393de91b02495e7f60ccd919368de37af38618da/bootstrap-datepicker.cssc +0 -0
  246. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_accordion.scssc +0 -0
  247. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_alerts.scssc +0 -0
  248. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_breadcrumbs.scssc +0 -0
  249. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_button-groups.scssc +0 -0
  250. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_buttons.scssc +0 -0
  251. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_carousel.scssc +0 -0
  252. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_close.scssc +0 -0
  253. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_code.scssc +0 -0
  254. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_component-animations.scssc +0 -0
  255. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_dropdowns.scssc +0 -0
  256. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_forms.scssc +0 -0
  257. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_grid.scssc +0 -0
  258. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_hero-unit.scssc +0 -0
  259. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_labels-badges.scssc +0 -0
  260. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_layouts.scssc +0 -0
  261. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_media.scssc +0 -0
  262. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_mixins.scssc +0 -0
  263. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_modals.scssc +0 -0
  264. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_navbar.scssc +0 -0
  265. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_navs.scssc +0 -0
  266. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_pager.scssc +0 -0
  267. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_pagination.scssc +0 -0
  268. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_popovers.scssc +0 -0
  269. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_progress-bars.scssc +0 -0
  270. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_reset.scssc +0 -0
  271. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_responsive-1200px-min.scssc +0 -0
  272. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_responsive-767px-max.scssc +0 -0
  273. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_responsive-768px-979px.scssc +0 -0
  274. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_responsive-navbar.scssc +0 -0
  275. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_responsive-utilities.scssc +0 -0
  276. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_scaffolding.scssc +0 -0
  277. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_sprites.scssc +0 -0
  278. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_tables.scssc +0 -0
  279. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_thumbnails.scssc +0 -0
  280. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_tooltip.scssc +0 -0
  281. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_type.scssc +0 -0
  282. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_utilities.scssc +0 -0
  283. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_variables.scssc +0 -0
  284. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/_wells.scssc +0 -0
  285. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/bootstrap.scssc +0 -0
  286. data/spec/internal/tmp/cache/assets/test/sass/51b00c7d39146f73896d987722a019852fb2ca5e/responsive.scssc +0 -0
  287. data/spec/internal/tmp/cache/assets/test/sass/6a8f3b19bc293c20ed8d8faf81b13284c10818d6/_catalog.css.scssc +0 -0
  288. data/spec/internal/tmp/cache/assets/test/sass/6a8f3b19bc293c20ed8d8faf81b13284c10818d6/_facets.css.scssc +0 -0
  289. data/spec/internal/tmp/cache/assets/test/sass/6a8f3b19bc293c20ed8d8faf81b13284c10818d6/_header.css.scssc +0 -0
  290. data/spec/internal/tmp/cache/assets/test/sass/953d624c1831fcea22a3be549290f4c654726e96/positioning.css.scssc +0 -0
  291. data/spec/internal/tmp/cache/assets/test/sass/b95751effdfef9cdba38bc1d169b6196172155ed/theme.css.scssc +0 -0
  292. data/spec/internal/tmp/cache/assets/test/sass/b95751effdfef9cdba38bc1d169b6196172155ed/typography.css.scssc +0 -0
  293. data/spec/internal/tmp/cache/assets/test/sass/e653ebc579903efbaf96508ec20b97304a2a14a0/token-input-facebook.cssc +0 -0
  294. data/spec/internal/tmp/cache/assets/test/sass/e9808fc781dff3e3e7170d18d009c46cb33a75c5/curate.css.scssc +0 -0
  295. data/spec/internal/tmp/cache/assets/test/sass/e9808fc781dff3e3e7170d18d009c46cb33a75c5/global-variables.scssc +0 -0
  296. data/spec/internal/tmp/cache/assets/test/sass/e9808fc781dff3e3e7170d18d009c46cb33a75c5/modules.scssc +0 -0
  297. data/spec/internal/tmp/cache/assets/test/sass/ef004a21da8f6e485bf56e67090fd7b67164e2d4/bootstrap-responsive.scssc +0 -0
  298. data/spec/internal/tmp/cache/assets/test/sass/ef004a21da8f6e485bf56e67090fd7b67164e2d4/bootstrap.scssc +0 -0
  299. data/spec/internal/tmp/cache/assets/test/sprockets/022df81faa4bf7df68048b690ef7c85c +0 -0
  300. data/spec/internal/tmp/cache/assets/test/sprockets/04a9cbc691396f514e6b88c05724f9cc +0 -0
  301. data/spec/internal/tmp/cache/assets/test/sprockets/070263a383619079784e4ce15cf15443 +0 -0
  302. data/spec/internal/tmp/cache/assets/test/sprockets/091e4dfe4ed53798289eecba25675954 +0 -0
  303. data/spec/internal/tmp/cache/assets/test/sprockets/0b4f161bc175df6a24a070de15ef8070 +0 -0
  304. data/spec/internal/tmp/cache/assets/test/sprockets/0d6ccd45e1a5bb30040987a5817f5ca7 +0 -0
  305. data/spec/internal/tmp/cache/assets/test/sprockets/1114f56d5a4f05583b0351978456c150 +0 -0
  306. data/spec/internal/tmp/cache/assets/test/sprockets/13fe41fee1fe35b49d145bcc06610705 +0 -0
  307. data/spec/internal/tmp/cache/assets/test/sprockets/163665b72c8e98b0c88c19896f080bc4 +0 -0
  308. data/spec/internal/tmp/cache/assets/test/sprockets/169842bd6ce5ed610c32403ca2ed06d6 +0 -0
  309. data/spec/internal/tmp/cache/assets/test/sprockets/19465db808fbe15048554cecb70ad7cf +0 -0
  310. data/spec/internal/tmp/cache/assets/test/sprockets/1a591a26fdf3ed78b25b5ab792d76b7e +0 -0
  311. data/spec/internal/tmp/cache/assets/test/sprockets/1c1167e9384b80e15359a663448a3196 +0 -0
  312. data/spec/internal/tmp/cache/assets/test/sprockets/1d084625b16ac691b3ac53f7c3af9383 +0 -0
  313. data/spec/internal/tmp/cache/assets/test/sprockets/1d2f8185792ec3fccced5ea4e4dd7ff2 +0 -0
  314. data/spec/internal/tmp/cache/assets/test/sprockets/1eeefbd68878e39bf538ca5fb6816827 +0 -0
  315. data/spec/internal/tmp/cache/assets/test/sprockets/1f3f013d8df49445e8f6d26abe4bd0c3 +0 -0
  316. data/spec/internal/tmp/cache/assets/test/sprockets/22589c57b7736c35f126b70fa4f6838d +0 -0
  317. data/spec/internal/tmp/cache/assets/test/sprockets/2458a8aab642c987741b9e5dbadc40be +0 -0
  318. data/spec/internal/tmp/cache/assets/test/sprockets/25c858866fd7a2ca6719b8f57b7da784 +0 -0
  319. data/spec/internal/tmp/cache/assets/test/sprockets/272deddade92ef016e309a2eb7b775cc +0 -0
  320. data/spec/internal/tmp/cache/assets/test/sprockets/293f9259ef62e6c2afde9949c46f0b36 +0 -0
  321. data/spec/internal/tmp/cache/assets/test/sprockets/2b89cef6265da9c35a9c68f4672c7ff5 +0 -0
  322. data/spec/internal/tmp/cache/assets/test/sprockets/2e0105bbafec2286e09b62e5471f4c73 +0 -0
  323. data/spec/internal/tmp/cache/assets/test/sprockets/2f5173deea6c795b8fdde723bb4b63af +0 -0
  324. data/spec/internal/tmp/cache/assets/test/sprockets/30980d53fa21cb948c92faff2cf90991 +0 -0
  325. data/spec/internal/tmp/cache/assets/test/sprockets/30b468617659dbbfc89c910dcb076662 +0 -0
  326. data/spec/internal/tmp/cache/assets/test/sprockets/31f03bdc9721687fd98c2b12c036e8a2 +0 -0
  327. data/spec/internal/tmp/cache/assets/test/sprockets/357970feca3ac29060c1e3861e2c0953 +0 -0
  328. data/spec/internal/tmp/cache/assets/test/sprockets/3b707f5b5654437450eb8d718b602724 +0 -0
  329. data/spec/internal/tmp/cache/assets/test/sprockets/4132e961bdf0f2ffa2f96a4c7822e209 +0 -0
  330. data/spec/internal/tmp/cache/assets/test/sprockets/41dd5dbd03cfa3f49e2d7569ffd03f8d +0 -0
  331. data/spec/internal/tmp/cache/assets/test/sprockets/42ad0d7de425a02e6ad4b53f8f96e73a +0 -0
  332. data/spec/internal/tmp/cache/assets/test/sprockets/4749d0a94ef75f86eebb5f638b83188c +0 -0
  333. data/spec/internal/tmp/cache/assets/test/sprockets/47d1bee927ac2da38db4c61acd85d648 +0 -0
  334. data/spec/internal/tmp/cache/assets/test/sprockets/483d9b04ae722b59d47428990e5d67a3 +0 -0
  335. data/spec/internal/tmp/cache/assets/test/sprockets/49dddc872622de1d975f563d9d10d6c9 +0 -0
  336. data/spec/internal/tmp/cache/assets/test/sprockets/49f85e65ad619dd02dc51988e77723d2 +0 -0
  337. data/spec/internal/tmp/cache/assets/test/sprockets/4b1fc3a748e34199e72958c656cc06cf +0 -0
  338. data/spec/internal/tmp/cache/assets/test/sprockets/4c5e67849a42922256c692cebe3625ae +0 -0
  339. data/spec/internal/tmp/cache/assets/test/sprockets/5141429549bc789c5a18f47a631ee310 +0 -0
  340. data/spec/internal/tmp/cache/assets/test/sprockets/541a8ef4d67b7e50312977c96e423051 +0 -0
  341. data/spec/internal/tmp/cache/assets/test/sprockets/55e3bb68ac9cf584a33a458f8a2b1676 +0 -0
  342. data/spec/internal/tmp/cache/assets/test/sprockets/5d53e364ada0619aa4fb30c112b6b102 +0 -0
  343. data/spec/internal/tmp/cache/assets/test/sprockets/611235bfd282813bdfbc998bcbe798e8 +0 -0
  344. data/spec/internal/tmp/cache/assets/test/sprockets/671dbbf33392960f4dfc8dc63bd7019b +0 -0
  345. data/spec/internal/tmp/cache/assets/test/sprockets/6e0879a87dae322b4e32263452ba6b4e +0 -0
  346. data/spec/internal/tmp/cache/assets/test/sprockets/6ff6303a1f21708f6bd3a328290e5d24 +0 -0
  347. data/spec/internal/tmp/cache/assets/test/sprockets/72d162018f00a25977df702c0c32873f +0 -0
  348. data/spec/internal/tmp/cache/assets/test/sprockets/7685f208e89b90425bf76796648ebc28 +0 -0
  349. data/spec/internal/tmp/cache/assets/test/sprockets/7d0dafd1bea0f4da00c580f0f6d664b8 +0 -0
  350. data/spec/internal/tmp/cache/assets/test/sprockets/7d4fe23150294500a7bcd2630667e5c8 +0 -0
  351. data/spec/internal/tmp/cache/assets/test/sprockets/7e48304ca1d04f24b1a3ddfd0e762248 +0 -0
  352. data/spec/internal/tmp/cache/assets/test/sprockets/7e6843e999995e7a8a28abe25d44de70 +0 -0
  353. data/spec/internal/tmp/cache/assets/test/sprockets/7f1cb34f019f0890927d422814194b01 +0 -0
  354. data/spec/internal/tmp/cache/assets/test/sprockets/80fbd1f419ec2c1133c164b09a4faa41 +0 -0
  355. data/spec/internal/tmp/cache/assets/test/sprockets/81ecd9c94638acd3ece19ecac462a723 +0 -0
  356. data/spec/internal/tmp/cache/assets/test/sprockets/82f457826b6170c0fd009ef469f31e16 +0 -0
  357. data/spec/internal/tmp/cache/assets/test/sprockets/8401fd13fe82bb392806930ed02005e1 +0 -0
  358. data/spec/internal/tmp/cache/assets/test/sprockets/89051a85201a06056a8d2b0c9f86cc67 +0 -0
  359. data/spec/internal/tmp/cache/assets/test/sprockets/8b503f71e2ed168eb20ff8cfc20ff3d4 +0 -0
  360. data/spec/internal/tmp/cache/assets/test/sprockets/8c7f3211b77d6699db8521f074d3e871 +0 -0
  361. data/spec/internal/tmp/cache/assets/test/sprockets/967c4a151c00ff79d54eab287c5a949b +0 -0
  362. data/spec/internal/tmp/cache/assets/test/sprockets/9a96d61233d5cc5799c7fc16fd9655c3 +0 -0
  363. data/spec/internal/tmp/cache/assets/test/sprockets/9c4023aaef54415afaf4892ced299f30 +0 -0
  364. data/spec/internal/tmp/cache/assets/test/sprockets/9d2b8824bdb90dbf4cc8b238820f5536 +0 -0
  365. data/spec/internal/tmp/cache/assets/test/sprockets/a16e48f0f9253ddceef37908141e96c3 +0 -0
  366. data/spec/internal/tmp/cache/assets/test/sprockets/a58efe476f9446653ee3ae72f0a61fad +0 -0
  367. data/spec/internal/tmp/cache/assets/test/sprockets/a5b14fb35b6609fda372da27bcd729a7 +0 -0
  368. data/spec/internal/tmp/cache/assets/test/sprockets/a9a428b52df1827450a88aa09e03c638 +0 -0
  369. data/spec/internal/tmp/cache/assets/test/sprockets/a9e4b0d4e6cb29a1cbc5e016fbcc0fb9 +0 -0
  370. data/spec/internal/tmp/cache/assets/test/sprockets/ada353bb8ffe3eb0f2dd479e6d869a70 +0 -0
  371. data/spec/internal/tmp/cache/assets/test/sprockets/aed5b98e50f137ce9635dd1ec2e825ae +0 -0
  372. data/spec/internal/tmp/cache/assets/test/sprockets/b148a5e98ff09a12b6a2139af1e62e46 +0 -0
  373. data/spec/internal/tmp/cache/assets/test/sprockets/b3b3d7f6ecf32ce8216b40eccc5da386 +0 -0
  374. data/spec/internal/tmp/cache/assets/test/sprockets/b9d7d32e6982bd30b74f8e53b9217c17 +0 -0
  375. data/spec/internal/tmp/cache/assets/test/sprockets/baf77fc130c9f3d5a5aa7fb780485a04 +0 -0
  376. data/spec/internal/tmp/cache/assets/test/sprockets/bbb1efb94f355bd05863c07b6f552c58 +0 -0
  377. data/spec/internal/tmp/cache/assets/test/sprockets/bd0dea58c57774fef248f0b0844a4654 +0 -0
  378. data/spec/internal/tmp/cache/assets/test/sprockets/bd4a5121c6495d513075e759f8cca6ed +0 -0
  379. data/spec/internal/tmp/cache/assets/test/sprockets/c052b51dcc86bc3909b8d1f00ec52063 +0 -0
  380. data/spec/internal/tmp/cache/assets/test/sprockets/c6d2f8432ae24aaa27e3c17827d59e9a +0 -0
  381. data/spec/internal/tmp/cache/assets/test/sprockets/c89f789c6b72000300327021b7d4c5c2 +0 -0
  382. data/spec/internal/tmp/cache/assets/test/sprockets/cbb27eb65bd8fb970a233e18ba352e8f +0 -0
  383. data/spec/internal/tmp/cache/assets/test/sprockets/cdf8872264f5f8dd811cdf810f6875a7 +0 -0
  384. data/spec/internal/tmp/cache/assets/test/sprockets/cffd775d018f68ce5dba1ee0d951a994 +0 -0
  385. data/spec/internal/tmp/cache/assets/test/sprockets/d0196b42a14494523f6911335f616faf +0 -0
  386. data/spec/internal/tmp/cache/assets/test/sprockets/d2473a08bfca80032fc2b63d1b701155 +0 -0
  387. data/spec/internal/tmp/cache/assets/test/sprockets/d510daa6eb0cd4805bff7fd0990dfdb5 +0 -0
  388. data/spec/internal/tmp/cache/assets/test/sprockets/d610f39602b6149ca02638c1728778b5 +0 -0
  389. data/spec/internal/tmp/cache/assets/test/sprockets/d771ace226fc8215a3572e0aa35bb0d6 +0 -0
  390. data/spec/internal/tmp/cache/assets/test/sprockets/d91f67015353a832fa2e3833f735348c +0 -0
  391. data/spec/internal/tmp/cache/assets/test/sprockets/da3f0c774f5df0a1a089c222895df846 +0 -0
  392. data/spec/internal/tmp/cache/assets/test/sprockets/db2cddc1e711c9846ddae11154b7e021 +0 -0
  393. data/spec/internal/tmp/cache/assets/test/sprockets/dc85d6ffbe7a752fa33121a762c54962 +0 -0
  394. data/spec/internal/tmp/cache/assets/test/sprockets/e0e4f218b157ae599e12a247a4cf8710 +0 -0
  395. data/spec/internal/tmp/cache/assets/test/sprockets/e1b5310fd1def23fa4153a98c6f4ec94 +0 -0
  396. data/spec/internal/tmp/cache/assets/test/sprockets/e214f7e5fca115c8dd417b1756b6c74e +0 -0
  397. data/spec/internal/tmp/cache/assets/test/sprockets/e33bc43550b9803eb105d236a57226ae +0 -0
  398. data/spec/internal/tmp/cache/assets/test/sprockets/e60245101cbc86285dea16c630966171 +0 -0
  399. data/spec/internal/tmp/cache/assets/test/sprockets/e9c2a0f2fa471ace3f7ed3a1f1b9ffc5 +0 -0
  400. data/spec/internal/tmp/cache/assets/test/sprockets/ea0ece5befbce765051e27cf991cc805 +0 -0
  401. data/spec/internal/tmp/cache/assets/test/sprockets/ea537228e3763da36f19f836971837bf +0 -0
  402. data/spec/internal/tmp/cache/assets/test/sprockets/eb8e9f5bc31c8df8014af288cf304fa2 +0 -0
  403. data/spec/internal/tmp/cache/assets/test/sprockets/ee98c5174937598bf3cc6cbd06de1930 +0 -0
  404. data/spec/internal/tmp/cache/assets/test/sprockets/efcc92e2af63ff01bdb496a5cd405447 +0 -0
  405. data/spec/internal/tmp/cache/assets/test/sprockets/f43e6de318148b8815fa65c6fd6ea092 +0 -0
  406. data/spec/internal/tmp/cache/assets/test/sprockets/f4dfad893ed757565a389ceceeadcbc1 +0 -0
  407. data/spec/internal/tmp/cache/assets/test/sprockets/f7cbd26ba1d28d48de824f0e94586655 +0 -0
  408. data/spec/internal/tmp/cache/assets/test/sprockets/f96152606fbc5602cd65176f6098f69a +0 -0
  409. data/spec/internal/tmp/cache/assets/test/sprockets/fb0dfe7bc7417e1329d9cc6c913584e9 +0 -0
  410. data/spec/internal/tmp/cache/assets/test/sprockets/fb4a42a3e047a7a0d87f3ad55c8d267a +0 -0
  411. data/spec/internal/tmp/cache/assets/test/sprockets/fd9f0ae81e726ff65daa70db0055de1a +0 -0
  412. data/spec/internal/tmp/cache/assets/test/sprockets/fecd72966f3f2994e3d5894e05d76bd8 +0 -0
  413. data/spec/internal/tmp/cache/assets/test/sprockets/ff775ea5449360537913ffb102837dfa +0 -0
  414. data/spec/repository_models/generic_work_spec.rb +92 -0
  415. data/spec/repository_models/hydramata/group_membership_form_spec.rb +86 -0
  416. data/spec/repository_models/hydramata/group_spec.rb +91 -0
  417. data/spec/repository_models/person_spec.rb +44 -0
  418. data/spec/support/shared/shared_examples_is_a_curation_concern_controller.rb +23 -1
  419. data/spec/support/shared/shared_examples_remotely_identified.rb +10 -2
  420. metadata +640 -21
  421. data/app/controllers/curate/organizations_controller.rb +0 -96
  422. data/app/helpers/curate/organizations_helper.rb +0 -13
  423. data/app/repository_models/organization.rb +0 -17
  424. data/app/views/curate/organizations/_button_create_organization.html.erb +0 -1
  425. data/app/views/curate/organizations/edit.html.erb +0 -4
  426. data/app/views/curate/organizations/index.html.erb +0 -11
  427. data/app/views/curate/organizations/show.html.erb +0 -27
  428. data/app/views/organizations/_organization.html.erb +0 -30
  429. data/spec/controllers/curate/organizations_controller_spec.rb +0 -50
  430. data/spec/factories/organizations_factory.rb +0 -21
  431. data/spec/repository_models/organization_spec.rb +0 -66
@@ -8,6 +8,12 @@ Bundler.require(:default, Rails.env)
8
8
 
9
9
  module Internal
10
10
  class Application < Rails::Application
11
+
12
+ config.generators do |g|
13
+ g.test_framework :rspec, :spec => true
14
+ end
15
+
16
+
11
17
  # Settings in config/environments/* take precedence over those specified here.
12
18
  # Application configuration should go into files in config/initializers
13
19
  # -- all .rb files in that directory are automatically loaded.
@@ -0,0 +1,5 @@
1
+ ---
2
+ :username: apitest
3
+ :password: apitest
4
+ :shoulder: doi:10.5072/FK2
5
+ :url: https://ezid.lib.purdue.edu/ezid/
@@ -17,7 +17,8 @@ Internal::Application.configure do
17
17
  config.static_cache_control = "public, max-age=3600"
18
18
 
19
19
  # Show full error reports and disable caching.
20
- config.consider_all_requests_local = true
20
+ # For end to end specs, I want the exception handler capturing things; Not raising exceptions.
21
+ config.consider_all_requests_local = ENV['LOCAL'] || false
21
22
  config.action_controller.perform_caching = false
22
23
 
23
24
  # Raise exceptions instead of rendering exception templates.
@@ -0,0 +1,14 @@
1
+ development:
2
+ user: fedoraAdmin
3
+ password: fedoraAdmin
4
+ url: http://127.0.0.1:8983/fedora
5
+ test: &TEST
6
+ user: fedoraAdmin
7
+ password: fedoraAdmin
8
+ url: <%= "http://127.0.0.1:#{ENV['TEST_JETTY_PORT'] || 8983}/fedora-test" %>
9
+ production:
10
+ user: fedoraAdmin
11
+ password: fedoraAdmin
12
+ url: http://your.production.server:8080/fedora
13
+ cucumber:
14
+ <<: *TEST
@@ -0,0 +1,12 @@
1
+ module ActionDispatch
2
+ module Http
3
+ class UploadedFile
4
+ def closed?
5
+ @tempfile.closed?
6
+ end
7
+ def close
8
+ @tempfile.close
9
+ end
10
+ end
11
+ end
12
+ end
@@ -0,0 +1,30 @@
1
+ Curate.configure do |config|
2
+ # Injected via `rails g curate:work Spam`
3
+ config.register_curation_concern :spam
4
+ config.application_root_url = 'http://localhost'
5
+ config.default_antivirus_instance = lambda {|file_path|
6
+ AntiVirusScanner::NO_VIRUS_FOUND_RETURN_VALUE
7
+ }
8
+ config.characterization_runner = lambda {|file_path|
9
+ Curate::Engine.root.join('spec/support/files/default_fits_output.xml').read
10
+ }
11
+ config.register_curation_concern :generic_work
12
+ config.register_curation_concern :dataset
13
+ config.register_curation_concern :article
14
+ config.register_curation_concern :etd
15
+ config.register_curation_concern :image
16
+ config.register_curation_concern :document
17
+ # # You can override curate's antivirus runner by configuring a lambda (or
18
+ # # object that responds to call)
19
+ # config.default_antivirus_instance = lambda {|filename| … }
20
+
21
+ # # Used for constructing permanent URLs
22
+ # config.application_root_url = 'https://repository.higher.edu/'
23
+
24
+ # # Used to load values for constructing SOLR searches
25
+ search_config_file = File.join(Rails.root, 'config', 'search_config.yml')
26
+ config.search_config = YAML::load(File.open(search_config_file))[Rails.env].with_indifferent_access
27
+
28
+ # # Override the file characterization runner that is used
29
+ # config.characterization_runner = lambda {|filename| … }
30
+ end
@@ -0,0 +1,256 @@
1
+ # Use this hook to configure devise mailer, warden hooks and so forth.
2
+ # Many of these configuration options can be set straight in your model.
3
+ Devise.setup do |config|
4
+ # The secret key used by Devise. Devise uses this key to generate
5
+ # random tokens. Changing this key will render invalid all existing
6
+ # confirmation, reset password and unlock tokens in the database.
7
+ # config.secret_key = '64f4521c2c6523e1a529b200c7712def904ab2885c3e365dac8196f05ed3f2fc302bb06ec7c8a06b9cf0aed7554a81eae7d272e75816e85c0d3be2a35a4fe78c'
8
+
9
+ # ==> Mailer Configuration
10
+ # Configure the e-mail address which will be shown in Devise::Mailer,
11
+ # note that it will be overwritten if you use your own mailer class
12
+ # with default "from" parameter.
13
+ config.mailer_sender = 'please-change-me-at-config-initializers-devise@example.com'
14
+
15
+ # Configure the class responsible to send e-mails.
16
+ # config.mailer = 'Devise::Mailer'
17
+
18
+ # ==> ORM configuration
19
+ # Load and configure the ORM. Supports :active_record (default) and
20
+ # :mongoid (bson_ext recommended) by default. Other ORMs may be
21
+ # available as additional gems.
22
+ require 'devise/orm/active_record'
23
+
24
+ # ==> Configuration for any authentication mechanism
25
+ # Configure which keys are used when authenticating a user. The default is
26
+ # just :email. You can configure it to use [:username, :subdomain], so for
27
+ # authenticating a user, both parameters are required. Remember that those
28
+ # parameters are used only when authenticating and not when retrieving from
29
+ # session. If you need permissions, you should implement that in a before filter.
30
+ # You can also supply a hash where the value is a boolean determining whether
31
+ # or not authentication should be aborted when the value is not present.
32
+ # config.authentication_keys = [ :email ]
33
+
34
+ # Configure parameters from the request object used for authentication. Each entry
35
+ # given should be a request method and it will automatically be passed to the
36
+ # find_for_authentication method and considered in your model lookup. For instance,
37
+ # if you set :request_keys to [:subdomain], :subdomain will be used on authentication.
38
+ # The same considerations mentioned for authentication_keys also apply to request_keys.
39
+ # config.request_keys = []
40
+
41
+ # Configure which authentication keys should be case-insensitive.
42
+ # These keys will be downcased upon creating or modifying a user and when used
43
+ # to authenticate or find a user. Default is :email.
44
+ config.case_insensitive_keys = [ :email ]
45
+
46
+ # Configure which authentication keys should have whitespace stripped.
47
+ # These keys will have whitespace before and after removed upon creating or
48
+ # modifying a user and when used to authenticate or find a user. Default is :email.
49
+ config.strip_whitespace_keys = [ :email ]
50
+
51
+ # Tell if authentication through request.params is enabled. True by default.
52
+ # It can be set to an array that will enable params authentication only for the
53
+ # given strategies, for example, `config.params_authenticatable = [:database]` will
54
+ # enable it only for database (email + password) authentication.
55
+ # config.params_authenticatable = true
56
+
57
+ # Tell if authentication through HTTP Auth is enabled. False by default.
58
+ # It can be set to an array that will enable http authentication only for the
59
+ # given strategies, for example, `config.http_authenticatable = [:database]` will
60
+ # enable it only for database authentication. The supported strategies are:
61
+ # :database = Support basic authentication with authentication key + password
62
+ # config.http_authenticatable = false
63
+
64
+ # If http headers should be returned for AJAX requests. True by default.
65
+ # config.http_authenticatable_on_xhr = true
66
+
67
+ # The realm used in Http Basic Authentication. 'Application' by default.
68
+ # config.http_authentication_realm = 'Application'
69
+
70
+ # It will change confirmation, password recovery and other workflows
71
+ # to behave the same regardless if the e-mail provided was right or wrong.
72
+ # Does not affect registerable.
73
+ # config.paranoid = true
74
+
75
+ # By default Devise will store the user in session. You can skip storage for
76
+ # particular strategies by setting this option.
77
+ # Notice that if you are skipping storage for all authentication paths, you
78
+ # may want to disable generating routes to Devise's sessions controller by
79
+ # passing skip: :sessions to `devise_for` in your config/routes.rb
80
+ config.skip_session_storage = [:http_auth]
81
+
82
+ # By default, Devise cleans up the CSRF token on authentication to
83
+ # avoid CSRF token fixation attacks. This means that, when using AJAX
84
+ # requests for sign in and sign up, you need to get a new CSRF token
85
+ # from the server. You can disable this option at your own risk.
86
+ # config.clean_up_csrf_token_on_authentication = true
87
+
88
+ # ==> Configuration for :database_authenticatable
89
+ # For bcrypt, this is the cost for hashing the password and defaults to 10. If
90
+ # using other encryptors, it sets how many times you want the password re-encrypted.
91
+ #
92
+ # Limiting the stretches to just one in testing will increase the performance of
93
+ # your test suite dramatically. However, it is STRONGLY RECOMMENDED to not use
94
+ # a value less than 10 in other environments. Note that, for bcrypt (the default
95
+ # encryptor), the cost increases exponentially with the number of stretches (e.g.
96
+ # a value of 20 is already extremely slow: approx. 60 seconds for 1 calculation).
97
+ config.stretches = Rails.env.test? ? 1 : 10
98
+
99
+ # Setup a pepper to generate the encrypted password.
100
+ # config.pepper = '4e08eeed8a45fb3fe0720872e609ed87fc5f3c79fc2e492202a6992123343dd3ccbfb0ba67e2b22bd2d6a91dcd6276c6161d616e45e5bea39ef8185e5b8663f2'
101
+
102
+ # ==> Configuration for :confirmable
103
+ # A period that the user is allowed to access the website even without
104
+ # confirming their account. For instance, if set to 2.days, the user will be
105
+ # able to access the website for two days without confirming their account,
106
+ # access will be blocked just in the third day. Default is 0.days, meaning
107
+ # the user cannot access the website without confirming their account.
108
+ # config.allow_unconfirmed_access_for = 2.days
109
+
110
+ # A period that the user is allowed to confirm their account before their
111
+ # token becomes invalid. For example, if set to 3.days, the user can confirm
112
+ # their account within 3 days after the mail was sent, but on the fourth day
113
+ # their account can't be confirmed with the token any more.
114
+ # Default is nil, meaning there is no restriction on how long a user can take
115
+ # before confirming their account.
116
+ # config.confirm_within = 3.days
117
+
118
+ # If true, requires any email changes to be confirmed (exactly the same way as
119
+ # initial account confirmation) to be applied. Requires additional unconfirmed_email
120
+ # db field (see migrations). Until confirmed, new email is stored in
121
+ # unconfirmed_email column, and copied to email column on successful confirmation.
122
+ config.reconfirmable = true
123
+
124
+ # Defines which key will be used when confirming an account
125
+ # config.confirmation_keys = [ :email ]
126
+
127
+ # ==> Configuration for :rememberable
128
+ # The time the user will be remembered without asking for credentials again.
129
+ # config.remember_for = 2.weeks
130
+
131
+ # If true, extends the user's remember period when remembered via cookie.
132
+ # config.extend_remember_period = false
133
+
134
+ # Options to be passed to the created cookie. For instance, you can set
135
+ # secure: true in order to force SSL only cookies.
136
+ # config.rememberable_options = {}
137
+
138
+ # ==> Configuration for :validatable
139
+ # Range for password length.
140
+ config.password_length = 8..128
141
+
142
+ # Email regex used to validate email formats. It simply asserts that
143
+ # one (and only one) @ exists in the given string. This is mainly
144
+ # to give user feedback and not to assert the e-mail validity.
145
+ # config.email_regexp = /\A[^@]+@[^@]+\z/
146
+
147
+ # ==> Configuration for :timeoutable
148
+ # The time you want to timeout the user session without activity. After this
149
+ # time the user will be asked for credentials again. Default is 30 minutes.
150
+ # config.timeout_in = 30.minutes
151
+
152
+ # If true, expires auth token on session timeout.
153
+ # config.expire_auth_token_on_timeout = false
154
+
155
+ # ==> Configuration for :lockable
156
+ # Defines which strategy will be used to lock an account.
157
+ # :failed_attempts = Locks an account after a number of failed attempts to sign in.
158
+ # :none = No lock strategy. You should handle locking by yourself.
159
+ # config.lock_strategy = :failed_attempts
160
+
161
+ # Defines which key will be used when locking and unlocking an account
162
+ # config.unlock_keys = [ :email ]
163
+
164
+ # Defines which strategy will be used to unlock an account.
165
+ # :email = Sends an unlock link to the user email
166
+ # :time = Re-enables login after a certain amount of time (see :unlock_in below)
167
+ # :both = Enables both strategies
168
+ # :none = No unlock strategy. You should handle unlocking by yourself.
169
+ # config.unlock_strategy = :both
170
+
171
+ # Number of authentication tries before locking an account if lock_strategy
172
+ # is failed attempts.
173
+ # config.maximum_attempts = 20
174
+
175
+ # Time interval to unlock the account if :time is enabled as unlock_strategy.
176
+ # config.unlock_in = 1.hour
177
+
178
+ # Warn on the last attempt before the account is locked.
179
+ # config.last_attempt_warning = false
180
+
181
+ # ==> Configuration for :recoverable
182
+ #
183
+ # Defines which key will be used when recovering the password for an account
184
+ # config.reset_password_keys = [ :email ]
185
+
186
+ # Time interval you can reset your password with a reset password key.
187
+ # Don't put a too small interval or your users won't have the time to
188
+ # change their passwords.
189
+ config.reset_password_within = 6.hours
190
+
191
+ # ==> Configuration for :encryptable
192
+ # Allow you to use another encryption algorithm besides bcrypt (default). You can use
193
+ # :sha1, :sha512 or encryptors from others authentication tools as :clearance_sha1,
194
+ # :authlogic_sha512 (then you should set stretches above to 20 for default behavior)
195
+ # and :restful_authentication_sha1 (then you should set stretches to 10, and copy
196
+ # REST_AUTH_SITE_KEY to pepper).
197
+ #
198
+ # Require the `devise-encryptable` gem when using anything other than bcrypt
199
+ # config.encryptor = :sha512
200
+
201
+ # ==> Scopes configuration
202
+ # Turn scoped views on. Before rendering "sessions/new", it will first check for
203
+ # "users/sessions/new". It's turned off by default because it's slower if you
204
+ # are using only default views.
205
+ # config.scoped_views = false
206
+
207
+ # Configure the default scope given to Warden. By default it's the first
208
+ # devise role declared in your routes (usually :user).
209
+ # config.default_scope = :user
210
+
211
+ # Set this configuration to false if you want /users/sign_out to sign out
212
+ # only the current scope. By default, Devise signs out all scopes.
213
+ # config.sign_out_all_scopes = true
214
+
215
+ # ==> Navigation configuration
216
+ # Lists the formats that should be treated as navigational. Formats like
217
+ # :html, should redirect to the sign in page when the user does not have
218
+ # access, but formats like :xml or :json, should return 401.
219
+ #
220
+ # If you have any extra navigational formats, like :iphone or :mobile, you
221
+ # should add them to the navigational formats lists.
222
+ #
223
+ # The "*/*" below is required to match Internet Explorer requests.
224
+ # config.navigational_formats = ['*/*', :html]
225
+
226
+ # The default HTTP method used to sign out a resource. Default is :delete.
227
+ config.sign_out_via = :get
228
+
229
+ # ==> OmniAuth
230
+ # Add a new OmniAuth provider. Check the wiki for more information on setting
231
+ # up on your models and hooks.
232
+ # config.omniauth :github, 'APP_ID', 'APP_SECRET', scope: 'user,public_repo'
233
+
234
+ # ==> Warden configuration
235
+ # If you want to use other strategies, that are not supported by Devise, or
236
+ # change the failure app, you can configure them inside the config.warden block.
237
+ #
238
+ # config.warden do |manager|
239
+ # manager.intercept_401 = false
240
+ # manager.default_strategies(scope: :user).unshift :some_external_strategy
241
+ # end
242
+
243
+ # ==> Mountable engine configurations
244
+ # When using Devise inside an engine, let's call it `MyEngine`, and this engine
245
+ # is mountable, there are some extra configurations to be taken into account.
246
+ # The following options are available, assuming the engine is mounted as:
247
+ #
248
+ # mount MyEngine, at: '/my_engine'
249
+ #
250
+ # The router that invoked `devise_for`, in the example above, would be:
251
+ # config.router_name = :my_engine
252
+ #
253
+ # When using omniauth, Devise cannot automatically set Omniauth path,
254
+ # so you need to do it manually. For the users scope, it would be:
255
+ # config.omniauth_path_prefix = '/my_engine/users/auth'
256
+ end
@@ -0,0 +1,29 @@
1
+ # Register and configure remote identifiers for persisted objects
2
+ Hydra::RemoteIdentifier.configure do |config|
3
+ doi_credentials = Psych.load_file(Rails.root.join("config/doi.yml"))
4
+ config.remote_service(:doi, doi_credentials) do |doi|
5
+ doi.register(GenericWork, Dataset, Article, Etd, Image, Document) do |map|
6
+ map.target {|obj| Curate.permanent_url_for(obj) }
7
+ map.creator :creator
8
+ map.title :title
9
+ map.publisher {|o| Array(o.publisher).join("; ")}
10
+ map.publicationyear {|o| o.date_uploaded.year }
11
+ # Make sure that this method both sets the identifier and persists the change!
12
+ map.set_identifier {|o,value| o.identifier = value; o.save }
13
+ end
14
+ end
15
+
16
+ # doi_credentials = Psych.load_file("/path/to/doi_credentials.yml")
17
+ # config.remote_service(:doi, doi_credentials) do |doi|
18
+ # doi.register(PersistedObject) do |map|
19
+ # map.target :url
20
+ # map.creator {|obj| obj.person_name }
21
+ # map.title :title
22
+ # map.publisher :publisher
23
+ # map.publicationyear :publicationyear
24
+ #
25
+ # # Make sure that this method persists the value
26
+ # map.set_identifier :set_doi_identifier=
27
+ # end
28
+ # end
29
+ end
@@ -0,0 +1,28 @@
1
+ # The following lines determine which user attributes your hydrangea app will use
2
+ # This configuration allows you to use the out of the box ActiveRecord associations between users and user_attributes
3
+ # It also allows you to specify your own user attributes
4
+ # The easiest way to override these methods would be to create your own module to include in User
5
+ # For example you could create a module for your local LDAP instance called MyLocalLDAPUserAttributes:
6
+ # User.send(:include, MyLocalLDAPAttributes)
7
+ # As long as your module includes methods for full_name, affiliation, and photo the personalization_helper should function correctly
8
+ #
9
+
10
+ # windows doesn't properly require hydra-head (from the gemfile), so we need to require it explicitly here:
11
+ require 'hydra/head' unless defined? Hydra
12
+
13
+ if Hydra.respond_to?(:configure)
14
+ Hydra.configure(:shared) do |config|
15
+ # This specifies the solr field names of permissions-related fields.
16
+ # You only need to change these values if you've indexed permissions by some means other than the Hydra's built-in tooling.
17
+ # If you change these, you must also update the permissions request handler in your solrconfig.xml to return those values
18
+ indexer = Solrizer::Descriptor.new(:string, :stored, :indexed, :multivalued)
19
+ config[:permissions] = {
20
+ :discover => {:group =>ActiveFedora::SolrService.solr_name("discover_access_group", indexer), :individual=>ActiveFedora::SolrService.solr_name("discover_access_person", indexer)},
21
+ :read => {:group =>ActiveFedora::SolrService.solr_name("read_access_group", indexer), :individual=>ActiveFedora::SolrService.solr_name("read_access_person", indexer)},
22
+ :edit => {:group =>ActiveFedora::SolrService.solr_name("edit_access_group", indexer), :individual=>ActiveFedora::SolrService.solr_name("edit_access_person", indexer)},
23
+ :owner => ActiveFedora::SolrService.solr_name("depositor", indexer),
24
+ :embargo_release_date => ActiveFedora::SolrService.solr_name("embargo_release_date", Solrizer::Descriptor.new(:date, :stored, :indexed))
25
+ }
26
+
27
+ end
28
+ end
@@ -0,0 +1,17 @@
1
+ Mailboxer.setup do |config|
2
+
3
+ #Configures if you applications uses or no the email sending for Notifications and Messages
4
+ config.uses_emails = true
5
+
6
+ #Configures the default from for the email sent for Messages and Notifications of Mailboxer
7
+ config.default_from = "no-reply@mailboxer.com"
8
+
9
+ #Configures the methods needed by mailboxer
10
+ config.email_method = :mailboxer_email
11
+ config.name_method = :name
12
+
13
+ #Configures if you use or not a search engine and wich one are you using
14
+ #Supported enignes: [:solr,:sphinx]
15
+ config.search_enabled = false
16
+ config.search_engine = :solr
17
+ end
@@ -1,4 +1,11 @@
1
- # Be sure to restart your server when you modify this file.
1
+ # Be sure to restart your server when you modify this file.Mime::Type.register_alias "text/plain", :refworks_marc_txt
2
+ Mime::Type.register_alias "text/plain", :openurl_kev
3
+ Mime::Type.register "application/x-endnote-refer", :endnote
4
+ Mime::Type.register "application/marc", :marc
5
+ Mime::Type.register "application/marcxml+xml", :marcxml,
6
+ ["application/x-marc+xml", "application/x-marcxml+xml",
7
+ "application/marc+xml"]
8
+
2
9
 
3
10
  # Add new mime types for use in respond_to blocks:
4
11
  # Mime::Type.register "text/richtext", :rtf
@@ -0,0 +1,32 @@
1
+ if defined?(PhusionPassenger)
2
+ PhusionPassenger.on_event(:starting_worker_process) do |forked|
3
+ # We're in smart spawning mode.
4
+ if forked
5
+ # Re-establish redis connection
6
+ require 'redis'
7
+ config = YAML::load(ERB.new(IO.read(File.join(Rails.root, 'config', 'redis.yml'))).result)[Rails.env].with_indifferent_access
8
+
9
+ # The important two lines
10
+ $redis.client.disconnect if $redis
11
+ $redis = Redis.new(host: config[:host], port: config[:port], thread_safe: true) rescue nil
12
+ Resque.redis = $redis
13
+ Resque.redis.client.reconnect if Resque.redis
14
+ end
15
+ end
16
+ else
17
+ config = YAML::load(ERB.new(IO.read(File.join(Rails.root, 'config', 'redis.yml'))).result)[Rails.env].with_indifferent_access
18
+ $redis = Redis.new(host: config[:host], port: config[:port], thread_safe: true) rescue nil
19
+ end
20
+
21
+
22
+ # Code borrowed from Obie's Redis patterns talk at RailsConf'12
23
+ Nest.class_eval do
24
+ def initialize(key, redis=$redis)
25
+ super(key.to_param)
26
+ @redis = redis
27
+ end
28
+
29
+ def [](key)
30
+ self.class.new("#{self}:#{key.to_param}", @redis)
31
+ end
32
+ end