2017-04-27 01:43:58 -06:00
|
|
|
defmodule Pleroma.Web.XML do
|
2017-06-24 06:35:32 -06:00
|
|
|
require Logger
|
|
|
|
|
2017-11-18 18:22:07 -07:00
|
|
|
def string_from_xpath(_, :error), do: nil
|
2018-03-30 07:01:53 -06:00
|
|
|
|
2017-04-27 01:43:58 -06:00
|
|
|
def string_from_xpath(xpath, doc) do
|
2018-04-03 13:43:59 -06:00
|
|
|
try do
|
|
|
|
{:xmlObj, :string, res} = :xmerl_xpath.string('string(#{xpath})', doc)
|
2017-04-27 01:43:58 -06:00
|
|
|
|
2018-04-03 13:43:59 -06:00
|
|
|
res =
|
|
|
|
res
|
|
|
|
|> to_string
|
|
|
|
|> String.trim()
|
2017-04-27 01:43:58 -06:00
|
|
|
|
2018-04-03 13:43:59 -06:00
|
|
|
if res == "", do: nil, else: res
|
|
|
|
catch
|
2018-05-04 14:59:01 -06:00
|
|
|
_e ->
|
2018-04-03 13:43:59 -06:00
|
|
|
Logger.debug("Couldn't find xpath #{xpath} in XML doc")
|
|
|
|
nil
|
|
|
|
end
|
2017-04-27 01:43:58 -06:00
|
|
|
end
|
|
|
|
|
|
|
|
def parse_document(text) do
|
2017-06-24 06:35:32 -06:00
|
|
|
try do
|
2018-03-30 07:01:53 -06:00
|
|
|
{doc, _rest} =
|
|
|
|
text
|
|
|
|
|> :binary.bin_to_list()
|
2018-12-11 05:31:52 -07:00
|
|
|
|> :xmerl_scan.string(quiet: true)
|
2017-04-27 01:43:58 -06:00
|
|
|
|
2017-06-24 06:35:32 -06:00
|
|
|
doc
|
2018-12-09 02:12:48 -07:00
|
|
|
rescue
|
|
|
|
_e ->
|
2018-03-19 11:51:31 -06:00
|
|
|
Logger.debug("Couldn't parse XML: #{inspect(text)}")
|
2017-06-24 06:35:32 -06:00
|
|
|
:error
|
2018-12-09 02:12:48 -07:00
|
|
|
catch
|
|
|
|
:exit, _error ->
|
2018-06-01 11:55:25 -06:00
|
|
|
Logger.debug("Couldn't parse XML: #{inspect(text)}")
|
|
|
|
:error
|
2017-06-24 06:35:32 -06:00
|
|
|
end
|
2017-04-27 01:43:58 -06:00
|
|
|
end
|
|
|
|
end
|