# frozen_string_literal: true

module Reports::TopUploads
  extend ActiveSupport::Concern

  class_methods do
    def report_top_uploads(report)
      report.modes = [:table]

      extension_filter = report.filters.dig(:file_extension)
      report.add_filter(
        "file_extension",
        type: "list",
        default: extension_filter || "any",
        choices: (SiteSetting.authorized_extensions.split("|") + Array(extension_filter)).uniq,
      )

      report.labels = [
        {
          type: :link,
          properties: %i[file_url file_name],
          title: I18n.t("reports.top_uploads.labels.filename"),
        },
        {
          type: :user,
          properties: {
            username: :author_username,
            id: :author_id,
            avatar: :author_avatar_template,
          },
          title: I18n.t("reports.top_uploads.labels.author"),
        },
        {
          type: :text,
          property: :extension,
          title: I18n.t("reports.top_uploads.labels.extension"),
        },
        { type: :bytes, property: :filesize, title: I18n.t("reports.top_uploads.labels.filesize") },
      ]

      report.data = []

      sql = <<~SQL
      SELECT
      u.id as user_id,
      u.username,
      u.uploaded_avatar_id,
      up.filesize,
      up.original_filename,
      up.extension,
      up.url
      FROM uploads up
      JOIN users u
      ON u.id = up.user_id
      /*where*/
      ORDER BY up.filesize DESC
      LIMIT #{report.limit || 250}
      SQL

      builder = DB.build(sql)
      builder.where(
        "up.id > :seeded_id_threshold",
        seeded_id_threshold: Upload::SEEDED_ID_THRESHOLD,
      )
      builder.where("up.created_at >= :start_date", start_date: report.start_date)
      builder.where("up.created_at < :end_date", end_date: report.end_date)

      if extension_filter
        builder.where("up.extension = :extension", extension: extension_filter.sub(/\A\./, ""))
      end

      builder.query.each do |row|
        data = {}
        data[:author_id] = row.user_id
        data[:author_username] = row.username
        data[:author_avatar_template] = User.avatar_template(row.username, row.uploaded_avatar_id)
        data[:filesize] = row.filesize
        data[:extension] = row.extension
        data[:file_url] = Discourse.store.cdn_url(row.url)
        data[:file_name] = row.original_filename.truncate(25)
        report.data << data
      end
    end
  end
end