logo

pleroma

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

audio_video_validator.ex (3006B)


  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.AudioVideoValidator 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} -> String.starts_with?(mime_type, ["video/", "audio/"])
  48. %{"mimeType" => mime_type} -> String.starts_with?(mime_type, ["video/", "audio/"])
  49. _ -> false
  50. end)
  51. end
  52. defp fix_url(%{"url" => url} = data) when is_list(url) do
  53. attachment = find_attachment(url)
  54. link_element =
  55. Enum.find(url, fn
  56. %{"mediaType" => "text/html"} -> true
  57. %{"mimeType" => "text/html"} -> true
  58. _ -> false
  59. end)
  60. data
  61. |> Map.put("attachment", [attachment])
  62. |> Map.put("url", link_element["href"])
  63. end
  64. defp fix_url(data), do: data
  65. defp fix_content(%{"mediaType" => "text/markdown", "content" => content} = data)
  66. when is_binary(content) do
  67. content =
  68. content
  69. |> Pleroma.Formatter.markdown_to_html()
  70. |> Pleroma.HTML.filter_tags()
  71. Map.put(data, "content", content)
  72. end
  73. defp fix_content(data), do: data
  74. defp fix(data) do
  75. data
  76. |> CommonFixes.fix_actor()
  77. |> CommonFixes.fix_object_defaults()
  78. |> Transmogrifier.fix_emoji()
  79. |> fix_url()
  80. |> fix_content()
  81. end
  82. def changeset(struct, data) do
  83. data = fix(data)
  84. struct
  85. |> cast(data, __schema__(:fields) -- [:attachment, :tag])
  86. |> cast_embed(:attachment, required: true)
  87. |> cast_embed(:tag)
  88. end
  89. defp validate_data(data_cng) do
  90. data_cng
  91. |> validate_inclusion(:type, ["Audio", "Video"])
  92. |> validate_required([:id, :actor, :attributedTo, :type, :context])
  93. |> CommonValidations.validate_any_presence([:cc, :to])
  94. |> CommonValidations.validate_fields_match([:actor, :attributedTo])
  95. |> CommonValidations.validate_actor_presence()
  96. |> CommonValidations.validate_host_match()
  97. end
  98. end