Просмотр исходного кода

Test Relay, switch to runtime configuration.

tags/v0.9.9
lain William Pitcock 5 лет назад
Родитель
Сommit
1e9ced5af4
6 измененных файлов: 99 добавлений и 8 удалений
  1. +14
    -0
      lib/pleroma/web/activity_pub/activity_pub_controller.ex
  2. +3
    -2
      lib/pleroma/web/federator/federator.ex
  3. +3
    -6
      lib/pleroma/web/router.ex
  4. +23
    -0
      test/web/activity_pub/activity_pub_controller_test.exs
  5. +11
    -0
      test/web/activity_pub/relay_test.exs
  6. +45
    -0
      test/web/federator_test.exs

+ 14
- 0
lib/pleroma/web/activity_pub/activity_pub_controller.ex Просмотреть файл

@@ -6,11 +6,25 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubController do
alias Pleroma.Web.ActivityPub.Relay
alias Pleroma.Web.ActivityPub.Utils
alias Pleroma.Web.Federator
alias Pleroma.Config

require Logger

action_fallback(:errors)

plug(:relay_active? when action in [:relay])

def relay_active?(conn, _) do
if Config.get([:instance, :allow_relay]) do
conn
else
conn
|> put_status(404)
|> json(%{error: "not found"})
|> halt
end
end

def user(conn, %{"nickname" => nickname}) do
with %User{} = user <- User.get_cached_by_nickname(nickname),
{:ok, user} <- Pleroma.Web.WebFinger.ensure_keys_present(user) do


+ 3
- 2
lib/pleroma/web/federator/federator.ex Просмотреть файл

@@ -7,6 +7,7 @@ defmodule Pleroma.Web.Federator do
alias Pleroma.Web.ActivityPub.Relay
alias Pleroma.Web.ActivityPub.Transmogrifier
alias Pleroma.Web.ActivityPub.Utils
alias Pleroma.Config
require Logger

@websub Application.get_env(:pleroma, :websub)
@@ -71,9 +72,9 @@ defmodule Pleroma.Web.Federator do
Logger.info(fn -> "Sending #{activity.data["id"]} out via Salmon" end)
Pleroma.Web.Salmon.publish(actor, activity)

if Mix.env() != :test do
if Config.get([:instance, :allow_relay]) do
Logger.info(fn -> "Relaying #{activity.data["id"]} out" end)
Pleroma.Web.ActivityPub.Relay.publish(activity)
Relay.publish(activity)
end
end



+ 3
- 6
lib/pleroma/web/router.ex Просмотреть файл

@@ -5,7 +5,6 @@ defmodule Pleroma.Web.Router do

@instance Application.get_env(:pleroma, :instance)
@federating Keyword.get(@instance, :federating)
@allow_relay Keyword.get(@instance, :allow_relay)
@public Keyword.get(@instance, :public)
@registrations_open Keyword.get(@instance, :registrations_open)

@@ -354,11 +353,9 @@ defmodule Pleroma.Web.Router do
end

if @federating do
if @allow_relay do
scope "/relay", Pleroma.Web.ActivityPub do
pipe_through(:ap_relay)
get("/", ActivityPubController, :relay)
end
scope "/relay", Pleroma.Web.ActivityPub do
pipe_through(:ap_relay)
get("/", ActivityPubController, :relay)
end

scope "/", Pleroma.Web.ActivityPub do


+ 23
- 0
test/web/activity_pub/activity_pub_controller_test.exs Просмотреть файл

@@ -4,6 +4,29 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubControllerTest do
alias Pleroma.Web.ActivityPub.{UserView, ObjectView}
alias Pleroma.{Repo, User}
alias Pleroma.Activity
alias Pleroma.Config

describe "/relay" do
test "with the relay active, it returns the relay user", %{conn: conn} do
Config.put([:instance, :allow_relay], true)

res =
conn
|> get(activity_pub_path(conn, :relay))
|> json_response(200)

assert res["id"] =~ "/relay"
end

test "with the relay disabled, it returns 404", %{conn: conn} do
Config.put([:instance, :allow_relay], false)

res =
conn
|> get(activity_pub_path(conn, :relay))
|> json_response(404)
end
end

describe "/users/:nickname" do
test "it returns a json representation of the user", %{conn: conn} do


+ 11
- 0
test/web/activity_pub/relay_test.exs Просмотреть файл

@@ -0,0 +1,11 @@
defmodule Pleroma.Web.ActivityPub.RelayTest do
use Pleroma.DataCase

alias Pleroma.Web.ActivityPub.Relay

test "gets an actor for the relay" do
user = Relay.get_actor()

assert user.ap_id =~ "/relay"
end
end

+ 45
- 0
test/web/federator_test.exs Просмотреть файл

@@ -1,6 +1,10 @@
defmodule Pleroma.Web.FederatorTest do
alias Pleroma.Web.Federator
alias Pleroma.Web.CommonAPI
alias Pleroma.Config
use Pleroma.DataCase
import Pleroma.Factory
import Mock

test "enqueues an element according to priority" do
queue = [%{item: 1, priority: 2}]
@@ -17,4 +21,45 @@ defmodule Pleroma.Web.FederatorTest do

assert {2, [%{item: 1, priority: 2}]} = Federator.queue_pop(queue)
end

describe "Publish an activity" do
setup do
user = insert(:user)
{:ok, activity} = CommonAPI.post(user, %{"status" => "HI"})

relay_mock = {
Pleroma.Web.ActivityPub.Relay,
[],
[publish: fn _activity -> send(self(), :relay_publish) end]
}

%{activity: activity, relay_mock: relay_mock}
end

test "with relays active, it publishes to the relay", %{
activity: activity,
relay_mock: relay_mock
} do
Config.put([:instance, :allow_relay], true)

with_mocks([relay_mock]) do
Federator.handle(:publish, activity)
end

assert_received :relay_publish
end

test "with relays deactivated, it does not publish to the relay", %{
activity: activity,
relay_mock: relay_mock
} do
Config.put([:instance, :allow_relay], false)

with_mocks([relay_mock]) do
Federator.handle(:publish, activity)
end

refute_received :relay_publish
end
end
end

Загрузка…
Отмена
Сохранить