/** * create jasper config information used for input for executing the report * * @param string $report_source full path to the jrxml-report definition file * * @return array Array with referense to the config-file and report name */ protected static function _create_jasper_info($report_source) { $info = pathinfo($report_source); $base_name = basename($report_source, '.' . $info['extension']); $report_name = "report_{$base_name}"; $memory = xmlwriter_open_memory(); xmlwriter_start_document($memory, '1.0', 'UTF-8'); xmlwriter_start_element($memory, 'JasperConfig'); // <JasperConfig> xmlwriter_start_element($memory, 'Reports'); // <Reports> xmlwriter_start_element($memory, 'Report'); // <Report> xmlwriter_write_attribute($memory, 'name', $report_name); xmlwriter_write_attribute($memory, 'source', $report_source); xmlwriter_end_element($memory); // </Report> xmlwriter_end_element($memory); // </Reports> xmlwriter_end_element($memory); // </JasperConfig> $xml = xmlwriter_output_memory($memory, true); $jasper_info = array('config' => $GLOBALS['phpgw_info']['server']['temp_dir'] . '/' . uniqid('config_') . "{$base_name}.xml", 'report_name' => $report_name); $fp = fopen($jasper_info['config'], "wb"); fwrite($fp, $xml); if (!fclose($fp)) { throw new Exception('jasper_wrapper::create_jasper_config did not write any config file'); } return $jasper_info; }
function FirstContact() { global $db, $xmlout; $db->init_log(1); $time = localtime(time(), true); $VerifyID = $time['tm_min'] + $time['tm_sec']; $RecordID = $db->add_usage_record($VerifyID); $memory = xmlwriter_open_memory(); xmlwriter_start_document($memory, '1.0', 'UTF-8'); xmlwriter_write_dtd($memory, "AWB"); xmlwriter_start_element($memory, "DB"); xmlwriter_write_attribute($memory, "Record", $RecordID); xmlwriter_write_attribute($memory, "Verify", $VerifyID); xmlwriter_end_element($memory); $xmlout = xmlwriter_output_memory($memory, true); }
<?php dl('xmlwriter.so'); $xw = xmlwriter_open_memory(); xmlwriter_set_indent($xw, 1); $res = xmlwriter_set_indent_string($xw, ' '); xmlwriter_start_document($xw, '1.0', 'UTF-8'); // A first element xmlwriter_start_element_ns($xw, 'prefix', 'books', 'uri'); xmlwriter_start_attribute($xw, 'isbn'); /* Uncomment this line if you have libxml 2.6.17 or CVS version after 2005/02/22 earlier versions segfault */ /* xmlwriter_start_attribute_ns($xw, 'prefix', 'isbn', 'uri'); xmlwriter_end_attribute($xw); */ xmlwriter_end_attribute($xw); xmlwriter_text($xw, 'book1'); xmlwriter_end_element($xw); xmlwriter_end_document($xw); $out = xmlwriter_output_memory($xw, 0); echo $out;
/** * We want to check that we get the expected structure from * xmlwriter & an idea of how it works, once we have this * down we can start working on the actual methods needed * to authenticate. * */ function testXMLWriterCanCreateOurNeededXML() { $xml = xmlwriter_open_memory(); xmlwriter_start_element($xml, 'Authentication'); xmlwriter_write_element($xml, 'client', 'blah'); xmlwriter_write_element($xml, 'password', 'blah'); xmlwriter_end_element($xml); $result = xmlwriter_output_memory($xml, true); $expected = '<Authentication><client>blah</client><password>blah</password></Authentication>'; $this->assertContains('Authentication', $result); $this->assertXmlStringEqualsXmlString($expected, $result); }
/** * @brief Generate an RSS feed * @param string $link * @param string $content */ public static function generaterss($link, $content) { $writer = xmlwriter_open_memory(); xmlwriter_set_indent($writer, 4); xmlwriter_start_document($writer, '1.0', 'utf-8'); xmlwriter_start_element($writer, 'rss'); xmlwriter_write_attribute($writer, 'version', '2.0'); xmlwriter_write_attribute($writer, 'xmlns:atom', 'http://www.w3.org/2005/Atom'); xmlwriter_start_element($writer, 'channel'); xmlwriter_write_element($writer, 'title', 'my ownCloud'); xmlwriter_write_element($writer, 'language', 'en-us'); xmlwriter_write_element($writer, 'link', $link); xmlwriter_write_element($writer, 'description', 'A personal ownCloud activities'); xmlwriter_write_element($writer, 'pubDate', date('r')); xmlwriter_write_element($writer, 'lastBuildDate', date('r')); xmlwriter_start_element($writer, 'atom:link'); xmlwriter_write_attribute($writer, 'href', $link); xmlwriter_write_attribute($writer, 'rel', 'self'); xmlwriter_write_attribute($writer, 'type', 'application/rss+xml'); xmlwriter_end_element($writer); // items for ($i = 0; $i < count($content); $i++) { xmlwriter_start_element($writer, 'item'); if (isset($content[$i]['subject'])) { xmlwriter_write_element($writer, 'title', $content[$i]['subject']); } if (isset($content[$i]['link'])) { xmlwriter_write_element($writer, 'link', $content[$i]['link']); } if (isset($content[$i]['link'])) { xmlwriter_write_element($writer, 'guid', $content[$i]['link']); } if (isset($content[$i]['timestamp'])) { xmlwriter_write_element($writer, 'pubDate', date('r', $content[$i]['timestamp'])); } if (isset($content[$i]['message'])) { xmlwriter_start_element($writer, 'description'); xmlwriter_start_cdata($writer); xmlwriter_text($writer, $content[$i]['message']); xmlwriter_end_cdata($writer); xmlwriter_end_element($writer); } xmlwriter_end_element($writer); } xmlwriter_end_element($writer); xmlwriter_end_element($writer); xmlwriter_end_document($writer); $entry = xmlwriter_output_memory($writer); unset($writer); return $entry; }
public static function toXml($writer, $data, $node) { foreach ($data as $key => $value) { if (is_numeric($key)) { $key = $node; } if (is_array($value)) { xmlwriter_start_element($writer, $key); OC_OCS::toxml($writer, $value, $node); xmlwriter_end_element($writer); } else { xmlwriter_write_element($writer, $key, $value); } } }
/** * Take an array of any size, and make it into xml * @param xmlwriter An xmlwriter instance * @param array The array which is to be transformed * @param mixed Either a string, or an array of elements defining element names for each level in the XML hierarchy * In the case of multiple lists of differently titled items at the same level, adding an array inside the array will allow for this to be constructed. * @param int Internal use (the index of the child item in question - corresponds to the index in the second level array above) */ public function toxml($writer, $data, $node, $childindex = 0) { $nodename = $node; if (is_array($node)) { $nodename = array_shift($node); } $childcount = -1; foreach ($data as $key => $value) { $childcount++; if (is_numeric($key)) { if (is_array($nodename)) { $key = $nodename[$childindex]; } else { $key = $nodename; } } if (is_array($value)) { xmlwriter_start_element($writer, $key); $this->toxml($writer, $value, $node, $childcount); xmlwriter_end_element($writer); } else { xmlwriter_write_element($writer, $key, $value); } } if (is_array($node)) { array_unshift($node, $nodename); } }
/** * Make recursive elements * @param array $data Data */ function dataElement($data, $last_tag) { if (!empty($data)) { foreach ($data as $key => $val) { $last_tag = !is_int($key) ? $key : $last_tag; if ($last_tag != '') { if (is_scalar($val) || is_null($val)) { xmlwriter_start_element($this->xml, $last_tag); $this->xmlwriter_write_cdata($val); xmlwriter_end_element($this->xml); } elseif (is_array($val)) { if (!is_int(key($val))) { xmlwriter_start_element($this->xml, $last_tag); $this->dataElement($val, $last_tag); xmlwriter_end_element($this->xml); } else { $this->dataElement($val, $last_tag); } } } } } }
<?php $file = dirname(__FILE__) . '/010.tmp'; $xw = xmlwriter_open_uri($file); var_dump(xmlwriter_start_element($xw, "tag")); var_dump(xmlwriter_start_attribute($xw, "attr")); var_dump(xmlwriter_end_attribute($xw)); var_dump(xmlwriter_start_attribute($xw, "-1")); var_dump(xmlwriter_end_attribute($xw)); var_dump(xmlwriter_start_attribute($xw, "\"")); var_dump(xmlwriter_end_attribute($xw)); var_dump(xmlwriter_end_element($xw)); unset($xw); var_dump(file_get_contents($file)); @unlink($file); echo "Done\n";
protected function get_xmldata($id = 0, $current_value) { $this->db =& $GLOBALS['phpgw']->db; $id = (int) $id; $sql = "SELECT * FROM fm_entity_1_11 WHERE id = {$id}"; $this->db->query($sql, __LINE__, __FILE__); $anlegg = array(); $TreeID = $this->type; $PeriodFrom = date('Ym'); if ($current_value) { $PeriodTo = 209912; } else { $PeriodTo = '000000'; } $memory = xmlwriter_open_memory(); xmlwriter_set_indent($memory, true); xmlwriter_start_document($memory, '1.0', 'UTF-8'); xmlwriter_start_element($memory, 'TreeListe'); xmlwriter_write_attribute($memory, 'TreeID', $TreeID); xmlwriter_write_attribute($memory, 'xmlns:xsi', 'http://www.w3.org/2001/XMLSchema-instance'); xmlwriter_write_attribute($memory, 'xsi:noNamespaceSchemaLocation', 'TreeListe.xsd'); while ($this->db->next_record()) { xmlwriter_start_element($memory, 'Tree'); xmlwriter_write_element($memory, 'ID', 'TJ'); xmlwriter_write_element($memory, 'Verdi', substr($this->db->f('maalepunkt_id'), -8)); xmlwriter_write_element($memory, 'Beskrivelse', $this->db->f('address')); xmlwriter_write_element($memory, 'Firma', 'BB'); xmlwriter_write_element($memory, 'PeriodeFra', $PeriodFrom); xmlwriter_write_element($memory, 'PeriodeTil', $PeriodTo); xmlwriter_write_element($memory, 'Status', 'N'); xmlwriter_start_element($memory, 'BegrepsLister'); xmlwriter_start_element($memory, 'BegrepsListe'); xmlwriter_write_attribute($memory, 'Prosent', 100); xmlwriter_start_element($memory, 'Begrep'); xmlwriter_write_comment($memory, 'Firma'); xmlwriter_write_element($memory, 'ID', 'A3'); xmlwriter_write_element($memory, 'Verdi', 'BB'); xmlwriter_end_element($memory); xmlwriter_start_element($memory, 'Begrep'); xmlwriter_write_comment($memory, 'Art'); xmlwriter_write_element($memory, 'ID', 'A0'); xmlwriter_write_element($memory, 'Verdi', '12304121'); xmlwriter_end_element($memory); xmlwriter_start_element($memory, 'Begrep'); xmlwriter_write_comment($memory, 'Asvar'); xmlwriter_write_element($memory, 'ID', 'C1'); xmlwriter_write_element($memory, 'Verdi', 45); xmlwriter_end_element($memory); xmlwriter_start_element($memory, 'Begrep'); xmlwriter_write_comment($memory, 'Tjeneste'); xmlwriter_write_element($memory, 'ID', 'TJE'); xmlwriter_write_element($memory, 'Verdi', ''); xmlwriter_end_element($memory); xmlwriter_start_element($memory, 'Begrep'); xmlwriter_write_comment($memory, 'Objekt'); xmlwriter_write_element($memory, 'ID', 'F0'); xmlwriter_write_element($memory, 'Verdi', $this->db->f('loc1')); xmlwriter_end_element($memory); xmlwriter_start_element($memory, 'Begrep'); xmlwriter_write_comment($memory, 'Prosjekt'); xmlwriter_write_element($memory, 'ID', 'B0'); xmlwriter_write_element($memory, 'Verdi', ''); xmlwriter_end_element($memory); xmlwriter_start_element($memory, 'Begrep'); xmlwriter_write_comment($memory, 'Fagkode'); xmlwriter_write_element($memory, 'ID', 'B1'); xmlwriter_write_element($memory, 'Verdi', '999'); xmlwriter_end_element($memory); xmlwriter_start_element($memory, 'Begrep'); xmlwriter_write_comment($memory, 'AV'); xmlwriter_write_element($memory, 'ID', 'AV'); xmlwriter_write_element($memory, 'Verdi', ''); xmlwriter_end_element($memory); xmlwriter_end_element($memory); xmlwriter_end_element($memory); xmlwriter_end_element($memory); } xmlwriter_end_element($memory); $xml = xmlwriter_output_memory($memory, true); if ($this->debug) { header('Content-type: text/xml'); echo $xml; die; } return $xml; }
/** * Sets our 3DSecure request to confirm the transaction. * * @param string $pares * @param string $reference * @param string $method * @return SimpleXML * */ function set3DSecureAuthRequest($pares, $reference, $method = 'deposits') { if (is_null($pares) || empty($pares)) { throw new Zend_Exception('PaRes is not set'); } if (strlen($reference) !== 16) { throw new Zend_Exception('Reference must be 16 characters long'); } $xml = xmlwriter_open_memory(); xmlwriter_start_element($xml, 'Request'); $auth = $this->_handleAuth($method); xmlwriter_write_raw($xml, $auth); xmlwriter_start_element($xml, 'Transaction'); xmlwriter_start_element($xml, 'HistoricTxn'); xmlwriter_write_element($xml, 'reference', $reference); xmlwriter_start_element($xml, 'method'); xmlwriter_write_attribute($xml, 'tx_status_u', 'accept'); xmlwriter_write_raw($xml, 'threedsecure_authorization_request'); xmlwriter_end_element($xml); xmlwriter_write_element($xml, 'pares_message', $pares); xmlwriter_end_element($xml); xmlwriter_end_element($xml); xmlwriter_end_element($xml); return xmlwriter_output_memory($xml, true); }
<?php $writer = xmlwriter_open_memory(); xmlwriter_set_indent_string($writer, '#'); // The second arg is supposedly required. But just keep executing anyway and use // the previous value... xmlwriter_set_indent_string($writer); xmlwriter_set_indent($writer, true); xmlwriter_start_document($writer, '1.0'); xmlwriter_start_element($writer, 'foo'); xmlwriter_start_element($writer, 'bar'); xmlwriter_end_element($writer); xmlwriter_end_element($writer); xmlwriter_end_document($writer); var_dump(xmlwriter_output_memory($writer));
VERIFY(xmlwriter_start_element_ns($xml, "fb", "node", "http://www.facebook.com/")); VERIFY(xmlwriter_write_attribute_ns($xml, "fb", "attr", "http://www.facebook.com/", "value")); VERIFY(xmlwriter_start_attribute_ns($xml, "fb", "attr2", "http://www.facebook.com/")); VERIFY(xmlwriter_end_attribute($xml)); VERIFY(xmlwriter_write_element_ns($xml, "prefix", "name", "http://some.url/", 1337)); VERIFY(xmlwriter_start_element($xml, "node")); VERIFY(xmlwriter_full_end_element($xml)); VERIFY(xmlwriter_end_element($xml)); VERIFY(xmlwriter_start_element($xml, "node")); VERIFY(xmlwriter_start_cdata($xml)); VERIFY(xmlwriter_text($xml, "Raw text")); VERIFY(xmlwriter_end_cdata($xml)); VERIFY(xmlwriter_end_element($xml)); VERIFY(xmlwriter_start_element($xml, "node")); VERIFY(xmlwriter_write_cdata($xml, "More CDATA")); VERIFY(xmlwriter_end_element($xml)); VERIFY(xmlwriter_start_comment($xml)); VERIFY(xmlwriter_text($xml, "Comments")); VERIFY(xmlwriter_end_comment($xml)); VERIFY(xmlwriter_write_comment($xml, "More comments")); VERIFY(xmlwriter_start_pi($xml, "lol")); VERIFY(xmlwriter_end_pi($xml)); VERIFY(xmlwriter_write_pi($xml, "php", "print 'Hello world!';")); VERIFY(xmlwriter_write_raw($xml, "<node>Raw XML</node>")); VERIFY(xmlwriter_write_dtd($xml, "name", "publicID", "systemID", "subset")); VERIFY(xmlwriter_start_dtd($xml, "name", "publicID", "systemID")); VERIFY(xmlwriter_end_dtd($xml)); VERIFY(xmlwriter_start_dtd_element($xml, "name")); VERIFY(xmlwriter_end_dtd_element($xml)); VERIFY(xmlwriter_write_dtd_element($xml, "name", "content")); VERIFY(xmlwriter_start_dtd_attlist($xml, "name"));
/** * Renders an xml_element structure to XMLWriter memory. This * basically acts as a wrapper for api_xml2_render_object, first * parsing through xml_element layers and then calling api_xml2_render_object * to actually render the objects and arrays found. * * @param $xml_memory the xmlwriter memory to use (created with xmlwriter_open_memory()) * @param $object the xml_element to be rendered */ function api_xml3_render_object($xml_memory, $object) { if (is_array($object->value) && isset($object->value[0]) && $object->value[0] instanceof xml_element) { xmlwriter_start_element($xml_memory, $object->name); if (isset($object->attrs)) { foreach ($object->attrs as $k => $v) { xmlwriter_write_attribute($xml_memory, $k, $v); } } foreach ($object->value as $elem) { api_xml3_render_object($xml_memory, $elem); } xmlwriter_end_element($xml_memory); } else { api_xml2_render_object($xml_memory, $object->name, $object->value, $object->attrs); } }