+ /* Mimic the message from libxml.c::php_libxml_ctx_error_level() */
+ private function log_xml_error($error) {
+ $output = "";
+
+ switch ($error->level) {
+ case LIBXML_ERR_WARNING:
+ $output .= "Warning $error->code: ";
+ break;
+ case LIBXML_ERR_ERROR:
+ $output .= "Error $error->code: ";
+ break;
+ case LIBXML_ERR_FATAL:
+ $output .= "Fatal Error $error->code: ";
+ break;
+ }
+
+ $output .= trim($error->message);
+
+ if ($error->file) {
+ $output .= " in $error->file";
+ } else {
+ $output .= " in Entity,";
+ }
+
+ $output .=" line $error->line";
+
+ error_log($output);
+ }
+
+ private function load_stylesheet($host) {
+ $stylesheet = "file://" . __DIR__ . "/rss_converter_" . $host . ".xsl";
+ if (FALSE === file_exists($stylesheet)) {
+ trigger_error("Conversion to RSS not supported: $host", E_USER_ERROR);
+ return NULL;
+ }
+
+ $stylesheet_contents = $this->get_contents($stylesheet);
+
+ $xslDoc = new DOMDocument();
+ $xslDoc->loadXML($stylesheet_contents);
+
+ $xsltProcessor = new XSLTProcessor();
+ $xsltProcessor->registerPHPFunctions();
+ $xsltProcessor->setParameter('', 'generateEnclosure', $this->generate_enclosure);
+ $xsltProcessor->importStylesheet($xslDoc);
+
+ return $xsltProcessor;
+ }
+
+ private function json_to_xml($html, $json_match_expr, $rootName) {
+ // pre-process, convert json to XML
+ $ret = preg_match($json_match_expr, $html, $matches);
+ if ($ret !== 1) {
+ trigger_error("Cannot match expression: $json_match_expr\n", E_USER_ERROR);
+ return NULL;
+ }
+
+ $data = json_decode($matches[1]);
+ if (!$data) {
+ return NULL;
+ }
+
+ $serializer_options = array (
+ 'addDecl' => TRUE,
+ 'encoding' => "UTF-8",
+ 'indent' => ' ',
+ 'rootName' => $rootName,
+ );
+
+ $serializer = new XML_Serializer($serializer_options);
+
+ $status = $serializer->serialize($data);
+ if (PEAR::isError($status)) {
+ trigger_error($status->getMessage(), E_USER_ERROR);
+ return NULL;
+ }