Fork of Pleroma with site-specific changes and feature branches https://git.pleroma.social/pleroma/pleroma
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

57 lines
1.6KB

  1. # Pleroma: A lightweight social networking server
  2. # Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
  3. # SPDX-License-Identifier: AGPL-3.0-only
  4. defmodule Pleroma.Web.ActivityPub.ObjectValidators.AcceptRejectValidator do
  5. use Ecto.Schema
  6. alias Pleroma.Activity
  7. alias Pleroma.EctoType.ActivityPub.ObjectValidators
  8. import Ecto.Changeset
  9. import Pleroma.Web.ActivityPub.ObjectValidators.CommonValidations
  10. @primary_key false
  11. embedded_schema do
  12. field(:id, ObjectValidators.ObjectID, primary_key: true)
  13. field(:type, :string)
  14. field(:object, ObjectValidators.ObjectID)
  15. field(:actor, ObjectValidators.ObjectID)
  16. field(:to, ObjectValidators.Recipients, default: [])
  17. field(:cc, ObjectValidators.Recipients, default: [])
  18. end
  19. def cast_data(data) do
  20. %__MODULE__{}
  21. |> cast(data, __schema__(:fields))
  22. end
  23. defp validate_data(cng) do
  24. cng
  25. |> validate_required([:id, :type, :actor, :to, :cc, :object])
  26. |> validate_inclusion(:type, ["Accept", "Reject"])
  27. |> validate_actor_presence()
  28. |> validate_object_presence(allowed_types: ["Follow"])
  29. |> validate_accept_reject_rights()
  30. end
  31. def cast_and_validate(data) do
  32. data
  33. |> cast_data
  34. |> validate_data
  35. end
  36. def validate_accept_reject_rights(cng) do
  37. with object_id when is_binary(object_id) <- get_field(cng, :object),
  38. %Activity{data: %{"object" => followed_actor}} <- Activity.get_by_ap_id(object_id),
  39. true <- followed_actor == get_field(cng, :actor) do
  40. cng
  41. else
  42. _e ->
  43. cng
  44. |> add_error(:actor, "can't accept or reject the given activity")
  45. end
  46. end
  47. end