Algolia Search for Rails
==================
This gem let you easily integrate the Algolia Search API to your favorite ORM. It's based on the [algoliasearch-client-ruby](https://github.com/algolia/algoliasearch-client-ruby) gem.
[data:image/s3,"s3://crabby-images/96b5a/96b5abc5033250974f51d0365e0af11063d18dc8" alt="Build Status"](https://travis-ci.org/algolia/algoliasearch-rails) [data:image/s3,"s3://crabby-images/02e24/02e245ef28e971ffe6069a5cb6dfb00c09afd75a" alt="Gem Version"](http://badge.fury.io/rb/algoliasearch-rails) [data:image/s3,"s3://crabby-images/8788e/8788ecdb67440492c9b15dac671b93808dd56cc9" alt="Code Climate"](https://codeclimate.com/github/algolia/algoliasearch-rails)
Table of Content
-------------
**Get started**
1. [Install](#install)
1. [Setup](#setup)
1. [Quick Start](#quick-start)
1. [Options](#options)
1. [Indexing](#indexing)
1. [Search settings](#search-settings)
1. [Note on testing](#note-on-testing)
Install
-------------
```sh
gem install algoliasearch-rails
```
If you are using Rails 3, add the gem to your Gemfile
:
```ruby
gem "algoliasearch-rails"
```
And run:
```sh
bundle install
```
Setup
-------------
Create a new file config/initializers/algoliasearch.rb
to setup your APPLICATION_ID
and API_KEY
.
```ruby
AlgoliaSearch.configuration = { application_id: 'YourApplicationID', api_key: 'YourAPIKey' }
```
We support both [will_paginate](https://github.com/mislav/will_paginate) and [kaminari](https://github.com/amatsuda/kaminari) as pagination backend. For example to use :will_paginate
, specify the :pagination_backend
as follow:
```ruby
AlgoliaSearch.configuration = { application_id: 'YourApplicationID', api_key: 'YourAPIKey', pagination_backend: :will_paginate }
```
Quick Start
-------------
The following code will create a contact
index and add search capabilities to your Contact
model:
```ruby
class Contact < ActiveRecord::Base
include AlgoliaSearch
algoliasearch do
attribute :first_name, :last_name, :email
end
end
```
You can either specify the attributes to send (here we restrict to :first_name, :last_name, :email
) or not (in that case, all attributes are sent).
```ruby
class Product < ActiveRecord::Base
include AlgoliaSearch
algoliasearch do
# all attributes will be sent
end
end
```
```ruby
p Contact.search("jon doe")
```
Options
----------
Each time a record is saved; it will be - synchronously - indexed. In the other hand, each time a record is destroyed, it will be - synchronoulsy - removed from the index.
You can disable auto-indexing and auto-removing setting the following options:
```ruby
class Contact < ActiveRecord::Base
include AlgoliaSearch
algoliasearch auto_index: false, auto_remove: false do
attribute :first_name, :last_name, :email
end
end
```
You can force indexing and removing to be asynchronous by setting the following option:
```ruby
class Contact < ActiveRecord::Base
include AlgoliaSearch
algoliasearch synchronous: false do
attribute :first_name, :last_name, :email
end
end
```
You can force force the index name using the following option:
```ruby
class Contact < ActiveRecord::Base
include AlgoliaSearch
algoliasearch index_name: "contacts_#{Rails.env}" do
attribute :first_name, :last_name, :email
end
end
```
Indexing
---------
You can trigger indexing using the index!
instance method.
```ruby
c = Contact.create!(params[:contact])
c.index!
```
And trigger index removing using the remove_from_index!
instance method.
```ruby
c.remove_from_index!
c.destroy
```
To reindex all your records, use the reindex!
class method:
```ruby
Contact.reindex!
```
To clear an index, use the clear_index!
class method:
```ruby
Contact.clear_index!
```
Search settings
----------
All [settings](https://github.com/algolia/algoliasearch-client-ruby#index-settings) can be specified either statically in your model or dynamically at search time using [search options](https://github.com/algolia/algoliasearch-client-ruby#search):
```ruby
class Contact < ActiveRecord::Base
include AlgoliaSearch
algoliasearch auto_index: false, auto_remove: false do
attribute :first_name, :last_name, :email
minWordSizeForApprox1 2
minWordSizeForApprox2 5
hitsPerPage 42
end
end
```
```ruby
p Contact.search("jon doe", hitsPerPage: 5, page: 2)
```
Note on testing
-----------------
To run the specs, please set the ALGOLIA_APPLICATION_ID
and ALGOLIA_API_KEY
environment variables. Since the tests are creating and removing indexes, DO NOT use your production account.