diff options
Diffstat (limited to 'app/models/abuse_report.rb')
-rw-r--r-- | app/models/abuse_report.rb | 37 |
1 files changed, 36 insertions, 1 deletions
diff --git a/app/models/abuse_report.rb b/app/models/abuse_report.rb index f1f22d94061..ee0c23ef31e 100644 --- a/app/models/abuse_report.rb +++ b/app/models/abuse_report.rb @@ -12,14 +12,49 @@ class AbuseReport < ApplicationRecord validates :reporter, presence: true validates :user, presence: true validates :message, presence: true - validates :user_id, uniqueness: { message: 'has already been reported' } + validates :category, presence: true + validates :user_id, + uniqueness: { + scope: [:reporter_id, :category], + message: ->(object, data) do + _('You have already reported this user') + end + } + + validates :reported_from_url, + allow_blank: true, + length: { maximum: 512 }, + addressable_url: { + dns_rebind_protection: true, + blocked_message: 'is an invalid URL. You can try reporting the abuse again, ' \ + 'or contact a GitLab administrator for help.' + } scope :by_user, ->(user) { where(user_id: user) } scope :with_users, -> { includes(:reporter, :user) } + enum category: { + spam: 1, + offensive: 2, + phishing: 3, + crypto: 4, + credentials: 5, + copyright: 6, + malware: 7, + other: 8 + } + # For CacheMarkdownField alias_method :author, :reporter + HUMANIZED_ATTRIBUTES = { + reported_from_url: "Reported from" + }.freeze + + def self.human_attribute_name(attr, options = {}) + HUMANIZED_ATTRIBUTES[attr.to_sym] || super + end + def remove_user(deleted_by:) user.delete_async(deleted_by: deleted_by, params: { hard_delete: true }) end |