logo

pleroma

My custom branche(s) on git.pleroma.social/pleroma/pleroma git clone https://hacktivis.me/git/pleroma.git

audio_image_video_validator.ex (3095B)


  1. # Pleroma: A lightweight social networking server
  2. # Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/>
  3. # SPDX-License-Identifier: AGPL-3.0-only
  4. defmodule Pleroma.Web.ActivityPub.ObjectValidators.AudioImageVideoValidator do
  5. use Ecto.Schema
  6. alias Pleroma.Web.ActivityPub.ObjectValidators.CommonFixes
  7. alias Pleroma.Web.ActivityPub.ObjectValidators.CommonValidations
  8. alias Pleroma.Web.ActivityPub.Transmogrifier
  9. import Ecto.Changeset
  10. @primary_key false
  11. @derive Jason.Encoder
  12. embedded_schema do
  13. quote do
  14. unquote do
  15. import Elixir.Pleroma.Web.ActivityPub.ObjectValidators.CommonFields
  16. message_fields()
  17. object_fields()
  18. status_object_fields()
  19. end
  20. end
  21. end
  22. def cast_and_apply(data) do
  23. data
  24. |> cast_data
  25. |> apply_action(:insert)
  26. end
  27. def cast_and_validate(data) do
  28. data
  29. |> cast_data()
  30. |> validate_data()
  31. end
  32. def cast_data(data) do
  33. %__MODULE__{}
  34. |> changeset(data)
  35. end
  36. defp find_attachment(url) do
  37. mpeg_url =
  38. Enum.find(url, fn
  39. %{"mediaType" => mime_type, "tag" => tags} when is_list(tags) ->
  40. mime_type == "application/x-mpegURL"
  41. _ ->
  42. false
  43. end)
  44. url
  45. |> Enum.concat(mpeg_url["tag"] || [])
  46. |> Enum.find(fn
  47. %{"mediaType" => mime_type} ->
  48. String.starts_with?(mime_type, ["video/", "audio/", "image/"])
  49. %{"mimeType" => mime_type} ->
  50. String.starts_with?(mime_type, ["video/", "audio/", "image/"])
  51. _ ->
  52. false
  53. end)
  54. end
  55. defp fix_url(%{"url" => url} = data) when is_list(url) do
  56. attachment = find_attachment(url)
  57. link_element =
  58. Enum.find(url, fn
  59. %{"mediaType" => "text/html"} -> true
  60. %{"mimeType" => "text/html"} -> true
  61. _ -> false
  62. end)
  63. data
  64. |> Map.put("attachment", [attachment])
  65. |> Map.put("url", link_element["href"])
  66. end
  67. defp fix_url(data), do: data
  68. defp fix_content(%{"mediaType" => "text/markdown", "content" => content} = data)
  69. when is_binary(content) do
  70. content =
  71. content
  72. |> Pleroma.Formatter.markdown_to_html()
  73. |> Pleroma.HTML.filter_tags()
  74. Map.put(data, "content", content)
  75. end
  76. defp fix_content(data), do: data
  77. defp fix(data) do
  78. data
  79. |> CommonFixes.fix_actor()
  80. |> CommonFixes.fix_object_defaults()
  81. |> CommonFixes.fix_quote_url()
  82. |> Transmogrifier.fix_emoji()
  83. |> fix_url()
  84. |> fix_content()
  85. end
  86. def changeset(struct, data) do
  87. data = fix(data)
  88. struct
  89. |> cast(data, __schema__(:fields) -- [:attachment, :tag])
  90. |> cast_embed(:attachment, required: true)
  91. |> cast_embed(:tag)
  92. end
  93. defp validate_data(data_cng) do
  94. data_cng
  95. |> validate_inclusion(:type, ~w[Audio Image Video])
  96. |> validate_required([:id, :actor, :attributedTo, :type, :context])
  97. |> CommonValidations.validate_any_presence([:cc, :to])
  98. |> CommonValidations.validate_fields_match([:actor, :attributedTo])
  99. |> CommonValidations.validate_actor_presence()
  100. |> CommonValidations.validate_host_match()
  101. end
  102. end