Source for file jWSDL.class.php

Documentation is available at jWSDL.class.php

  1. <?php
  2. /**
  3. @package     jelix
  4. @subpackage  utils
  5. @author      Sylvain de Vathaire
  6. @contributor Laurent Jouanneau
  7. @copyright   2008 Sylvain de Vathaire, 2009-2011 Laurent Jouanneau
  8. @link        http://www.jelix.org
  9. @licence     GNU Lesser General Public Licence see LICENCE file or http://www.gnu.org/licenses/lgpl.html
  10. */
  11.  
  12.  
  13. require_once(LIB_PATH.'wshelper/WSDLStruct.class.php');
  14. require_once(LIB_PATH.'wshelper/WSDLException.class.php');
  15. require_once(LIB_PATH.'wshelper/WSException.class.php');
  16. require_once(LIB_PATH.'wshelper/IPXMLSchema.class.php');
  17. require_once(LIB_PATH.'wshelper/IPPhpDoc.class.php');
  18. require_once(LIB_PATH.'wshelper/IPReflectionClass.class.php');
  19. require_once(LIB_PATH.'wshelper/IPReflectionCommentParser.class.php');
  20. require_once(LIB_PATH.'wshelper/IPReflectionMethod.class.php');
  21. require_once(LIB_PATH.'wshelper/IPReflectionProperty.class.php');
  22.  
  23.  
  24.  
  25. /**
  26.  * object to generate WSDL files and web services documentation
  27.  * we have 1 WSDL file for each soap web service, each service is implemented by 1 Jelix controller
  28.  * @package    jelix
  29.  * @subpackage utils
  30.  */
  31. class jWSDL {
  32.  
  33.     /**
  34.     * module name
  35.     */
  36.     public $module;
  37.  
  38.     /**
  39.     * controller name
  40.     */
  41.     public $controller;
  42.  
  43.     /**
  44.     * controller class name
  45.     */
  46.     private $controllerClassName;
  47.  
  48.     /**
  49.     * WSDL file path (cached file)
  50.     */
  51.     public $WSDLfilePath;
  52.  
  53.  
  54.     private $_ctrlpath;
  55.  
  56.     private $_dirname 'WSDL';
  57.     private $_cacheSuffix '.wsdl';
  58.  
  59.  
  60.     public function __construct($module$controller){
  61.  
  62.         $this->module = $module;
  63.         $this->controller = $controller;
  64.  
  65.         $this->_createPath();
  66.         $this->_createCachePath();
  67.      }
  68.  
  69.     /**
  70.      * create the path for the cache file
  71.      */
  72.     private function _createPath(){
  73.         global $gJConfig;
  74.  
  75.         //Check module availability
  76.         if(!isset($gJConfig->_modulesPathList[$this->module])){
  77.             throw new jExceptionSelector('jelix~errors.module.unknown'$this->module);
  78.         }
  79.  
  80.         //Build controller path
  81.         $this->_ctrlpath $gJConfig->_modulesPathList[$this->module].'controllers/'.$this->controller.'.soap.php';
  82.  
  83.         //Check controller availability
  84.         if(!file_exists($this->_ctrlpath)){
  85.             throw new jException('jelix~errors.action.unknown',$this->controller);
  86.         }
  87.  
  88.         //Check controller declaration
  89.         require_once($this->_ctrlpath);
  90.         $this->controllerClassName $this->controller.'Ctrl';
  91.         if(!class_exists($this->controllerClassName,false)){
  92.             throw new jException('jelix~errors.ad.controller.class.unknown'array('jWSDL'$this->controllerClassName$this->_ctrlpath));
  93.         }
  94.  
  95.         //Check eAccelerator configuration in order to Reflexion API work
  96.         if (extension_loaded('eAccelerator')) {
  97.             $reflect new ReflectionClass('jWSDL');
  98.             if($reflect->getDocComment(== NULL{
  99.                 throw new jException('jWSDL~errors.eaccelerator.configuration');
  100.             }
  101.             unset($reflect);
  102.         }
  103.  
  104.     }
  105.  
  106.     /**
  107.      * Build the WSDL cache file path
  108.      */
  109.     private function _createCachePath(){
  110.         $this->_cachePath JELIX_APP_TEMP_PATH.'compiled/'.$this->_dirname.'/'.$this->module.'~'.$this->controller.$this->_cacheSuffix;
  111.     }
  112.  
  113.     /**
  114.      * Return the WSDL cache file path (WSDL is updated if necessary)
  115.      */
  116.     public function getWSDLFilePath(){
  117.         $this->_updateWSDL();
  118.         return $this->_cachePath;
  119.     }
  120.  
  121.     /**
  122.      * Return the WSDL file content (WSDL is updated if necessary)
  123.      */
  124.     public function getWSDLFile(){
  125.         $this->_updateWSDL();
  126.         return file_get_contents($this->_cachePath);
  127.     }
  128.  
  129.     /**
  130.      * Return array of params object for the operation $operationName
  131.      * @param string $operationName Name of the operation (controller method)
  132.      * @return array list params object (empty if no params)
  133.      */
  134.     public function getOperationParams($operationName){
  135.  
  136.        $IPReflectionMethod new IPReflectionMethod($this->controllerClassName$operationName);
  137.        return $IPReflectionMethod->parameters;
  138.     }
  139.  
  140.     /**
  141.      * Update the WSDL cache file
  142.      */
  143.     private function _updateWSDL(){
  144.  
  145.         global $gJConfig;
  146.         static $updated FALSE;
  147.  
  148.         if($updated){
  149.             return;
  150.         }
  151.  
  152.         $mustCompile $gJConfig->compilation['force'|| !file_exists($this->_cachePath);
  153.         if($gJConfig->compilation['checkCacheFiletime'&& !$mustCompile){
  154.             iffilemtime($this->_ctrlpathfilemtime($this->_cachePath)){
  155.                 $mustCompile true;
  156.             }
  157.         }
  158.  
  159.         if($mustCompile){
  160.             jFile::write($this->_cachePath$this->_compile());
  161.         }
  162.         $updated TRUE;
  163.     }
  164.  
  165.     /**
  166.      * Generate the WSDL content
  167.      */
  168.     private function _compile(){
  169.  
  170.         global $gJConfig$gJCoord;
  171.         
  172.         $url jUrl::get($this->module.'~'.$this->controller.':index@soap',array(),jUrl::JURL);
  173.         $url->clearParam ();
  174.         $url->setParam('service',$this->module.'~'.$this->controller );
  175.  
  176.         $serviceURL $serviceNameSpace $gJCoord->request->getServerURI();
  177.  
  178.         $serviceURL .= $url->toString();
  179.         $serviceNameSpace .= $gJConfig->urlengine['basePath'];
  180.  
  181.         $wsdl new WSDLStruct($serviceNameSpace$serviceURLSOAP_RPCSOAP_ENCODED);
  182.         $wsdl->setService(new IPReflectionClass($this->controllerClassName));
  183.  
  184.         try {
  185.             $gendoc $wsdl->generateDocument();
  186.         catch (WSDLException $exception{
  187.             throw new JException('jWSDL~errors.wsdl.generation'$exception->msg);
  188.         }
  189.  
  190.         return $gendoc;
  191.     }
  192.  
  193.     /**
  194.      * Load the class or service definition for doc purpose
  195.      * @param string $classname Name of the class for witch we want the doc, default doc is the service one (controller)
  196.      */
  197.     public function doc($className=""){
  198.  
  199.         if($className != ""){
  200.             if(!class_exists($className,false)){
  201.                 throw new jException('jelix~errors.ad.controller.class.unknown'array('WSDL generation'$className$this->_ctrlpath));
  202.             }
  203.             $classObject new IPReflectionClass($className);
  204.         }else{
  205.             $classObject new IPReflectionClass($this->controllerClassName);
  206.         }
  207.  
  208.         $documentation Array();
  209.         $documentation['menu'Array();
  210.  
  211.         if($classObject){
  212.             $classObject->properties $classObject->getProperties(falsefalsefalse);
  213.             $classObject->methods $classObject->getMethods(falsefalsefalse);
  214.             foreach((array)$classObject->methods as $method{
  215.                 $method->params $method->getParameters();
  216.             }
  217.  
  218.             $documentation['class'$classObject;
  219.             $documentation['service'$this->module.'~'.$this->controller;
  220.         }
  221.         return $documentation;
  222.     }
  223.  
  224.     /**
  225.      * Return an array of all the soap controllers class available in the application
  226.      * @return array Classname of controllers
  227.      */
  228.     public static function getSoapControllers(){
  229.  
  230.         global $gJConfig;
  231.  
  232.         $modules $gJConfig->_modulesPathList;
  233.         $controllers array();
  234.  
  235.         foreach($modules as $module){
  236.             if(is_dir($module.'controllers')){
  237.                 if ($handle opendir($module.'controllers')) {
  238.                     $moduleName basename($module);
  239.                     while (false !== ($file readdir($handle))) {
  240.                         if (substr($filestrlen($filestrlen('.soap.php')) == '.soap.php'{
  241.                             $controller array();
  242.                             $controller['class'substr($file0strlen($filestrlen('.soap.php'));
  243.                             $controller['module'$moduleName;
  244.                             $controller['service'$moduleName.'~'.$controller['class'];
  245.                             array_push($controllers$controller);
  246.                         }
  247.                     }
  248.                     closedir($handle);
  249.                 }
  250.             }
  251.         }
  252.         return $controllers;
  253.     }
  254. }

Documentation generated on Thu, 19 Sep 2013 00:08:02 +0200 by phpDocumentor 1.4.3