X-Git-Url: http://git.squeep.com/?a=blobdiff_plain;ds=sidebyside;f=lib%2Fpleroma%2Fweb%2Factivity_pub%2Factivity_pub.ex;h=b01def6939937e59d6ff96747e2943f4631bb3fe;hb=6aa1523bb3d8dfe12ce5143d27023fd833b0c1aa;hp=0f5a78e8a79d66724416d17abf4f60ab7da4b7b1;hpb=1f0f79d95911769f1a99aebc5df47aa98b38c360;p=akkoma diff --git a/lib/pleroma/web/activity_pub/activity_pub.ex b/lib/pleroma/web/activity_pub/activity_pub.ex index 0f5a78e8a..b01def693 100644 --- a/lib/pleroma/web/activity_pub/activity_pub.ex +++ b/lib/pleroma/web/activity_pub/activity_pub.ex @@ -1,20 +1,36 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do alias Pleroma.Repo - alias Pleroma.Activity + alias Pleroma.{Activity, Object, Upload} import Ecto.Query def insert(map) when is_map(map) do map = Map.put_new_lazy(map, "id", &generate_activity_id/0) + map = if map["object"] do + object = Map.put_new_lazy(map["object"], "id", &generate_object_id/0) + Repo.insert!(%Object{data: object}) + Map.put(map, "object", object) + else + map + end + 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}" + generate_id("activities") + end + + def generate_context_id do + generate_id("contexts") + end + + def generate_object_id do + generate_id("objects") + end + + def generate_id(type) do + "#{Pleroma.Web.base_url()}/#{type}/#{Ecto.UUID.generate}" end def fetch_public_activities(opts \\ %{}) do @@ -41,4 +57,15 @@ 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 + + def upload(%Plug.Upload{} = file) do + data = Upload.store(file) + Repo.insert(%Object{data: data}) + end end