logo

pleroma

My custom branche(s) on git.pleroma.social/pleroma/pleroma
commit: 866a2663d4093204317aba7ff87a6d93eaf805fd
parent: ae50b165cced7fda1e62f677f959c6f202127aa7
Author: Roger Braun <roger@rogerbraun.net>
Date:   Fri, 24 Mar 2017 00:09:08 +0100

Add fetching of activities in context.

Diffstat:

Mlib/pleroma/web/activity_pub/activity_pub.ex6++++++
Mtest/web/activity_pub/activity_pub_test.exs12++++++++++++
2 files changed, 18 insertions(+), 0 deletions(-)

diff --git a/lib/pleroma/web/activity_pub/activity_pub.ex b/lib/pleroma/web/activity_pub/activity_pub.ex @@ -60,4 +60,10 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do Repo.all(query) |> Enum.reverse end + + def fetch_activities_for_context(context) do + query = from activity in Activity, + where: fragment("? @> ?", activity.data, ^%{ context: context }) + Repo.all(query) + end end diff --git a/test/web/activity_pub/activity_pub_test.exs b/test/web/activity_pub/activity_pub_test.exs @@ -49,6 +49,18 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do end end + describe "fetch activities in context" do + test "retrieves activities that have a given context" do + {:ok, activity} = ActivityBuilder.insert(%{"context" => "2hu"}) + {:ok, activity_two} = ActivityBuilder.insert(%{"context" => "2hu"}) + {:ok, _activity_three} = ActivityBuilder.insert(%{"context" => "3hu"}) + + activities = ActivityPub.fetch_activities_for_context("2hu") + + assert activities == [activity, activity_two] + end + end + describe "public fetch activities" do test "retrieves public activities" do %{public: public} = ActivityBuilder.public_and_non_public