From 8b1228b0d409d7751f01d9fb72ebfbbf62399486 Mon Sep 17 00:00:00 2001 From: GitLab Bot Date: Fri, 10 Jan 2020 15:07:47 +0000 Subject: Add latest changes from gitlab-org/gitlab@master --- app/services/concerns/spam_check_methods.rb | 35 +++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 app/services/concerns/spam_check_methods.rb (limited to 'app/services/concerns') diff --git a/app/services/concerns/spam_check_methods.rb b/app/services/concerns/spam_check_methods.rb new file mode 100644 index 00000000000..a0945857f89 --- /dev/null +++ b/app/services/concerns/spam_check_methods.rb @@ -0,0 +1,35 @@ +# frozen_string_literal: true + +# SpamCheckMethods +# +# Provide helper methods for checking if a given spammable object has +# potential spam data. +# +# Dependencies: +# - params with :request + +module SpamCheckMethods + # rubocop:disable Gitlab/ModuleWithInstanceVariables + def filter_spam_check_params + @request = params.delete(:request) + @api = params.delete(:api) + @recaptcha_verified = params.delete(:recaptcha_verified) + @spam_log_id = params.delete(:spam_log_id) + end + # rubocop:enable Gitlab/ModuleWithInstanceVariables + + # In order to be proceed to the spam check process, @spammable has to be + # a dirty instance, which means it should be already assigned with the new + # attribute values. + # rubocop:disable Gitlab/ModuleWithInstanceVariables + # rubocop: disable CodeReuse/ActiveRecord + def spam_check(spammable, user) + spam_service = SpamService.new(spammable, @request) + + spam_service.when_recaptcha_verified(@recaptcha_verified, @api) do + user.spam_logs.find_by(id: @spam_log_id)&.update!(recaptcha_verified: true) + end + end + # rubocop: enable CodeReuse/ActiveRecord + # rubocop:enable Gitlab/ModuleWithInstanceVariables +end -- cgit v1.2.3