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