diff options
author | dtluna <dtluna@openmailbox.org> | 2017-04-28 16:06:57 +0300 |
---|---|---|
committer | dtluna <dtluna@openmailbox.org> | 2017-04-28 16:06:57 +0300 |
commit | a9b2ad17596d1b6deca646239a95e94dc644ebf3 (patch) | |
tree | 9e086441831f33e191cd62b05b61ece0677491cc /lib/xml_builder.ex | |
parent | 28b203d08fe2e0d7afe3f3ec03a16cef62288b23 (diff) | |
parent | fb5cebc1b5dcfd6af7fa1a81bc5b26275714fa26 (diff) | |
download | pleroma-a9b2ad17596d1b6deca646239a95e94dc644ebf3.tar.gz |
Merge branch 'develop' of ssh.gitgud.io:lambadalambda/pleroma into feature/unfollow-activity
Diffstat (limited to 'lib/xml_builder.ex')
-rw-r--r-- | lib/xml_builder.ex | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/lib/xml_builder.ex b/lib/xml_builder.ex new file mode 100644 index 000000000..ac1ac8a74 --- /dev/null +++ b/lib/xml_builder.ex @@ -0,0 +1,42 @@ +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: "<?xml version=\"1.0\" encoding=\"UTF-8\"?>" <> to_xml(content) + + defp make_open_tag(tag, attributes) do + attributes_string = for {attribute, value} <- attributes do + "#{attribute}=\"#{value}\"" + end |> Enum.join(" ") + + Enum.join([tag, attributes_string], " ") |> String.strip + end +end |