f90089e1bf
Use Upload Media logic from Pleroma Backend changes for picture upload Move AS <-> Model conversion to separate module Front changes Downgrade apollo-client: https://github.com/Akryum/vue-apollo/issues/577 Signed-off-by: Thomas Citharel <tcit@tcit.fr>
139 lines
4 KiB
Elixir
139 lines
4 KiB
Elixir
defmodule MobilizonWeb.Resolvers.Person do
|
|
@moduledoc """
|
|
Handles the person-related GraphQL calls
|
|
"""
|
|
alias Mobilizon.Actors
|
|
alias Mobilizon.Actors.Actor
|
|
alias Mobilizon.Users.User
|
|
alias Mobilizon.Users
|
|
alias Mobilizon.Events
|
|
alias Mobilizon.Service.ActivityPub
|
|
|
|
@doc """
|
|
Find a person
|
|
"""
|
|
def find_person(_parent, %{preferred_username: name}, _resolution) do
|
|
case ActivityPub.find_or_make_person_from_nickname(name) do
|
|
{:ok, actor} ->
|
|
{:ok, actor}
|
|
|
|
_ ->
|
|
{:error, "Person with name #{name} not found"}
|
|
end
|
|
end
|
|
|
|
@doc """
|
|
Returns the current actor for the currently logged-in user
|
|
"""
|
|
def get_current_person(_parent, _args, %{context: %{current_user: user}}) do
|
|
{:ok, Users.get_actor_for_user(user)}
|
|
end
|
|
|
|
def get_current_person(_parent, _args, _resolution) do
|
|
{:error, "You need to be logged-in to view current person"}
|
|
end
|
|
|
|
@doc """
|
|
Returns the list of identities for the logged-in user
|
|
"""
|
|
def identities(_parent, _args, %{context: %{current_user: user}}) do
|
|
{:ok, Users.get_actors_for_user(user)}
|
|
end
|
|
|
|
def identities(_parent, _args, _resolution) do
|
|
{:error, "You need to be logged-in to view your list of identities"}
|
|
end
|
|
|
|
@doc """
|
|
This function is used to create more identities from an existing user
|
|
"""
|
|
def create_person(
|
|
_parent,
|
|
%{preferred_username: _preferred_username} = args,
|
|
%{
|
|
context: %{current_user: user}
|
|
} = _resolution
|
|
) do
|
|
args = Map.put(args, :user_id, user.id)
|
|
|
|
with args <- save_attached_pictures(args),
|
|
{:ok, %Actor{} = new_person} <- Actors.new_person(args) do
|
|
{:ok, new_person}
|
|
end
|
|
end
|
|
|
|
@doc """
|
|
This function is used to create more identities from an existing user
|
|
"""
|
|
def create_person(_parent, _args, _resolution) do
|
|
{:error, "You need to be logged-in to create a new identity"}
|
|
end
|
|
|
|
defp save_attached_pictures(args) do
|
|
Enum.reduce([:avatar, :banner], args, fn key, args ->
|
|
if Map.has_key?(args, key) do
|
|
pic = args[key][:picture]
|
|
|
|
with {:ok, %{"name" => name, "url" => [%{"href" => url, "mediaType" => content_type}]}} <-
|
|
MobilizonWeb.Upload.store(pic.file, type: key, description: pic.alt) do
|
|
Map.put(args, key, %{"name" => name, "url" => url, "mediaType" => content_type})
|
|
end
|
|
else
|
|
args
|
|
end
|
|
end)
|
|
end
|
|
|
|
@doc """
|
|
This function is used to register a person afterwards the user has been created (but not activated)
|
|
"""
|
|
def register_person(_parent, args, _resolution) do
|
|
with {:ok, %User{} = user} <- Users.get_user_by_email(args.email),
|
|
{:no_actor, nil} <- {:no_actor, Users.get_actor_for_user(user)},
|
|
args <- Map.put(args, :user_id, user.id),
|
|
args <- save_attached_pictures(args),
|
|
{:ok, %Actor{} = new_person} <- Actors.new_person(args) do
|
|
{:ok, new_person}
|
|
else
|
|
{:error, :user_not_found} ->
|
|
{:error, "User with email not found"}
|
|
|
|
{:no_actor, _} ->
|
|
{:error, "You already have a profile for this user"}
|
|
|
|
{:error, %Ecto.Changeset{} = e} ->
|
|
{:error, e}
|
|
end
|
|
end
|
|
|
|
@doc """
|
|
Returns the list of events this person is going to
|
|
"""
|
|
def person_going_to_events(%Actor{id: actor_id}, _args, %{
|
|
context: %{current_user: user}
|
|
}) do
|
|
with {:is_owned, true, actor} <- User.owns_actor(user, actor_id),
|
|
events <- Events.list_event_participations_for_actor(actor) do
|
|
{:ok, events}
|
|
else
|
|
{:is_owned, false} ->
|
|
{:error, "Actor id is not owned by authenticated user"}
|
|
end
|
|
end
|
|
|
|
@doc """
|
|
Returns the list of events this person is going to
|
|
"""
|
|
def person_going_to_events(_parent, %{}, %{
|
|
context: %{current_user: user}
|
|
}) do
|
|
with %Actor{} = actor <- Users.get_actor_for_user(user),
|
|
events <- Events.list_event_participations_for_actor(actor) do
|
|
{:ok, events}
|
|
else
|
|
{:is_owned, false} ->
|
|
{:error, "Actor id is not owned by authenticated user"}
|
|
end
|
|
end
|
|
end
|