projects
/
akkoma
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge pull request 'Change default Postgres user/DB to akkoma' (#63) from norm/akkoma...
[akkoma]
/
lib
/
mix
/
tasks
/
pleroma
/
relay.ex
diff --git
a/lib/mix/tasks/pleroma/relay.ex
b/lib/mix/tasks/pleroma/relay.ex
index 2502923af314e40311cb3059cba9ceb4f82d5471..01e6b4279bbadad6eaebc272a6e02a00aec18dce 100644
(file)
--- a/
lib/mix/tasks/pleroma/relay.ex
+++ b/
lib/mix/tasks/pleroma/relay.ex
@@
-1,43
+1,59
@@
+# Pleroma: A lightweight social networking server
+# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
+# SPDX-License-Identifier: AGPL-3.0-only
+
defmodule Mix.Tasks.Pleroma.Relay do
use Mix.Task
defmodule Mix.Tasks.Pleroma.Relay do
use Mix.Task
+ import Mix.Pleroma
alias Pleroma.Web.ActivityPub.Relay
alias Pleroma.Web.ActivityPub.Relay
- alias Mix.Tasks.Pleroma.Common
@shortdoc "Manages remote relays"
@shortdoc "Manages remote relays"
- @moduledoc """
- Manages remote relays
-
- ## Follow a remote relay
+ @moduledoc File.read!("docs/administration/CLI_tasks/relay.md")
- ``mix pleroma.relay follow <relay_url>``
+ def run(["follow", target]) do
+ start_pleroma()
- Example: ``mix pleroma.relay follow https://example.org/relay``
+ with {:ok, _activity} <- Relay.follow(target) do
+ # put this task to sleep to allow the genserver to push out the messages
+ :timer.sleep(500)
+ else
+ {:error, e} -> shell_error("Error while following #{target}: #{inspect(e)}")
+ end
+ end
- ## Unfollow a remote relay
+ def run(["unfollow", target | rest]) do
+ start_pleroma()
- ``mix pleroma.relay unfollow <relay_url>``
+ {options, [], []} =
+ OptionParser.parse(
+ rest,
+ strict: [force: :boolean],
+ aliases: [f: :force]
+ )
- Example: ``mix pleroma.relay unfollow https://example.org/relay``
- """
- def run(["follow", target]) do
- Common.start_pleroma()
+ force = Keyword.get(options, :force, false)
- with {:ok,
activity} <- Relay.follow(target
) do
+ with {:ok,
_activity} <- Relay.unfollow(target, %{force: force}
) do
# put this task to sleep to allow the genserver to push out the messages
:timer.sleep(500)
else
# put this task to sleep to allow the genserver to push out the messages
:timer.sleep(500)
else
- {:error, e} ->
Mix.shell().
error("Error while following #{target}: #{inspect(e)}")
+ {:error, e} ->
shell_
error("Error while following #{target}: #{inspect(e)}")
end
end
end
end
- def run(["
unfollow", target
]) do
-
Common.
start_pleroma()
+ def run(["
list"
]) do
+ start_pleroma()
- with {:ok, activity} <- Relay.follow(target) do
- # put this task to sleep to allow the genserver to push out the messages
- :timer.sleep(500)
+ with {:ok, list} <- Relay.list() do
+ Enum.each(list, &print_relay_url/1)
else
else
- {:error, e} ->
Mix.shell().error("Error while following #{target}
: #{inspect(e)}")
+ {:error, e} ->
shell_error("Error while fetching relay subscription list
: #{inspect(e)}")
end
end
end
end
+
+ defp print_relay_url(%{followed_back: false} = relay) do
+ shell_info("#{relay.actor} - no Accept received (relay didn't follow back)")
+ end
+
+ defp print_relay_url(relay), do: shell_info(relay.actor)
end
end