admin_api_controller: Have some basic code

This commit is contained in:
Haelwenn (lanodan) Monnier 2018-10-02 19:03:05 +02:00
parent ee2e1328ad
commit 77d2fd54dd
No known key found for this signature in database
GPG key ID: D5B7A8E43C997DEE

View file

@ -1,25 +1,72 @@
defmodule Pleroma.Web.AdminAPI.Controller do
use Pleroma.Web, :controller
alias Pleroma.{User, Repo}
alias Pleroma.Web.ActivityPub.Relay
require Logger
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
conn
|> send(200)
end
def user_create(%{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
def relay_follow(%{assigns: %{user: user}} = conn, _params) do
def relay_follow(conn, %{relay_url: target}) do
:ok = Relay.follow(target)
conn
|> send(200)
end
def relay_unfollow(%{assigns: %{user: user}} = conn, _params) do
def relay_unfollow(conn, %{relay_url: target}) do
:ok = Relay.unfollow(target)
conn
|> send(200)
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 user_delete(%{assigns: %{user: user}} = conn, _params) do
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