diff options
author | kaniini <nenolod@gmail.com> | 2019-01-25 05:19:32 +0000 |
---|---|---|
committer | kaniini <nenolod@gmail.com> | 2019-01-25 05:19:32 +0000 |
commit | 4c99b6d35abe2beb184a12f7cba6f84a0fc6a27a (patch) | |
tree | ea0088876ab982a270a286048316e0eed6c18af7 /lib/pleroma/web/common_api/utils.ex | |
parent | 4df71cd88b2725f1838c2899b3078a74dbb0c33f (diff) | |
parent | 9274cabe01977a3c2d35059d7889c63e2bd54de1 (diff) | |
download | pleroma-4c99b6d35abe2beb184a12f7cba6f84a0fc6a27a.tar.gz |
Merge branch 'fix/tusky-dm' into 'develop'
Add actor to recipients list
Closes #390
See merge request pleroma/pleroma!683
Diffstat (limited to 'lib/pleroma/web/common_api/utils.ex')
-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 |