blob: 733ce31be1a2b64ee1104e1fc3b49d6364d5028c (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
module Recaptcha
module Verify
# Your private API can be specified in the +options+ hash or preferably
# using the Configuration.
def verify_recaptcha(options = {})
if !options.is_a? Hash
options = {:model => options}
end
env = options[:env] || ENV['RAILS_ENV']
return true if Recaptcha.configuration.skip_verify_env.include? env
model = options[:model]
attribute = options[:attribute] || :base
private_key = options[:private_key] || Recaptcha.configuration.private_key
raise RecaptchaError, "No private key specified." unless private_key
begin
recaptcha = nil
Timeout::timeout(options[:timeout] || 3) do
recaptcha = Net::HTTP.post_form URI.parse(Recaptcha.configuration.verify_url), {
"privatekey" => private_key,
"remoteip" => request.remote_ip,
"challenge" => params[:recaptcha_challenge_field],
"response" => params[:recaptcha_response_field]
}
end
answer, error = recaptcha.body.split.map { |s| s.chomp }
unless answer == 'true'
flash[:recaptcha_error] = error
if model
model.valid?
model.errors.add attribute, options[:message] || "Word verification response is incorrect, please try again."
end
return false
else
flash[:recaptcha_error] = nil
return true
end
rescue Timeout::Error
flash[:recaptcha_error] = "recaptcha-not-reachable"
if model
model.valid?
model.errors.add attribute, options[:message] || "Oops, we failed to validate your word verification response. Please try again."
end
return false
rescue Exception => e
raise RecaptchaError, e.message, e.backtrace
end
end # verify_recaptcha
end # Verify
end # Recaptcha
|