# Yandex Cleanweb [![Build Status](https://travis-ci.org/evrone/yandex-cleanweb.png?branch=master)](https://travis-ci.org/evrone/yandex-cleanweb) Ruby wrapper for [Yandex Cleanweb](http://api.yandex.ru/cleanweb/) spam detector. Unfortunatelly, this gem *is not capable with MRI 1.8.7* because of MRI 1.8.7 doesn't have `URI.encode_www_form` method. ## Installation Add this line to your application's Gemfile: gem 'yandex_cleanweb', '~> 0.0.5' And then execute: $ bundle Or install it yourself as: $ gem install yandex_cleanweb ## Usage Get the api key: [http://api.yandex.ru/cleanweb/getkey.xml](http://api.yandex.ru/cleanweb/getkey.xml) ```ruby YandexCleanweb.api_key = "your_key" YandexCleanweb.spam?("just phrase") => false YandexCleanweb.spam?(body_plain: "my text", ip: "80.80.40.3") => false YandexCleanweb.spam?(body_html: "some spam spam link") => { id: "request id", links: [ ['http://spam.com', true] ] } ``` Tell Cleanweb API that message is spam: ```ruby YandexCleanweb.api_key = "your_key" YandexCleanweb.spam!("some spam here") YandexCleanweb.spam!(body_html: "some spam spam link") ``` More complex example: ```ruby user_input = "download free porn ..." if spam_check = YandexCleanweb.spam?(user_input, ip: current_user.ip) captcha = YandexCleanweb.get_captcha(spam_check[:id]) # now you can show captcha[:url] to user # but remember to write captcha[:captcha] to session # to check is captcha enterred by user is valid: captcha_valid = YandexCleanweb.valid_captcha?(result[:id], captcha[:captcha], user_captcha) end ``` If you use Yandex Cleanweb in Rails app, we recommend to set up the api key in `config/initializers/yandex_cleanweb.rb` ## Contributing 1. Fork it 2. Create your feature branch (`git checkout -b my-new-feature`) 3. Commit your changes (`git commit -am 'Add some feature'`) 4. Push to the branch (`git push origin my-new-feature`) 5. Create new Pull Request