include local instance in bubble timeline (#117)

Reviewed-on: https://akkoma.dev/AkkomaGang/akkoma/pulls/117
Signed-off-by: marcin mikołajczak <git@mkljczk.pl>
This commit is contained in:
floatingghost 2022-07-26 12:22:49 +00:00 committed by marcin mikołajczak
parent 5dabf69757
commit 195e46bcca
5 changed files with 18 additions and 27 deletions

View file

@ -895,7 +895,6 @@ defmodule Pleroma.Web.Router do
post("/tags/:id/follow", TagController, :follow) post("/tags/:id/follow", TagController, :follow)
post("/tags/:id/unfollow", TagController, :unfollow) post("/tags/:id/unfollow", TagController, :unfollow)
get("/followed_tags", TagController, :show_followed) get("/followed_tags", TagController, :show_followed)
end
post("/bite", BiteController, :bite) post("/bite", BiteController, :bite)
end end

View file

@ -8,5 +8,7 @@ def change do
end end
create(unique_index(:user_follows_hashtag, [:user_id, :hashtag_id])) create(unique_index(:user_follows_hashtag, [:user_id, :hashtag_id]))
create_if_not_exists(index(:user_follows_hashtag, [:hashtag_id]))
end end
end end

View file

@ -412,7 +412,7 @@ test "We don't have unexpected tables which may contain objects that are referen
["scheduled_activities"], ["scheduled_activities"],
["schema_migrations"], ["schema_migrations"],
["thread_mutes"], ["thread_mutes"],
# ["user_follows_hashtag"], # not in pleroma ["user_follows_hashtag"],
# ["user_frontend_setting_profiles"], # not in pleroma # ["user_frontend_setting_profiles"], # not in pleroma
["user_invite_tokens"], ["user_invite_tokens"],
["user_notes"], ["user_notes"],

View file

@ -864,13 +864,19 @@ test "it should return public activities that reference a given hashtag" do
user = insert(:user) user = insert(:user)
other_user = insert(:user) other_user = insert(:user)
{:ok, normally_visible} = CommonAPI.post(other_user, %{status: "hello :)", visibility: "public"}) {:ok, normally_visible} =
CommonAPI.post(other_user, %{status: "hello :)", visibility: "public"})
{:ok, public} = CommonAPI.post(user, %{status: "maji #tenshi", visibility: "public"}) {:ok, public} = CommonAPI.post(user, %{status: "maji #tenshi", visibility: "public"})
{:ok, _unrelated} = CommonAPI.post(user, %{status: "dai #tensh", visibility: "public"}) {:ok, _unrelated} = CommonAPI.post(user, %{status: "dai #tensh", visibility: "public"})
{:ok, unlisted} = CommonAPI.post(user, %{status: "maji #tenshi", visibility: "unlisted"}) {:ok, unlisted} = CommonAPI.post(user, %{status: "maji #tenshi", visibility: "unlisted"})
{:ok, _private} = CommonAPI.post(user, %{status: "maji #tenshi", visibility: "private"}) {:ok, _private} = CommonAPI.post(user, %{status: "maji #tenshi", visibility: "private"})
activities = ActivityPub.fetch_activities([other_user.follower_address], %{followed_hashtags: [hashtag.id]}) activities =
ActivityPub.fetch_activities([other_user.follower_address], %{
followed_hashtags: [hashtag.id]
})
assert length(activities) == 3 assert length(activities) == 3
normal_id = normally_visible.id normal_id = normally_visible.id
public_id = public.id public_id = public.id

View file

@ -459,7 +459,6 @@ test "should return 404 if disabled" do
test "should not return 404 if local is specified" do test "should not return 404 if local is specified" do
clear_config([:instance, :federated_timeline_available], false) clear_config([:instance, :federated_timeline_available], false)
result =
build_conn() build_conn()
|> get("/api/v1/timelines/public?local=true") |> get("/api/v1/timelines/public?local=true")
|> json_response_and_validate_schema(200) |> json_response_and_validate_schema(200)
@ -1093,18 +1092,10 @@ test "with `%{local: true, federated: false}`, forbids unauthenticated access to
describe "bubble" do describe "bubble" do
setup do: oauth_access(["read:statuses"]) setup do: oauth_access(["read:statuses"])
test "it returns nothing if no bubble is configured", %{user: user, conn: conn} do
clear_config([:instance, :local_bubble], [])
{:ok, _} = CommonAPI.post(user, %{status: ".", visibility: "public"})
conn = get(conn, "/api/v1/timelines/bubble")
assert [] = json_response_and_validate_schema(conn, :ok)
end
test "filtering", %{conn: conn, user: user} do test "filtering", %{conn: conn, user: user} do
clear_config([:instance, :local_bubble], []) clear_config([:instance, :local_bubble], [])
local_user = insert(:user) # our endpoint host has a port in it so let's set the AP ID
local_user = insert(:user, %{ap_id: "https://localhost/users/user"})
remote_user = insert(:user, %{ap_id: "https://example.com/users/remote_user"}) remote_user = insert(:user, %{ap_id: "https://example.com/users/remote_user"})
{:ok, user, local_user} = User.follow(user, local_user) {:ok, user, local_user} = User.follow(user, local_user)
{:ok, _user, remote_user} = User.follow(user, remote_user) {:ok, _user, remote_user} = User.follow(user, remote_user)
@ -1112,15 +1103,8 @@ test "filtering", %{conn: conn, user: user} do
{:ok, local_activity} = CommonAPI.post(local_user, %{status: "Status"}) {:ok, local_activity} = CommonAPI.post(local_user, %{status: "Status"})
remote_activity = create_remote_activity(remote_user) remote_activity = create_remote_activity(remote_user)
resp = # If nothing, only include ours
conn clear_config([:instance, :local_bubble], [])
|> get("/api/v1/timelines/bubble")
|> json_response_and_validate_schema(200)
|> Enum.map(& &1["id"])
assert Enum.empty?(resp)
clear_config([:instance, :local_bubble], ["localhost:4001"])
one_instance = one_instance =
conn conn