From 3a4773c3c2bd0bbef244eb519b07208da9108e49 Mon Sep 17 00:00:00 2001
From: dcc
Date: Sat, 2 Sep 2023 00:52:52 -0700
Subject: First
---
lib/pleroma/emails/admin_email.ex | 99 +++++++++++++++++++++++++++++++++++++++
1 file changed, 99 insertions(+)
create mode 100644 lib/pleroma/emails/admin_email.ex
(limited to 'lib/pleroma/emails/admin_email.ex')
diff --git a/lib/pleroma/emails/admin_email.ex b/lib/pleroma/emails/admin_email.ex
new file mode 100644
index 0000000..372e552
--- /dev/null
+++ b/lib/pleroma/emails/admin_email.ex
@@ -0,0 +1,99 @@
+# Pleroma: A lightweight social networking server
+# Copyright © 2017-2022 Pleroma Authors
+# SPDX-License-Identifier: AGPL-3.0-only
+
+defmodule Pleroma.Emails.AdminEmail do
+ @moduledoc "Admin emails"
+
+ import Swoosh.Email
+
+ alias Pleroma.Config
+ alias Pleroma.HTML
+ alias Pleroma.Web.Router.Helpers
+
+ defp instance_config, do: Config.get(:instance)
+ defp instance_name, do: instance_config()[:name]
+
+ defp instance_notify_email do
+ Keyword.get(instance_config(), :notify_email, instance_config()[:email])
+ end
+
+ def test_email(mail_to \\ nil) do
+ html_body = """
+ Instance Test Email
+ A test email was requested. Hello. :)
+ """
+
+ new()
+ |> to(mail_to || Config.get([:instance, :email]))
+ |> from({instance_name(), instance_notify_email()})
+ |> subject("Instance Test Email")
+ |> html_body(html_body)
+ end
+
+ def report(to, reporter, account, statuses, comment) do
+ comment_html =
+ if comment do
+ "Comment: #{comment}"
+ else
+ ""
+ end
+
+ statuses_html =
+ if is_list(statuses) && length(statuses) > 0 do
+ statuses_list_html =
+ statuses
+ |> Enum.map(fn
+ %{id: id} ->
+ status_url = Helpers.o_status_url(Pleroma.Web.Endpoint, :notice, id)
+ "
#{status_url}"
+
+ %{"id" => id} when is_binary(id) ->
+ "#{id}"
+
+ id when is_binary(id) ->
+ "#{id}"
+ end)
+ |> Enum.join("\n")
+
+ """
+ Statuses:
+
+ #{statuses_list_html}
+
+
+ """
+ else
+ ""
+ end
+
+ html_body = """
+ Reported by: #{reporter.nickname}
+ Reported Account: #{account.nickname}
+ #{comment_html}
+ #{statuses_html}
+
+ View Reports in AdminFE
+ """
+
+ new()
+ |> to({to.name, to.email})
+ |> from({instance_name(), instance_notify_email()})
+ |> subject("#{instance_name()} Report")
+ |> html_body(html_body)
+ end
+
+ def new_unapproved_registration(to, account) do
+ html_body = """
+
New account for review: @#{account.nickname}
+ #{HTML.strip_tags(account.registration_reason)}
+ Visit AdminFE
+ """
+
+ new()
+ |> to({to.name, to.email})
+ |> from({instance_name(), instance_notify_email()})
+ |> subject("New account up for review on #{instance_name()} (@#{account.nickname})")
+ |> html_body(html_body)
+ end
+end
--
cgit v1.2.3