logo

pleroma

My custom branche(s) on git.pleroma.social/pleroma/pleroma

plug_helper.ex (1466B)


  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. defmodule Pleroma.Plugs.PlugHelper do
  5. @moduledoc "Pleroma Plug helper"
  6. @called_plugs_list_id :called_plugs
  7. def called_plugs_list_id, do: @called_plugs_list_id
  8. @skipped_plugs_list_id :skipped_plugs
  9. def skipped_plugs_list_id, do: @skipped_plugs_list_id
  10. @doc "Returns `true` if specified plug was called."
  11. def plug_called?(conn, plug_module) do
  12. contained_in_private_list?(conn, @called_plugs_list_id, plug_module)
  13. end
  14. @doc "Returns `true` if specified plug was explicitly marked as skipped."
  15. def plug_skipped?(conn, plug_module) do
  16. contained_in_private_list?(conn, @skipped_plugs_list_id, plug_module)
  17. end
  18. @doc "Returns `true` if specified plug was either called or explicitly marked as skipped."
  19. def plug_called_or_skipped?(conn, plug_module) do
  20. plug_called?(conn, plug_module) || plug_skipped?(conn, plug_module)
  21. end
  22. # Appends plug to known list (skipped, called). Intended to be used from within plug code only.
  23. def append_to_private_list(conn, list_id, value) do
  24. list = conn.private[list_id] || []
  25. modified_list = Enum.uniq(list ++ [value])
  26. Plug.Conn.put_private(conn, list_id, modified_list)
  27. end
  28. defp contained_in_private_list?(conn, private_variable, value) do
  29. list = conn.private[private_variable] || []
  30. value in list
  31. end
  32. end