2019-04-20 14:42:19 +02:00
|
|
|
defmodule Pleroma.DigestEmailWorker do
|
|
|
|
import Ecto.Query
|
|
|
|
|
2019-07-16 15:49:50 +02:00
|
|
|
def perform do
|
2019-05-29 20:31:27 +02:00
|
|
|
config = Pleroma.Config.get([:email_notifications, :digest])
|
2019-04-20 14:42:19 +02:00
|
|
|
negative_interval = -Map.fetch!(config, :interval)
|
|
|
|
inactivity_threshold = Map.fetch!(config, :inactivity_threshold)
|
|
|
|
inactive_users_query = Pleroma.User.list_inactive_users_query(inactivity_threshold)
|
|
|
|
|
|
|
|
now = NaiveDateTime.truncate(NaiveDateTime.utc_now(), :second)
|
|
|
|
|
|
|
|
from(u in inactive_users_query,
|
2019-04-20 14:57:43 +02:00
|
|
|
where: fragment(~s(? #> '{"email_notifications","digest"}' @> 'true'), u.info),
|
2019-04-20 14:42:19 +02:00
|
|
|
where: u.last_digest_emailed_at < datetime_add(^now, ^negative_interval, "day"),
|
|
|
|
select: u
|
|
|
|
)
|
|
|
|
|> Pleroma.Repo.all()
|
2019-08-10 19:38:31 +02:00
|
|
|
|> Enum.each(&PleromaJobQueue.enqueue(:digest_emails, __MODULE__, [&1]))
|
2019-04-20 14:42:19 +02:00
|
|
|
end
|
|
|
|
|
2019-07-14 21:32:11 +02:00
|
|
|
@doc """
|
|
|
|
Send digest email to the given user.
|
|
|
|
Updates `last_digest_emailed_at` field for the user and returns the updated user.
|
|
|
|
"""
|
|
|
|
@spec perform(Pleroma.User.t()) :: Pleroma.User.t()
|
|
|
|
def perform(user) do
|
2019-04-20 14:42:19 +02:00
|
|
|
with %Swoosh.Email{} = email <- Pleroma.Emails.UserEmail.digest_email(user) do
|
|
|
|
Pleroma.Emails.Mailer.deliver_async(email)
|
|
|
|
end
|
|
|
|
|
|
|
|
Pleroma.User.touch_last_digest_emailed_at(user)
|
|
|
|
end
|
|
|
|
end
|