# frozen_string_literal: true

module Jobs
  class ActivationReminderEmails < ::Jobs::Scheduled
    every 2.hours

    def execute(args)
      User
        .joins(
          "LEFT JOIN user_custom_fields ON users.id = user_id AND user_custom_fields.name = 'activation_reminder'",
        )
        .where(active: false, staged: false, user_custom_fields: { value: nil })
        .where("users.created_at BETWEEN ? AND ?", 3.days.ago, 2.days.ago)
        .find_each do |user|
          user.custom_fields["activation_reminder"] = true
          user.save_custom_fields

          email_token =
            user.email_tokens.create!(email: user.email, scope: EmailToken.scopes[:signup])
          ::Jobs.enqueue(
            :user_email,
            type: "activation_reminder",
            user_id: user.id,
            email_token: email_token.token,
          )
        end
    end
  end
end