Sha256: 1f66f7df57c5f64d7eb006be2fb610624cd1a902d1b06e5bde3c14922936780b
Contents?: true
Size: 1.36 KB
Versions: 14
Compression:
Stored size: 1.36 KB
Contents
# -*- encoding : utf-8 -*- module Blacklight::Base extend ActiveSupport::Concern include Blacklight::Configurable include Blacklight::SearchHelper include Blacklight::Catalog::SearchContext included do # When Blacklight::Exceptions::InvalidRequest is raised, the rsolr_request_error method is executed. # The index action will more than likely throw this one. # Example, when the standard query parser is used, and a user submits a "bad" query. rescue_from Blacklight::Exceptions::InvalidRequest, with: :handle_request_error if respond_to? :rescue_from end protected # when The index throws an error (Blacklight::Exceptions::InvalidRequest), this method is executed. def handle_request_error(exception) if Rails.env.development? || Rails.env.test? raise exception # Rails own code will catch and give usual Rails error page with stack trace else flash_notice = I18n.t('blacklight.search.errors.request_error') # If there are errors coming from the index page, we want to trap those sensibly if flash[:notice] == flash_notice logger.error "Cowardly aborting rsolr_request_error exception handling, because we redirected to a page that raises another exception" raise exception end logger.error exception flash[:notice] = flash_notice redirect_to root_path end end end
Version data entries
14 entries across 14 versions & 1 rubygems