Sha256: c33fa3adcbe0cef18e3a3ab4360b6be3d6154a7feda5a2cfe58d552cbea8b89e
Contents?: true
Size: 1.35 KB
Versions: 7
Compression:
Stored size: 1.35 KB
Contents
module Spree module Admin class SearchController < Spree::Admin::BaseController # http://spreecommerce.com/blog/2010/11/02/json-hijacking-vulnerability/ before_action :check_json_authenticity, only: :index respond_to :json # TODO: Clean this up by moving searching out to user_class_extensions # And then JSON building with something like Active Model Serializers def users if params[:ids] # split here may be String#split or Array#split, so we must flatten the results @users = Spree.user_class.where(id: params[:ids].split(',').flatten) else @users = Spree.user_class.ransack({ m: 'or', email_start: params[:q], addresses_firstname_start: params[:q], addresses_lastname_start: params[:q] }).result.limit(10) end end def products if params[:ids] # split here may be String#split or Array#split, so we must flatten the results @products = Product.where(id: params[:ids].split(",").flatten) else @products = Product.ransack(params[:q]).result end @products = @products.distinct.page(params[:page]).per(params[:per_page]) expires_in 15.minutes, public: true headers['Surrogate-Control'] = "max-age=#{15.minutes}" end end end end
Version data entries
7 entries across 7 versions & 1 rubygems