lib/searchkick.rb in searchkick-0.0.1 vs lib/searchkick.rb in searchkick-0.0.2

- old
+ new

@@ -1,49 +1,9 @@ require "searchkick/version" +require "searchkick/reindex" +require "searchkick/search" +require "searchkick/model" require "searchkick/tasks" require "tire" +require "active_record" # TODO only require active_model -module Searchkick - module ClassMethods - - # https://gist.github.com/jarosan/3124884 - def reindex - alias_name = klass.tire.index.name - new_index = alias_name + "_" + Time.now.strftime("%Y%m%d%H%M%S") - - # Rake::Task["tire:import"].invoke - index = Tire::Index.new(new_index) - Tire::Tasks::Import.create_index(index, klass) - scope = klass.respond_to?(:tire_import) ? klass.tire_import : klass - scope.find_in_batches do |batch| - index.import batch - end - - if a = Tire::Alias.find(alias_name) - puts "[IMPORT] Alias found: #{Tire::Alias.find(alias_name).indices.to_ary.join(",")}" - old_indices = Tire::Alias.find(alias_name).indices - old_indices.each do |index| - a.indices.delete index - end - - a.indices.add new_index - a.save - - old_indices.each do |index| - puts "[IMPORT] Deleting index: #{index}" - i = Tire::Index.new(index) - i.delete if i.exists? - end - else - puts "[IMPORT] No alias found. Deleting index, creating new one, and setting up alias" - i = Tire::Index.new(alias_name) - i.delete if i.exists? - Tire::Alias.create(name: alias_name, indices: [new_index]) - end - - puts "[IMPORT] Saved alias #{alias_name} pointing to #{new_index}" - end - - end -end - -Tire::Model::Search::ClassMethodsProxy.send :include, Searchkick::ClassMethods +ActiveRecord::Base.send(:extend, Searchkick::Model)