logo

pleroma

My custom branche(s) on git.pleroma.social/pleroma/pleroma
commit: 1f0f79d95911769f1a99aebc5df47aa98b38c360
parent: 9ad045fd587f83386d9582136c971dbcd4410b67
Author: Roger Braun <roger@rogerbraun.net>
Date:   Thu, 23 Mar 2017 17:56:49 +0100

Generate ids for activities.

Diffstat:

Mlib/pleroma/web/activity_pub/activity_pub.ex10++++++++++
Mtest/web/activity_pub/activity_pub_test.exs18++++++++++++++----
2 files changed, 24 insertions(+), 4 deletions(-)

diff --git a/lib/pleroma/web/activity_pub/activity_pub.ex b/lib/pleroma/web/activity_pub/activity_pub.ex @@ -4,9 +4,19 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do import Ecto.Query def insert(map) when is_map(map) do + map = Map.put_new_lazy(map, "id", &generate_activity_id/0) + Repo.insert(%Activity{data: map}) end + def generate_activity_id do + host = + Application.get_env(:pleroma, Pleroma.Web.Endpoint) + |> Keyword.fetch!(:url) + |> Keyword.fetch!(:host) + "https://#{host}/activities/#{Ecto.UUID.generate}" + end + def fetch_public_activities(opts \\ %{}) do public = ["https://www.w3.org/ns/activitystreams#Public"] fetch_activities(public, opts) diff --git a/test/web/activity_pub/activity_pub_test.exs b/test/web/activity_pub/activity_pub_test.exs @@ -5,17 +5,27 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do alias Pleroma.Builders.ActivityBuilder describe "insertion" do - test "inserts a given map into the activity database" do + test "inserts a given map into the activity database, giving it an id if it has none." do data = %{ - ok: true + "ok" => true } {:ok, %Activity{} = activity} = ActivityPub.insert(data) - assert activity.data == data + assert activity.data["ok"] == data["ok"] + assert is_binary(activity.data["id"]) + + given_id = "bla" + data = %{ + "ok" => true, + "id" => given_id + } + + {:ok, %Activity{} = activity} = ActivityPub.insert(data) + assert activity.data["ok"] == data["ok"] + assert activity.data["id"] == given_id end end - describe "fetch activities for recipients" do test "retrieve the activities for certain recipients" do {:ok, activity_one} = ActivityBuilder.insert(%{"to" => ["someone"]})