# Humanizer Humanizer is a very simple CAPTCHA method. It has a localized YAML file with questions and answers which is used to validate that the user is an actual human. Any model that includes ActiveModel::Validations should work. Our aim is to be database and mapper agnostic, so if it doesn't work for you, open an issue. Humanizer only works with Rails 3. ## Installation 1. `gem install humanizer` 2. `rails g humanizer` ## Advanced Installation * Install all locales: `rails g humanizer --all-locales` * Show available locales: `rails g humanizer --show-locales` * Install selected locales: `rails g humanizer en fi de` ## Usage 1. In your model, include Humanizer and add the #require_human_on method, example: class User < ActiveRecord::Base include Humanizer require_human_on :create end 2. Ask the question in the form, example: <%= f.label :humanizer_answer, @model.humanizer_question %> <%= f.text_field :humanizer_answer %> <%= f.hidden_field :humanizer_question_id %> 3. If you are using attr_accessible, remember to whitelist `:humanizer_answer` and `:humanizer_question_id`. ## Configuration Default translations can be found in config/locales/ You might want to add/change question and answer pairs. This can be easily done by adding/modifying entries in locales file. ## Skipping validation You might want to skip the humanizer validations on your tests or rails console. You can just have a simple attribute on your model and use it to bypass the validation. Here's an example: attr_accessor :bypass_humanizer require_human_on :create, :unless => :bypass_humanizer Now when bypass_humanizer is true, validation will be skipped. ## Live sites * [ArcticStartup.com](http://arcticstartup.com/) - signup form ## License Humanizer is licensed under the MIT License, for more details see the LICENSE file. ## Question/Answer Translations * English, Finnish and Portuguese translations by [Kisko Labs](http://kiskolabs.com/) * German by [Sven Schwyn](http://github.com/svoop) * Dutch by [Joren De Groof](http://github.com/joren) * Brazilian Portuguese by [Britto](http://github.com/britto) * Russian by [Shark](http://github.com/Serheo) ## Contributors * [Florian Bertholin](http://github.com/Arkan) * [seogrady](http://github.com/seogrady)