# Pleroma: A lightweight social networking server # Copyright © 2017-2020 Pleroma Authors # SPDX-License-Identifier: AGPL-3.0-only defmodule Pleroma.Web.ActivityPub.ObjectValidators.DeleteValidator do use Ecto.Schema alias Pleroma.Web.ActivityPub.ObjectValidators.Types import Ecto.Changeset import Pleroma.Web.ActivityPub.ObjectValidators.CommonValidations @primary_key false embedded_schema do field(:id, Types.ObjectID, primary_key: true) field(:type, :string) field(:actor, Types.ObjectID) field(:to, Types.Recipients, default: []) field(:cc, Types.Recipients, default: []) field(:object, Types.ObjectID) end def cast_data(data) do %__MODULE__{} |> cast(data, __schema__(:fields)) end def validate_data(cng) do cng |> validate_required([:id, :type, :actor, :to, :cc, :object]) |> validate_inclusion(:type, ["Delete"]) |> validate_same_domain() |> validate_object_presence() end def validate_same_domain(cng) do actor_domain = cng |> get_field(:actor) |> URI.parse() |> (& &1.host).() object_domain = cng |> get_field(:object) |> URI.parse() |> (& &1.host).() if object_domain != actor_domain do cng |> add_error(:actor, "is not allowed to delete object") else cng end end def cast_and_validate(data) do data |> cast_data |> validate_data end end