debian-mirror-gitlab/app/serializers/admin/abuse_report_details_entity.rb
2023-07-09 08:55:56 +05:30

104 lines
3.3 KiB
Ruby

# frozen_string_literal: true
module Admin
class AbuseReportDetailsEntity < Grape::Entity
include RequestAwareEntity
expose :user, if: ->(report) { report.user } do
expose :details, merge: true do |report|
UserEntity.represent(report.user, only: [:name, :username, :avatar_url, :email, :created_at, :last_activity_on])
end
expose :path do |report|
user_path(report.user)
end
expose :admin_path do |report|
admin_user_path(report.user)
end
expose :plan do |report|
if Gitlab::CurrentSettings.current_application_settings.try(:should_check_namespace_plan?)
report.user.namespace&.actual_plan&.title
end
end
expose :verification_state do
expose :email do |report|
report.user.confirmed?
end
expose :phone do |report|
report.user.phone_number_validation.present? && report.user.phone_number_validation.validated?
end
expose :credit_card do |report|
report.user.credit_card_validation.present?
end
end
expose :credit_card, if: ->(report) { report.user.credit_card_validation&.holder_name } do
expose :name do |report|
report.user.credit_card_validation.holder_name
end
expose :similar_records_count do |report|
report.user.credit_card_validation.similar_records.count
end
expose :card_matches_link do |report|
card_match_admin_user_path(report.user) if Gitlab.ee?
end
end
expose :other_reports do |report|
AbuseReportEntity.represent(report.other_reports_for_user, only: [:created_at, :category, :report_path])
end
expose :most_used_ip do |report|
AuthenticationEvent.most_used_ip_address_for_user(report.user)
end
expose :last_sign_in_ip do |report|
report.user.last_sign_in_ip
end
expose :snippets_count do |report|
report.user.snippets.count
end
expose :groups_count do |report|
report.user.groups.count
end
expose :notes_count do |report|
report.user.notes.count
end
end
expose :reporter, if: ->(report) { report.reporter } do
expose :details, merge: true do |report|
UserEntity.represent(report.reporter, only: [:name, :username, :avatar_url])
end
expose :path do |report|
user_path(report.reporter)
end
end
expose :report do
expose :message
expose :created_at, as: :reported_at
expose :category
expose :report_type, as: :type
expose :reported_content, as: :content
expose :reported_from_url, as: :url
expose :screenshot_path, as: :screenshot
end
expose :actions, if: ->(report) { report.user } do
expose :user_blocked do |report|
report.user.blocked?
end
expose :block_user_path do |report|
block_admin_user_path(report.user)
end
expose :remove_report_path do |report|
admin_abuse_report_path(report)
end
expose :remove_user_and_report_path do |report|
admin_abuse_report_path(report, remove_user: true)
end
expose :reported_user do |report|
UserEntity.represent(report.user, only: [:name, :created_at])
end
expose :redirect_path do |_|
admin_abuse_reports_path
end
end
end
end