| 
<?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());
 }
 }
 }
 ?>
 
 |