Merge branch 'cache-follow-state' into 'develop'
[akkoma] / lib / pleroma / digest_email_worker.ex
index fa6067a0325f436d3d3a00bff012b639350e1525..18e67d39b07cd5d7176f36c95cdd84b539f1299c 100644 (file)
@@ -1,12 +1,10 @@
 defmodule Pleroma.DigestEmailWorker do
   import Ecto.Query
-  require Logger
 
-  # alias Pleroma.User
+  @queue_name :digest_emails
 
-  def run() do
-    Logger.warn("Running digester")
-    config = Application.get_env(:pleroma, :email_notifications)[:digest]
+  def perform do
+    config = Pleroma.Config.get([:email_notifications, :digest])
     negative_interval = -Map.fetch!(config, :interval)
     inactivity_threshold = Map.fetch!(config, :inactivity_threshold)
     inactive_users_query = Pleroma.User.list_inactive_users_query(inactivity_threshold)
@@ -14,32 +12,24 @@ defmodule Pleroma.DigestEmailWorker do
     now = NaiveDateTime.truncate(NaiveDateTime.utc_now(), :second)
 
     from(u in inactive_users_query,
-      where: fragment("? #> '{\"email_notifications\",\"digest\"}' @> 'true'", u.info),
+      where: fragment(~s(? #> '{"email_notifications","digest"}' @> 'true'), u.info),
       where: u.last_digest_emailed_at < datetime_add(^now, ^negative_interval, "day"),
       select: u
     )
     |> Pleroma.Repo.all()
-    |> run(:pre)
+    |> Enum.each(&PleromaJobQueue.enqueue(@queue_name, __MODULE__, [&1]))
   end
 
-  defp run(v, :pre) do
-    Logger.warn("Running for #{length(v)} users")
-    run(v)
-  end
-
-  defp run([]), do: :ok
-
-  defp run([user | users]) do
+  @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
     with %Swoosh.Email{} = email <- Pleroma.Emails.UserEmail.digest_email(user) do
-      Logger.warn("Sending to #{user.nickname}")
       Pleroma.Emails.Mailer.deliver_async(email)
-    else
-      _ ->
-        Logger.warn("Skipping #{user.nickname}")
     end
 
     Pleroma.User.touch_last_digest_emailed_at(user)
-
-    run(users)
   end
 end