<?php
/*
* Phramework Copyright (C) 2005 GodsArmor.com
*
* This library is free software; you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License as published by the Free
* Software Foundation; either version 2.1 of the License, or (at your option) any
* later version.
*
* This library is distributed in the hope that it will be useful, but WITHOUT ANY
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
* PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License along
* with this library; if not, write to theFree Software Foundation, Inc.,
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
/**
* This class requires no parameters but does require that the data sent into
* this class has the following key/value pairs
* <ul>
* <li>xml: (required) The XML data in string format.</li>
* <li>params: (optional) An array of key/value pairs that coorespond to
* parameters that should be passed into the XSL stylesheet.</li>
* </ul>
* This class also requires that CURL and an XSLT processor is compiled into PHP.
*/
class XsltPlugin extends ViewPlugin {
function XsltPlugin() {
// Nothing to set up here
}
function init($params) {
// No parameters required
}
function destroy() {
// Nothing to destroy
}
function processView($viewValue, $data) {
$xml = $data['xml'];
$params = null;
if (isset($data['params'])) {
$params = $data['params'];
}
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $viewValue);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
$xsl = curl_exec($ch);
curl_close($ch);
$xslt=new Xslt();
$xslt->setXmlString($xml);
$xslt->setXslString($xsl);
if (isset($params) && is_array($params)) {
$xslt->addParameters($params);
}
if($xslt->transform()) {
$ret=$xslt->getOutput();
echo $ret;
} else {
echo("Error:".$xslt->getError());
}
}
}
?>
|