fix inbound federation

This commit is contained in:
sadposter 2021-12-14 13:58:16 +00:00
parent 144c06487a
commit 5d901c337e
7 changed files with 49 additions and 23 deletions

View file

@ -28,6 +28,7 @@ defmodule Mix.Tasks.Pleroma.Activity do
def run(["delete_by_keyword", user, keyword | _rest]) do
start_pleroma()
u = User.get_by_nickname(user)
Activity
|> Activity.with_preloaded_object()
|> Activity.restrict_deactivated_users()
@ -38,8 +39,8 @@ defmodule Mix.Tasks.Pleroma.Activity do
:offset
)
|> Enum.map(fn x -> CommonAPI.delete(x.id, u) end)
|> Enum.count
|> IO.puts
|> Enum.count()
|> IO.puts()
end
defp query_with(q, search_query) do

View file

@ -11,6 +11,16 @@ defmodule Mix.Tasks.Pleroma.Search do
@shortdoc "Manages elasticsearch"
def run(["import_since", d | _rest]) do
start_pleroma()
{:ok, since, _} = DateTime.from_iso8601(d)
from(a in Activity, where: not ilike(a.actor, "%/relay") and a.inserted_at > ^since)
|> Activity.with_preloaded_object()
|> Activity.with_preloaded_user_actor()
|> get_all
end
def run(["import" | _rest]) do
start_pleroma()
@ -41,9 +51,11 @@ defmodule Mix.Tasks.Pleroma.Search do
else
res
|> Enum.filter(fn x ->
t = x.object
t =
x.object
|> Map.get(:data, %{})
|> Map.get("type", "")
t == "Note"
end)
|> Pleroma.Elasticsearch.bulk_post(:activities)

View file

@ -441,6 +441,7 @@ defmodule Mix.Tasks.Pleroma.User do
def run(["blocking", nickname]) do
start_pleroma()
with %User{local: true} = user <- User.get_cached_by_nickname(nickname) do
blocks = User.following_ap_ids(user)
IO.inspect(blocks, limit: :infinity)
@ -450,6 +451,7 @@ defmodule Mix.Tasks.Pleroma.User do
def run(["timeline_query", nickname]) do
start_pleroma()
params = %{local: true}
with %User{local: true} = user <- User.get_cached_by_nickname(nickname) do
params =
params
@ -462,6 +464,7 @@ defmodule Mix.Tasks.Pleroma.User do
|> Map.put(:user, user)
|> Map.put(:local_only, params[:local])
|> Map.delete(:local)
_activities =
[user.ap_id | User.following(user)]
|> ActivityPub.fetch_activities(params)

View file

@ -17,7 +17,9 @@ defmodule Pleroma.Elasticsearch do
maybe_put_into_elasticsearch(activity)
end
def maybe_put_into_elasticsearch(%{data: %{"type" => "Create"}, object: %{data: %{"type" => "Note"}}} = activity) do
def maybe_put_into_elasticsearch(
%{data: %{"type" => "Create"}, object: %{data: %{"type" => "Note"}}} = activity
) do
if Config.get([:search, :provider]) == Pleroma.Search.Elasticsearch do
actor = Pleroma.Activity.user_actor(activity)

View file

@ -46,6 +46,12 @@ defmodule Pleroma.Search.Elasticsearch do
@impl Pleroma.Search
def search(%{assigns: %{user: user}} = _conn, %{q: query} = _params, _options) do
q = %{
size: 500,
terminate_after: 500,
timeout: "10s",
sort: [
%{"_timestamp" => "desc"}
],
query: %{
bool: %{
must: parse(String.trim(query))
@ -64,6 +70,7 @@ defmodule Pleroma.Search.Elasticsearch do
|> Enum.map(fn result -> result["_id"] end)
|> Pleroma.Activity.all_by_ids_with_object()
|> Enum.filter(fn x -> Visibility.visible_for_user?(x, user) end)
|> Enum.reverse()
%{
"accounts" => [],

View file

@ -398,9 +398,11 @@ defmodule Pleroma.Web.CommonAPI do
def post(user, %{status: _} = data) do
with {:ok, draft} <- ActivityDraft.create(user, data) do
activity = ActivityPub.create(draft.changes, draft.preview?)
unless draft.preview? do
Pleroma.Elasticsearch.maybe_put_into_elasticsearch(activity)
end
activity
end
end

View file

@ -79,7 +79,6 @@ defmodule Pleroma.Web.Endpoint do
}
)
# Serve at "/" the static files from "priv/static" directory.
#
# You should set gzip to true if you are running phoenix.digest