class ApplicationController < ActionController::Base protect_from_forgery rescue_from CanCan::AccessDenied, :with => :render_403 rescue_from ActiveRecord::RecordNotFound, :with => :render_404 private def render_403 return if performed? if user_signed_in? respond_to do |format| format.html {render :template => 'page/403', :status => 403} format.mobile {render :template => 'page/403', :status => 403} format.xml {render :template => 'page/403', :status => 403} format.json end else respond_to do |format| format.html {redirect_to new_user_session_url} format.mobile {redirect_to new_user_session_url} format.xml {render :template => 'page/403', :status => 403} format.json end end end def render_404 return if performed? respond_to do |format| format.html {render :template => 'page/404', :status => 404} format.mobile {render :template => 'page/404', :status => 404} format.xml {render :template => 'page/404', :status => 404} format.json end end def not_found raise ActiveRecord::RecordNotFound end def access_denied raise CanCan::AccessDenied end def store_location if request.get? and request.format.try(:html?) and !request.xhr? session[:user_return_to] = request.fullpath end end def get_user @user = User.where(:username => params[:user_id]).first if params[:user_id] #authorize! :show, @user if @user end def solr_commit Sunspot.commit end def convert_charset case params[:format] when 'csv' return unless Setting.csv_charset_conversion # TODO: 他の言語 if @locale.to_sym == :ja headers["Content-Type"] = "text/csv; charset=Shift_JIS" response.body = NKF::nkf('-Ws', response.body) end when 'xml' if @locale.to_sym == :ja headers["Content-Type"] = "application/xml; charset=Shift_JIS" response.body = NKF::nkf('-Ws', response.body) end end end end