admin_api_controller.ex: Add documentation, fix get_invite_token
[akkoma] / lib / pleroma / web / admin_api / admin_api_controller.ex
1 defmodule Pleroma.Web.AdminAPI.AdminAPIController do
2 use Pleroma.Web, :controller
3 alias Pleroma.{User, Repo}
4 alias Pleroma.Web.ActivityPub.Relay
5
6 require Logger
7
8 action_fallback(:errors)
9
10 def user_delete(conn, %{nickname: nickname}) do
11 user = User.get_by_nickname(nickname)
12
13 if user[:local] == true do
14 User.delete(user)
15 else
16 User.delete(user)
17 end
18
19 conn
20 |> send(200)
21 end
22
23 def user_create(
24 conn,
25 %{user: %{nickname: nickname, email: email, password: password} = user}
26 ) do
27 new_user = %User{
28 nickname: nickname,
29 name: user.name || nickname,
30 email: email,
31 password: password,
32 password_confirmation: password,
33 bio: user.bio || "."
34 }
35
36 User.register_changeset(%User{}, new_user)
37
38 Repo.insert!(user)
39
40 conn
41 |> send(200)
42 end
43
44 def relay_follow(conn, %{relay_url: target}) do
45 :ok = Relay.follow(target)
46
47 conn
48 |> send(200)
49 end
50
51 def relay_unfollow(conn, %{relay_url: target}) do
52 :ok = Relay.unfollow(target)
53
54 conn
55 |> send(200)
56 end
57
58 @shortdoc "Get a account registeration invite token (base64 string)"
59 def get_invite_token(conn, _params) do
60 {:ok, token} <- Pleroma.UserInviteToken.create_token()
61
62 conn
63 |> json(token.token)
64 end
65
66 @shortdoc "Get a password reset token (base64 string) for given nickname"
67 def get_password_reset(conn, %{"nickname" => nickname}) do
68 (%User{local: true} = user) = User.get_by_nickname(nickname)
69 {:ok, token} = Pleroma.PasswordResetToken.create_token(user)
70
71 conn
72 |> json(token.token)
73 end
74
75 def errors(conn, {:param_cast, _}) do
76 conn
77 |> put_status(400)
78 |> json("Invalid parameters")
79 end
80
81 def errors(conn, _) do
82 conn
83 |> put_status(500)
84 |> json("Something went wrong")
85 end
86 end