8246558ede963a6442077e51896223ea5f2cd48d
[akkoma] / lib / pleroma / web / activity_pub / object_validator.ex
1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
4
5 defmodule Pleroma.Web.ActivityPub.ObjectValidator do
6 @moduledoc """
7 This module is responsible for validating an object (which can be an activity)
8 and checking if it is both well formed and also compatible with our view of
9 the system.
10 """
11
12 alias Pleroma.Object
13 alias Pleroma.User
14 alias Pleroma.Web.ActivityPub.ObjectValidators.LikeValidator
15 alias Pleroma.Web.ActivityPub.ObjectValidators.EmojiReactValidator
16
17 @spec validate(map(), keyword()) :: {:ok, map(), keyword()} | {:error, any()}
18 def validate(object, meta)
19
20 def validate(%{"type" => "Like"} = object, meta) do
21 with {:ok, object} <-
22 object |> LikeValidator.cast_and_validate() |> Ecto.Changeset.apply_action(:insert) do
23 object = stringify_keys(object |> Map.from_struct())
24 {:ok, object, meta}
25 end
26 end
27
28 def validate(%{"type" => "EmojiReact"} = object, meta) do
29 with {:ok, object} <-
30 object
31 |> EmojiReactValidator.cast_and_validate()
32 |> Ecto.Changeset.apply_action(:insert) do
33 object = stringify_keys(object |> Map.from_struct())
34 {:ok, object, meta}
35 end
36 end
37
38 def stringify_keys(object) do
39 object
40 |> Map.new(fn {key, val} -> {to_string(key), val} end)
41 end
42
43 def fetch_actor_and_object(object) do
44 User.get_or_fetch_by_ap_id(object["actor"])
45 Object.normalize(object["object"])
46 :ok
47 end
48 end