Pleroma/lib/pleroma/web/mastodon_api/mastodon_api.ex

94 lines
2.5 KiB
Elixir
Raw Normal View History

# Pleroma: A lightweight social networking server
# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
# SPDX-License-Identifier: AGPL-3.0-only
2019-03-11 19:03:30 +01:00
defmodule Pleroma.Web.MastodonAPI.MastodonAPI do
import Ecto.Query
import Ecto.Changeset
2018-03-30 15:01:53 +02:00
alias Pleroma.Activity
alias Pleroma.Notification
alias Pleroma.Pagination
2019-03-28 10:39:10 +01:00
alias Pleroma.ScheduledActivity
alias Pleroma.User
alias Pleroma.Web.CommonAPI
@spec follow(User.t(), User.t(), map) :: {:ok, User.t()} | {:error, String.t()}
def follow(follower, followed, params \\ %{}) do
result =
if not User.following?(follower, followed) do
CommonAPI.follow(follower, followed)
else
{:ok, follower, followed, nil}
end
with {:ok, follower, _followed, _} <- result do
options = cast_params(params)
case reblogs_visibility(options[:reblogs], result) do
{:ok, follower} -> {:ok, follower}
_ -> {:ok, follower}
end
end
end
2019-03-11 19:03:30 +01:00
defp reblogs_visibility(false, {:ok, follower, followed, _}) do
CommonAPI.hide_reblogs(follower, followed)
end
defp reblogs_visibility(_, {:ok, follower, followed, _}) do
CommonAPI.show_reblogs(follower, followed)
end
@spec get_followers(User.t(), map()) :: list(User.t())
2019-03-11 19:03:30 +01:00
def get_followers(user, params \\ %{}) do
user
|> User.get_followers_query()
|> Pagination.fetch_paginated(params)
2019-03-11 19:03:30 +01:00
end
def get_friends(user, params \\ %{}) do
user
|> User.get_friends_query()
|> Pagination.fetch_paginated(params)
2019-03-11 19:03:30 +01:00
end
def get_notifications(user, params \\ %{}) do
2019-03-11 19:03:30 +01:00
options = cast_params(params)
user
2019-07-14 15:29:31 +02:00
|> Notification.for_user_query(options)
|> restrict(:exclude_types, options)
|> Pagination.fetch_paginated(params)
2019-03-11 19:03:30 +01:00
end
2019-03-28 10:39:10 +01:00
def get_scheduled_activities(user, params \\ %{}) do
user
|> ScheduledActivity.for_user_query()
|> Pagination.fetch_paginated(params)
end
defp cast_params(params) do
2019-03-11 19:03:30 +01:00
param_types = %{
exclude_types: {:array, :string},
2019-07-14 15:29:31 +02:00
reblogs: :boolean,
with_muted: :boolean
2019-03-11 19:03:30 +01:00
}
changeset = cast({%{}, param_types}, params, Map.keys(param_types))
changeset.changes
end
defp restrict(query, :exclude_types, %{exclude_types: mastodon_types = [_ | _]}) do
ap_types =
mastodon_types
|> Enum.map(&Activity.from_mastodon_notification_type/1)
|> Enum.filter(& &1)
2019-03-11 19:03:30 +01:00
query
|> where([q, a], not fragment("? @> ARRAY[?->>'type']::varchar[]", ^ap_types, a.data))
2019-03-11 19:03:30 +01:00
end
defp restrict(query, _, _), do: query
end