forked from AkkomaGang/akkoma
admin_api_controller: Have some basic code
This commit is contained in:
parent
ee2e1328ad
commit
77d2fd54dd
1 changed files with 53 additions and 6 deletions
|
@ -1,25 +1,72 @@
|
||||||
defmodule Pleroma.Web.AdminAPI.Controller do
|
defmodule Pleroma.Web.AdminAPI.Controller do
|
||||||
use Pleroma.Web, :controller
|
use Pleroma.Web, :controller
|
||||||
|
alias Pleroma.{User, Repo}
|
||||||
|
alias Pleroma.Web.ActivityPub.Relay
|
||||||
|
|
||||||
require Logger
|
require Logger
|
||||||
|
|
||||||
action_fallback(:errors)
|
action_fallback(:errors)
|
||||||
|
|
||||||
def user_delete(%{assigns: %{user: user}} = conn, _params) do
|
def user_delete(conn, %{nickname: nickname}) do
|
||||||
|
user = User.get_by_nickname(nickname)
|
||||||
|
|
||||||
|
if user[:local] == true do
|
||||||
|
User.delete(user)
|
||||||
|
else
|
||||||
|
User.delete(user)
|
||||||
end
|
end
|
||||||
|
|
||||||
def user_create(%{assigns: %{user: user}} = conn, _params) do
|
conn
|
||||||
|
|> send(200)
|
||||||
end
|
end
|
||||||
|
|
||||||
def relay_follow(%{assigns: %{user: user}} = conn, _params) do
|
def user_create(
|
||||||
|
conn,
|
||||||
|
%{user: %{nickname: nickname, email: email, password: password} = user}
|
||||||
|
) do
|
||||||
|
new_user = %User{
|
||||||
|
nickname: nickname,
|
||||||
|
name: user.name || nickname,
|
||||||
|
email: email,
|
||||||
|
password: password,
|
||||||
|
password_confirmation: password,
|
||||||
|
bio: user.bio || "."
|
||||||
|
}
|
||||||
|
|
||||||
|
User.register_changeset(%User{}, new_user)
|
||||||
|
|
||||||
|
Repo.insert!(user)
|
||||||
|
|
||||||
|
conn
|
||||||
|
|> send(200)
|
||||||
end
|
end
|
||||||
|
|
||||||
def relay_unfollow(%{assigns: %{user: user}} = conn, _params) do
|
def relay_follow(conn, %{relay_url: target}) do
|
||||||
|
:ok = Relay.follow(target)
|
||||||
|
|
||||||
|
conn
|
||||||
|
|> send(200)
|
||||||
end
|
end
|
||||||
|
|
||||||
def user_delete(%{assigns: %{user: user}} = conn, _params) do
|
def relay_unfollow(conn, %{relay_url: target}) do
|
||||||
|
:ok = Relay.unfollow(target)
|
||||||
|
|
||||||
|
conn
|
||||||
|
|> send(200)
|
||||||
end
|
end
|
||||||
|
|
||||||
def user_delete(%{assigns: %{user: user}} = conn, _params) do
|
def get_invite_token(conn, _params) do
|
||||||
|
{:ok, token} <- Pleroma.UserInviteToken.create_token()
|
||||||
|
|
||||||
|
conn
|
||||||
|
|> puts(token)
|
||||||
|
end
|
||||||
|
|
||||||
|
def get_password_reset(conn, %{nickname: nickname}) do
|
||||||
|
(%User{local: true} = user) = User.get_by_nickname(nickname)
|
||||||
|
{:ok, token} = Pleroma.PasswordResetToken.create_token(user)
|
||||||
|
|
||||||
|
conn
|
||||||
|
|> puts(token)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue