diff options
author | Alex Gleason <alex@alexgleason.me> | 2021-06-14 20:07:51 -0500 |
---|---|---|
committer | Alex Gleason <alex@alexgleason.me> | 2021-06-14 20:08:13 -0500 |
commit | 90df530decdcbb222f6429d69e301af3b027176c (patch) | |
tree | f3c9705773d671b2d9beff8468e5d77b377a42d5 /lib | |
parent | 784b8b5f836d13bbdb46e839e23e642422f271b9 (diff) | |
download | pleroma-90df530decdcbb222f6429d69e301af3b027176c.tar.gz |
AdminAPI: get email list subscribers
Diffstat (limited to 'lib')
-rw-r--r-- | lib/pleroma/user/mailing_list.ex | 9 | ||||
-rw-r--r-- | lib/pleroma/web/admin_api/controllers/email_list_controller.ex | 26 | ||||
-rw-r--r-- | lib/pleroma/web/router.ex | 2 |
3 files changed, 34 insertions, 3 deletions
diff --git a/lib/pleroma/user/mailing_list.ex b/lib/pleroma/user/mailing_list.ex index 2cc223cc7..b60069023 100644 --- a/lib/pleroma/user/mailing_list.ex +++ b/lib/pleroma/user/mailing_list.ex @@ -11,6 +11,8 @@ defmodule Pleroma.User.MailingList do alias Pleroma.Repo alias Pleroma.User + @header_row ["Email Address"] + defp subscribers_query do User.Query.build(%{ local: true, @@ -34,10 +36,11 @@ defmodule Pleroma.User.MailingList do |> build_csv() end - defp build_row(%User{email: email}), do: email + defp build_row(%User{email: email}), do: [email] defp build_csv(lines) do - ["Email Address" | lines] - |> Enum.join("\n") + [@header_row | lines] + |> CSV.encode() + |> Enum.join() end end diff --git a/lib/pleroma/web/admin_api/controllers/email_list_controller.ex b/lib/pleroma/web/admin_api/controllers/email_list_controller.ex new file mode 100644 index 000000000..dfe9009b8 --- /dev/null +++ b/lib/pleroma/web/admin_api/controllers/email_list_controller.ex @@ -0,0 +1,26 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.AdminAPI.EmailListController do + use Pleroma.Web, :controller + + alias Pleroma.User.MailingList + alias Pleroma.Web.Plugs.OAuthScopesPlug + + require Logger + + plug( + OAuthScopesPlug, + %{scopes: ["admin:read:accounts"]} when action in [:subscribers] + ) + + def subscribers(conn, _params) do + csv = MailingList.generate_csv() + + conn + |> put_resp_content_type("text/csv") + |> resp(200, csv) + |> send_resp() + end +end diff --git a/lib/pleroma/web/router.ex b/lib/pleroma/web/router.ex index 72ad14f05..f825fadcd 100644 --- a/lib/pleroma/web/router.ex +++ b/lib/pleroma/web/router.ex @@ -257,6 +257,8 @@ defmodule Pleroma.Web.Router do post("/frontends/install", FrontendController, :install) post("/backups", AdminAPIController, :create_backup) + + get("/email_list/subscribers.csv", EmailListController, :subscribers) end scope "/api/v1/pleroma/emoji", Pleroma.Web.PleromaAPI do |