2018-12-23 20:04:54 +00:00
|
|
|
# Pleroma: A lightweight social networking server
|
|
|
|
# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/>
|
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2018-08-06 06:15:22 +00:00
|
|
|
defmodule Pleroma.Web.ActivityPub.Relay do
|
2018-08-06 08:03:10 +00:00
|
|
|
alias Pleroma.{User, Object, Activity}
|
2018-08-06 07:14:16 +00:00
|
|
|
alias Pleroma.Web.ActivityPub.ActivityPub
|
|
|
|
require Logger
|
2018-08-06 06:15:22 +00:00
|
|
|
|
|
|
|
def get_actor do
|
|
|
|
User.get_or_create_instance_user()
|
|
|
|
end
|
2018-08-06 07:14:16 +00:00
|
|
|
|
|
|
|
def follow(target_instance) do
|
|
|
|
with %User{} = local_user <- get_actor(),
|
|
|
|
%User{} = target_user <- User.get_or_fetch_by_ap_id(target_instance),
|
|
|
|
{:ok, activity} <- ActivityPub.follow(local_user, target_user) do
|
|
|
|
Logger.info("relay: followed instance: #{target_instance}; id=#{activity.data["id"]}")
|
2018-11-10 14:31:37 +00:00
|
|
|
{:ok, activity}
|
2018-08-06 07:14:16 +00:00
|
|
|
else
|
2018-11-10 13:49:02 +00:00
|
|
|
e ->
|
|
|
|
Logger.error("error: #{inspect(e)}")
|
2018-11-10 14:31:37 +00:00
|
|
|
{:error, e}
|
2018-08-06 07:14:16 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def unfollow(target_instance) do
|
|
|
|
with %User{} = local_user <- get_actor(),
|
|
|
|
%User{} = target_user <- User.get_or_fetch_by_ap_id(target_instance),
|
|
|
|
{:ok, activity} <- ActivityPub.unfollow(local_user, target_user) do
|
|
|
|
Logger.info("relay: unfollowed instance: #{target_instance}: id=#{activity.data["id"]}")
|
2018-11-10 14:31:37 +00:00
|
|
|
{:ok, activity}
|
2018-08-06 07:14:16 +00:00
|
|
|
else
|
2018-11-10 13:49:02 +00:00
|
|
|
e ->
|
|
|
|
Logger.error("error: #{inspect(e)}")
|
2018-11-10 14:31:37 +00:00
|
|
|
{:error, e}
|
2018-08-06 07:14:16 +00:00
|
|
|
end
|
|
|
|
end
|
2018-08-06 07:43:37 +00:00
|
|
|
|
2018-08-06 08:03:10 +00:00
|
|
|
def publish(%Activity{data: %{"type" => "Create"}} = activity) do
|
2018-08-06 07:43:37 +00:00
|
|
|
with %User{} = user <- get_actor(),
|
|
|
|
%Object{} = object <- Object.normalize(activity.data["object"]["id"]) do
|
|
|
|
ActivityPub.announce(user, object)
|
|
|
|
else
|
|
|
|
e -> Logger.error("error: #{inspect(e)}")
|
|
|
|
end
|
|
|
|
end
|
2018-08-06 08:03:10 +00:00
|
|
|
|
|
|
|
def publish(_), do: nil
|
2018-08-06 06:15:22 +00:00
|
|
|
end
|