diff options
author | rinpatch <rinpatch@sdf.org> | 2019-01-25 10:40:51 +0300 |
---|---|---|
committer | rinpatch <rinpatch@sdf.org> | 2019-01-25 10:40:51 +0300 |
commit | 3a5b3c5a3aca6886b96afb7d12628be6d42e427a (patch) | |
tree | 48e376b83da9c1f221a9eb2817025e264cf08318 /lib/pleroma/web/common_api | |
parent | c9b418e5477229017b3750c55cf3ea3d03b7e609 (diff) | |
parent | 4c99b6d35abe2beb184a12f7cba6f84a0fc6a27a (diff) | |
download | pleroma-3a5b3c5a3aca6886b96afb7d12628be6d42e427a.tar.gz |
Merge remote-tracking branch 'pl/develop' into oembed_provider
Diffstat (limited to 'lib/pleroma/web/common_api')
-rw-r--r-- | lib/pleroma/web/common_api/utils.ex | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/lib/pleroma/web/common_api/utils.ex b/lib/pleroma/web/common_api/utils.ex index a0f59d900..208677bd7 100644 --- a/lib/pleroma/web/common_api/utils.ex +++ b/lib/pleroma/web/common_api/utils.ex @@ -261,4 +261,46 @@ defmodule Pleroma.Web.CommonAPI.Utils do } end) end + + def maybe_notify_to_recipients( + recipients, + %Activity{data: %{"to" => to, "type" => _type}} = _activity + ) do + recipients ++ to + end + + def maybe_notify_mentioned_recipients( + recipients, + %Activity{data: %{"to" => _to, "type" => type} = data} = _activity + ) + when type == "Create" do + object = Object.normalize(data["object"]) + + object_data = + cond do + !is_nil(object) -> + object.data + + is_map(data["object"]) -> + data["object"] + + true -> + %{} + end + + tagged_mentions = maybe_extract_mentions(object_data) + + recipients ++ tagged_mentions + end + + def maybe_notify_mentioned_recipients(recipients, _), do: recipients + + def maybe_extract_mentions(%{"tag" => tag}) do + tag + |> Enum.filter(fn x -> is_map(x) end) + |> Enum.filter(fn x -> x["type"] == "Mention" end) + |> Enum.map(fn x -> x["href"] end) + end + + def maybe_extract_mentions(_), do: [] end |