acts_as_ferret

This ActiveRecord mixin adds full text search capabilities to any Rails model.

It is heavily based on the original acts_as_ferret plugin done by Kasper Weibel and a modified version done by Thomas Lockney, which both can be found on ferret.davebalmain.com/trac/wiki/FerretOnRails

Project Homepage

rm.jkraemer.net/projects/show/aaf

Installation

Aaf is available via git from rubyforge.org and github.com. Github also offers tarball downloads, check out github.com/jkraemer/acts_as_ferret/tree/master .

Installation inside your Rails project via script/plugin

script/plugin install git://github.com/jkraemer/acts_as_ferret.git

The rubyforge repository is located at git://rubyforge.org/actsasferret.git

Old SVN repository

In november 2008 I stopped updating the svn repository that has been the main repository for aaf for several years. In case you want to retrieve any of the older versions of the plugin, it’s still there at

svn://code.jkraemer.net/acts_as_ferret/

System-wide installation with Rubygems

sudo gem install acts_as_ferret

To use acts_as_ferret in your project, add the following line to your project’s config/environment.rb:

require 'acts_as_ferret'

Call the aaf_install script that came with the gem inside your project directory to install the sample config file and the drb server start/stop script.

Usage

include the following in your model class (specifiying the fields you want to get indexed):

acts_as_ferret :fields => [ :title, :description ]

now you can use ModelClass.find_with_ferret(query) to find instances of your model whose indexed fields match a given query. All query terms are required by default, but explicit OR queries are possible. This differs from the ferret default, but imho is the more often needed/expected behaviour (more query terms result in less results).

Please see ActsAsFerret::ActMethods#acts_as_ferret for more information.

License

Released under the MIT license.

Authors

  • Kasper Weibel Nielsen-Refs (original author)

  • Jens Kraemer <[email protected]> (current maintainer)