summaryrefslogtreecommitdiff
path: root/lib/xml_builder.ex
diff options
context:
space:
mode:
authorIvan Tashkinov <ivantashkinov@gmail.com>2020-10-17 13:12:39 +0300
committerIvan Tashkinov <ivantashkinov@gmail.com>2020-10-17 13:12:39 +0300
commit049ece1ef38f1aeb656a88ed1d15bf3d4a364e01 (patch)
tree16d4a05e533685e8b8385f886e58addb05a90d7d /lib/xml_builder.ex
parent2498e569f12694439b6f99d0730f6fb36301c454 (diff)
parent023f726d7f497705d766adee8874b94efb08a0aa (diff)
downloadpleroma-049ece1ef38f1aeb656a88ed1d15bf3d4a364e01.tar.gz
pleroma-049ece1ef38f1aeb656a88ed1d15bf3d4a364e01.zip
Merge remote-tracking branch 'remotes/origin/develop' into ostatus-controller-no-auth-check-on-non-federating-instances
# Conflicts: # lib/pleroma/web/feed/user_controller.ex # lib/pleroma/web/o_status/o_status_controller.ex # lib/pleroma/web/router.ex # lib/pleroma/web/static_fe/static_fe_controller.ex
Diffstat (limited to 'lib/xml_builder.ex')
-rw-r--r--lib/xml_builder.ex49
1 files changed, 0 insertions, 49 deletions
diff --git a/lib/xml_builder.ex b/lib/xml_builder.ex
deleted file mode 100644
index 33b63a71f..000000000
--- a/lib/xml_builder.ex
+++ /dev/null
@@ -1,49 +0,0 @@
-# Pleroma: A lightweight social networking server
-# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
-# SPDX-License-Identifier: AGPL-3.0-only
-
-defmodule Pleroma.XmlBuilder do
- def to_xml({tag, attributes, content}) do
- open_tag = make_open_tag(tag, attributes)
-
- content_xml = to_xml(content)
-
- "<#{open_tag}>#{content_xml}</#{tag}>"
- end
-
- def to_xml({tag, %{} = attributes}) do
- open_tag = make_open_tag(tag, attributes)
-
- "<#{open_tag} />"
- end
-
- def to_xml({tag, content}), do: to_xml({tag, %{}, content})
-
- def to_xml(content) when is_binary(content) do
- to_string(content)
- end
-
- def to_xml(content) when is_list(content) do
- for element <- content do
- to_xml(element)
- end
- |> Enum.join()
- end
-
- def to_xml(%NaiveDateTime{} = time) do
- NaiveDateTime.to_iso8601(time)
- end
-
- def to_doc(content), do: ~s(<?xml version="1.0" encoding="UTF-8"?>) <> to_xml(content)
-
- defp make_open_tag(tag, attributes) do
- attributes_string =
- for {attribute, value} <- attributes do
- value = String.replace(value, "\"", "&quot;")
- "#{attribute}=\"#{value}\""
- end
- |> Enum.join(" ")
-
- [tag, attributes_string] |> Enum.join(" ") |> String.trim()
- end
-end