discourse/app/jobs/scheduled/enqueue_digest_emails.rb

37 lines
1.3 KiB
Ruby
Raw Normal View History

2013-02-06 03:16:51 +08:00
module Jobs
# A daily job that will enqueue digest emails to be sent to users
2013-08-08 01:25:05 +08:00
class EnqueueDigestEmails < Jobs::Scheduled
2016-04-01 05:33:25 +08:00
every 30.minutes
2013-02-06 03:16:51 +08:00
def execute(args)
2015-01-27 12:46:21 +08:00
unless SiteSetting.disable_digest_emails?
target_user_ids.each do |user_id|
Jobs.enqueue(:user_email, type: :digest, user_id: user_id)
end
2013-02-26 00:42:20 +08:00
end
2013-02-06 03:16:51 +08:00
end
def target_user_ids
2016-04-01 05:33:25 +08:00
# Users who want to receive digest email within their chosen digest email frequency
query = User.real
2016-04-01 05:33:25 +08:00
.where(active: true, staged: false)
.joins(:user_option)
.not_suspended
2016-04-01 05:33:25 +08:00
.where(user_options: {email_digests: true})
.where("COALESCE(last_emailed_at, '2010-01-01') <= CURRENT_TIMESTAMP - ('1 MINUTE'::INTERVAL * user_options.digest_after_minutes)")
.where("COALESCE(last_seen_at, '2010-01-01') <= CURRENT_TIMESTAMP - ('1 MINUTE'::INTERVAL * user_options.digest_after_minutes)")
.where("COALESCE(last_seen_at, '2010-01-01') >= CURRENT_TIMESTAMP - ('1 DAY'::INTERVAL * #{SiteSetting.delete_digest_email_after_days})")
# If the site requires approval, make sure the user is approved
if SiteSetting.must_approve_users?
query = query.where("approved OR moderator OR admin")
end
query.pluck(:id)
2013-02-06 03:16:51 +08:00
end
end
2013-02-26 00:42:20 +08:00
end