forked from AkkomaGang/akkoma
[#114] Moved email_invite action to AdminAPIController, adjusted tests.
This commit is contained in:
parent
3cbf16a5fe
commit
a89e3b4b60
5 changed files with 46 additions and 45 deletions
|
@ -147,6 +147,19 @@ def relay_unfollow(conn, %{"relay_url" => target}) do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@doc "Sends registration invite via email"
|
||||||
|
def email_invite(%{assigns: %{user: user}} = conn, %{"email" => email} = params) do
|
||||||
|
with true <-
|
||||||
|
Pleroma.Config.get([:instance, :invites_enabled]) &&
|
||||||
|
!Pleroma.Config.get([:instance, :registrations_open]),
|
||||||
|
{:ok, invite_token} <- Pleroma.UserInviteToken.create_token(),
|
||||||
|
email <-
|
||||||
|
Pleroma.UserEmail.user_invitation_email(user, invite_token, email, params["name"]),
|
||||||
|
{:ok, _} <- Pleroma.Mailer.deliver(email) do
|
||||||
|
json_response(conn, :no_content, "")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
@doc "Get a account registeration invite token (base64 string)"
|
@doc "Get a account registeration invite token (base64 string)"
|
||||||
def get_invite_token(conn, _params) do
|
def get_invite_token(conn, _params) do
|
||||||
{:ok, token} = Pleroma.UserInviteToken.create_token()
|
{:ok, token} = Pleroma.UserInviteToken.create_token()
|
||||||
|
|
|
@ -117,6 +117,8 @@ defmodule Pleroma.Web.Router do
|
||||||
delete("/relay", AdminAPIController, :relay_unfollow)
|
delete("/relay", AdminAPIController, :relay_unfollow)
|
||||||
|
|
||||||
get("/invite_token", AdminAPIController, :get_invite_token)
|
get("/invite_token", AdminAPIController, :get_invite_token)
|
||||||
|
post("/email_invite", AdminAPIController, :email_invite)
|
||||||
|
|
||||||
get("/password_reset", AdminAPIController, :get_password_reset)
|
get("/password_reset", AdminAPIController, :get_password_reset)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -335,18 +335,6 @@ def password_reset(conn, params) do
|
||||||
|
|
||||||
def confirm_email(_conn, _params), do: :noop
|
def confirm_email(_conn, _params), do: :noop
|
||||||
|
|
||||||
def email_invite(%{assigns: %{user: user}} = conn, %{"email" => email} = params) do
|
|
||||||
with true <-
|
|
||||||
Pleroma.Config.get([:instance, :invites_enabled]) &&
|
|
||||||
!Pleroma.Config.get([:instance, :registrations_open]),
|
|
||||||
{:ok, invite_token} <- Pleroma.UserInviteToken.create_token(),
|
|
||||||
email <-
|
|
||||||
Pleroma.UserEmail.user_invitation_email(user, invite_token, email, params["name"]),
|
|
||||||
{:ok, _} <- Pleroma.Mailer.deliver(email) do
|
|
||||||
json_response(conn, :no_content, "")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def update_avatar(%{assigns: %{user: user}} = conn, params) do
|
def update_avatar(%{assigns: %{user: user}} = conn, params) do
|
||||||
{:ok, object} = ActivityPub.upload(params, type: :avatar)
|
{:ok, object} = ActivityPub.upload(params, type: :avatar)
|
||||||
change = Changeset.change(user, %{avatar: object.data})
|
change = Changeset.change(user, %{avatar: object.data})
|
||||||
|
|
|
@ -154,6 +154,37 @@ test "/:right DELETE, can remove from a permission group" do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe "POST /api/pleroma/admin/email_invite, with valid parameters" do
|
||||||
|
setup do
|
||||||
|
registrations_open = Pleroma.Config.get([:instance, :registrations_open])
|
||||||
|
invites_enabled = Pleroma.Config.get([:instance, :invites_enabled])
|
||||||
|
Pleroma.Config.put([:instance, :registrations_open], false)
|
||||||
|
Pleroma.Config.put([:instance, :invites_enabled], true)
|
||||||
|
|
||||||
|
on_exit(fn ->
|
||||||
|
Pleroma.Config.put([:instance, :registrations_open], registrations_open)
|
||||||
|
Pleroma.Config.put([:instance, :invites_enabled], invites_enabled)
|
||||||
|
:ok
|
||||||
|
end)
|
||||||
|
|
||||||
|
[user: insert(:user, info: %{is_admin: true})]
|
||||||
|
end
|
||||||
|
|
||||||
|
test "sends invitation and returns 204", %{conn: conn, user: user} do
|
||||||
|
recipient_email = "foo@bar.com"
|
||||||
|
recipient_name = "J. D."
|
||||||
|
|
||||||
|
conn =
|
||||||
|
conn
|
||||||
|
|> assign(:user, user)
|
||||||
|
|> post("/api/pleroma/admin/email_invite?email=#{recipient_email}&name=#{recipient_name}")
|
||||||
|
|
||||||
|
assert json_response(conn, :no_content)
|
||||||
|
|
||||||
|
Swoosh.TestAssertions.assert_email_sent()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
test "/api/pleroma/admin/invite_token" do
|
test "/api/pleroma/admin/invite_token" do
|
||||||
admin = insert(:user, info: %{is_admin: true})
|
admin = insert(:user, info: %{is_admin: true})
|
||||||
|
|
||||||
|
|
|
@ -873,39 +873,6 @@ test "it returns 500 when user is not local", %{conn: conn, user: user} do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "POST /api/email_invite, with valid parameters" do
|
|
||||||
setup [:valid_user]
|
|
||||||
|
|
||||||
setup do
|
|
||||||
registrations_open = Pleroma.Config.get([:instance, :registrations_open])
|
|
||||||
invites_enabled = Pleroma.Config.get([:instance, :invites_enabled])
|
|
||||||
Pleroma.Config.put([:instance, :registrations_open], false)
|
|
||||||
Pleroma.Config.put([:instance, :invites_enabled], true)
|
|
||||||
|
|
||||||
on_exit(fn ->
|
|
||||||
Pleroma.Config.put([:instance, :registrations_open], registrations_open)
|
|
||||||
Pleroma.Config.put([:instance, :invites_enabled], invites_enabled)
|
|
||||||
:ok
|
|
||||||
end)
|
|
||||||
|
|
||||||
:ok
|
|
||||||
end
|
|
||||||
|
|
||||||
test "sends invitation and returns 204", %{conn: conn, user: user} do
|
|
||||||
recipient_email = "foo@bar.com"
|
|
||||||
recipient_name = "J. D."
|
|
||||||
|
|
||||||
conn =
|
|
||||||
conn
|
|
||||||
|> assign(:user, user)
|
|
||||||
|> post("/api/email_invite?email=#{recipient_email}&name=#{recipient_name}")
|
|
||||||
|
|
||||||
assert json_response(conn, :no_content)
|
|
||||||
|
|
||||||
Swoosh.TestAssertions.assert_email_sent()
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
describe "GET /api/externalprofile/show" do
|
describe "GET /api/externalprofile/show" do
|
||||||
test "it returns the user", %{conn: conn} do
|
test "it returns the user", %{conn: conn} do
|
||||||
user = insert(:user)
|
user = insert(:user)
|
||||||
|
|
Loading…
Reference in a new issue