2020-01-30 10:09:15 -05:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module Spam
|
|
|
|
class AkismetService
|
|
|
|
attr_accessor :text, :options
|
|
|
|
|
|
|
|
def initialize(owner_name, owner_email, text, options = {})
|
|
|
|
@owner_name = owner_name
|
|
|
|
@owner_email = owner_email
|
|
|
|
@text = text
|
|
|
|
@options = options
|
|
|
|
end
|
|
|
|
|
|
|
|
def spam?
|
|
|
|
return false unless akismet_enabled?
|
|
|
|
|
|
|
|
params = {
|
|
|
|
type: 'comment',
|
|
|
|
text: text,
|
2020-05-19 02:08:03 -04:00
|
|
|
created_at: DateTime.current,
|
2020-01-30 10:09:15 -05:00
|
|
|
author: owner_name,
|
|
|
|
author_email: owner_email,
|
2021-06-21 08:07:45 -04:00
|
|
|
# NOTE: The akismet_client needs the option to be named `:referrer`, not `:referer`
|
2021-06-05 02:10:14 -04:00
|
|
|
referrer: options[:referer]
|
2020-01-30 10:09:15 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
begin
|
|
|
|
is_spam, is_blatant = akismet_client.check(options[:ip_address], options[:user_agent], params)
|
|
|
|
is_spam || is_blatant
|
2021-06-05 02:10:14 -04:00
|
|
|
rescue ArgumentError => e
|
|
|
|
Gitlab::ErrorTracking.track_and_raise_for_dev_exception(e)
|
|
|
|
false
|
2021-04-26 08:09:44 -04:00
|
|
|
rescue StandardError => e
|
2021-06-05 02:10:14 -04:00
|
|
|
Gitlab::ErrorTracking.track_exception(e)
|
|
|
|
Gitlab::AppLogger.error("Error during Akismet spam check, flagging as not spam: #{e}")
|
2020-01-30 10:09:15 -05:00
|
|
|
false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def submit_ham
|
|
|
|
submit(:ham)
|
|
|
|
end
|
|
|
|
|
|
|
|
def submit_spam
|
|
|
|
submit(:spam)
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
attr_accessor :owner_name, :owner_email
|
|
|
|
|
|
|
|
def akismet_client
|
|
|
|
@akismet_client ||= ::Akismet::Client.new(Gitlab::CurrentSettings.akismet_api_key,
|
|
|
|
Gitlab.config.gitlab.url)
|
|
|
|
end
|
|
|
|
|
|
|
|
def akismet_enabled?
|
|
|
|
Gitlab::CurrentSettings.akismet_enabled
|
|
|
|
end
|
|
|
|
|
|
|
|
def submit(type)
|
|
|
|
return false unless akismet_enabled?
|
|
|
|
|
|
|
|
params = {
|
|
|
|
type: 'comment',
|
|
|
|
text: text,
|
|
|
|
author: owner_name,
|
|
|
|
author_email: owner_email
|
|
|
|
}
|
|
|
|
|
|
|
|
begin
|
|
|
|
akismet_client.public_send(type, options[:ip_address], options[:user_agent], params) # rubocop:disable GitlabSecurity/PublicSend
|
|
|
|
true
|
2021-04-26 08:09:44 -04:00
|
|
|
rescue StandardError => e
|
2020-05-21 17:08:31 -04:00
|
|
|
Gitlab::AppLogger.error("Unable to connect to Akismet: #{e}, skipping!")
|
2020-01-30 10:09:15 -05:00
|
|
|
false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|