diff options
| author | Haelwenn (lanodan) Monnier <contact@hacktivis.me> | 2020-04-01 07:47:07 +0200 | 
|---|---|---|
| committer | Haelwenn (lanodan) Monnier <contact@hacktivis.me> | 2020-04-10 06:20:02 +0200 | 
| commit | 62656ab259cec1a8585abecf45096b283fa4c60a (patch) | |
| tree | 53662dc406811afe8f9a332ae91e20887e6f03dc /lib | |
| parent | 369c03834c5f2638080ff515055723e6c1c716bf (diff) | |
| download | pleroma-62656ab259cec1a8585abecf45096b283fa4c60a.tar.gz pleroma-62656ab259cec1a8585abecf45096b283fa4c60a.zip | |
User: Move inbox & shared_inbox to own fields
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/pleroma/user.ex | 8 | ||||
| -rw-r--r-- | lib/pleroma/web/activity_pub/activity_pub.ex | 19 | ||||
| -rw-r--r-- | lib/pleroma/web/activity_pub/publisher.ex | 13 | 
3 files changed, 31 insertions, 9 deletions
| diff --git a/lib/pleroma/user.ex b/lib/pleroma/user.ex index 027386a22..7d8f3a76b 100644 --- a/lib/pleroma/user.ex +++ b/lib/pleroma/user.ex @@ -134,6 +134,8 @@ defmodule Pleroma.User do      field(:skip_thread_containment, :boolean, default: false)      field(:actor_type, :string, default: "Person")      field(:also_known_as, {:array, :string}, default: []) +    field(:inbox, :string) +    field(:shared_inbox, :string)      embeds_one(        :notification_settings, @@ -367,6 +369,8 @@ defmodule Pleroma.User do          :bio,          :name,          :ap_id, +        :inbox, +        :shared_inbox,          :nickname,          :public_key,          :avatar, @@ -411,6 +415,8 @@ defmodule Pleroma.User do          :name,          :avatar,          :public_key, +        :inbox, +        :shared_inbox,          :locked,          :no_rich_text,          :default_scope, @@ -508,6 +514,8 @@ defmodule Pleroma.User do          :follower_address,          :following_address,          :public_key, +        :inbox, +        :shared_inbox,          :avatar,          :last_refreshed_at,          :ap_enabled, diff --git a/lib/pleroma/web/activity_pub/activity_pub.ex b/lib/pleroma/web/activity_pub/activity_pub.ex index 0e4a9d842..f0bbecc9b 100644 --- a/lib/pleroma/web/activity_pub/activity_pub.ex +++ b/lib/pleroma/web/activity_pub/activity_pub.ex @@ -1432,7 +1432,20 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do      discoverable = data["discoverable"] || false      invisible = data["invisible"] || false      actor_type = data["type"] || "Person" -    public_key = data["publicKey"]["publicKeyPem"] + +    public_key = +      if is_map(data["publicKey"]) && is_binary(data["publicKey"]["publicKeyPem"]) do +        data["publicKey"]["publicKeyPem"] +      else +        nil +      end + +    shared_inbox = +      if is_map(data["endpoints"]) && is_binary(data["endpoints"]["sharedInbox"]) do +        data["endpoints"]["sharedInbox"] +      else +        nil +      end      user_data = %{        ap_id: data["id"], @@ -1451,7 +1464,9 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do        bio: data["summary"],        actor_type: actor_type,        also_known_as: Map.get(data, "alsoKnownAs", []), -      public_key: public_key +      public_key: public_key, +      inbox: data["inbox"], +      shared_inbox: shared_inbox      }      # nickname can be nil because of virtual actors diff --git a/lib/pleroma/web/activity_pub/publisher.ex b/lib/pleroma/web/activity_pub/publisher.ex index 6c558e7f0..b70cbd043 100644 --- a/lib/pleroma/web/activity_pub/publisher.ex +++ b/lib/pleroma/web/activity_pub/publisher.ex @@ -141,8 +141,8 @@ defmodule Pleroma.Web.ActivityPub.Publisher do      |> Enum.map(& &1.ap_id)    end -  defp maybe_use_sharedinbox(%User{source_data: data}), -    do: (is_map(data["endpoints"]) && Map.get(data["endpoints"], "sharedInbox")) || data["inbox"] +  defp maybe_use_sharedinbox(%User{shared_inbox: nil, inbox: inbox}), do: inbox +  defp maybe_use_sharedinbox(%User{shared_inbox: shared_inbox}), do: shared_inbox    @doc """    Determine a user inbox to use based on heuristics.  These heuristics @@ -157,7 +157,7 @@ defmodule Pleroma.Web.ActivityPub.Publisher do    """    def determine_inbox(          %Activity{data: activity_data}, -        %User{source_data: data} = user +        %User{inbox: inbox} = user        ) do      to = activity_data["to"] || []      cc = activity_data["cc"] || [] @@ -174,7 +174,7 @@ defmodule Pleroma.Web.ActivityPub.Publisher do          maybe_use_sharedinbox(user)        true -> -        data["inbox"] +        inbox      end    end @@ -192,14 +192,13 @@ defmodule Pleroma.Web.ActivityPub.Publisher do      inboxes =        recipients        |> Enum.filter(&User.ap_enabled?/1) -      |> Enum.map(fn %{source_data: data} -> data["inbox"] end) +      |> Enum.map(fn actor -> actor.inbox end)        |> Enum.filter(fn inbox -> should_federate?(inbox, public) end)        |> Instances.filter_reachable()      Repo.checkout(fn ->        Enum.each(inboxes, fn {inbox, unreachable_since} -> -        %User{ap_id: ap_id} = -          Enum.find(recipients, fn %{source_data: data} -> data["inbox"] == inbox end) +        %User{ap_id: ap_id} = Enum.find(recipients, fn actor -> actor.inbox == inbox end)          # Get all the recipients on the same host and add them to cc. Otherwise, a remote          # instance would only accept a first message for the first recipient and ignore the rest. | 
