Merge branch 'feature/1734-user-deletion' into 'develop'
[akkoma] / lib / mix / tasks / pleroma / digest.ex
index 19c4ce71e58940c5793b38889ca6dd4c0e81cac8..3595f912d622ab0dd54de666adb7a4ddad553d08 100644 (file)
@@ -1,17 +1,10 @@
 defmodule Mix.Tasks.Pleroma.Digest do
   use Mix.Task
+  import Mix.Pleroma
 
   @shortdoc "Manages digest emails"
-  @moduledoc """
-  Manages digest emails
+  @moduledoc File.read!("docs/administration/CLI_tasks/digest.md")
 
-  ## Send digest email since given date (user registration date by default)
-  ignoring user activity status.
-
-  ``mix pleroma.digest test <nickname> <since_date>``
-
-  Example: ``mix pleroma.digest test donaldtheduck 2019-05-20``
-  """
   def run(["test", nickname | opts]) do
     Mix.Pleroma.start_pleroma()
 
@@ -27,7 +20,13 @@ defmodule Mix.Tasks.Pleroma.Digest do
 
     patched_user = %{user | last_digest_emailed_at: last_digest_emailed_at}
 
-    :ok = Pleroma.DigestEmailWorker.run([patched_user])
-    Mix.shell().info("Digest email have been sent to #{nickname} (#{user.email})")
+    with %Swoosh.Email{} = email <- Pleroma.Emails.UserEmail.digest_email(patched_user) do
+      {:ok, _} = Pleroma.Emails.Mailer.deliver(email)
+
+      shell_info("Digest email have been sent to #{nickname} (#{user.email})")
+    else
+      _ ->
+        shell_info("Cound't find any mentions for #{nickname} since #{last_digest_emailed_at}")
+    end
   end
 end