aboutsummaryrefslogtreecommitdiff
path: root/lib/pleroma/xml_builder.ex
diff options
context:
space:
mode:
authorAlex Gleason <alex@alexgleason.me>2020-10-13 19:20:00 -0500
committerAlex Gleason <alex@alexgleason.me>2020-10-13 19:20:00 -0500
commitc3112fd13a6af239b9dff0813e93266ec58f571e (patch)
tree7f2252d7a08e4a59b66e392b2732a1cdd8745758 /lib/pleroma/xml_builder.ex
parent66e00ace7c0708f2f9361bc6e1008ccea08cb6ef (diff)
parent481906207e6d803e5c4d3e455c7b93119e392177 (diff)
downloadpleroma-c3112fd13a6af239b9dff0813e93266ec58f571e.tar.gz
Merge remote-tracking branch 'upstream/develop' into registration-workflow
Diffstat (limited to 'lib/pleroma/xml_builder.ex')
-rw-r--r--lib/pleroma/xml_builder.ex49
1 files changed, 49 insertions, 0 deletions
diff --git a/lib/pleroma/xml_builder.ex b/lib/pleroma/xml_builder.ex
new file mode 100644
index 000000000..33b63a71f
--- /dev/null
+++ b/lib/pleroma/xml_builder.ex
@@ -0,0 +1,49 @@
+# 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