Ejemplo n.º 1
0
 /**
  * Add a Single or Multiple Functions to the WSDL
  *
  * @param string $function Function Name
  * @param string $namespace Function namespace - Not Used
  */
 public function addFunction($function, $namespace = '')
 {
     static $port;
     static $operation;
     static $binding;
     if (!is_array($function)) {
         $function = (array) $function;
     }
     $uri = $this->getUri();
     if (!$this->_wsdl instanceof Wsdl) {
         $parts = explode('.', basename($_SERVER['SCRIPT_NAME']));
         $name = $parts[0];
         $wsdl = new Wsdl($name, $uri, $this->_strategy);
         // The wsdl:types element must precede all other elements (WS-I Basic Profile 1.1 R2023)
         $wsdl->addSchemaTypeSection();
         $port = $wsdl->addPortType($name . 'Port');
         $binding = $wsdl->addBinding($name . 'Binding', 'tns:' . $name . 'Port');
         $wsdl->addSoapBinding($binding, $this->_bindingStyle['style'], $this->_bindingStyle['transport']);
         $wsdl->addService($name . 'Service', $name . 'Port', 'tns:' . $name . 'Binding', $uri);
     } else {
         $wsdl = $this->_wsdl;
     }
     foreach ($function as $func) {
         $method = $this->_reflection->reflectFunction($func);
         $this->_addFunctionToWsdl($method, $wsdl, $port, $binding);
     }
     $this->_wsdl = $wsdl;
 }
Ejemplo n.º 2
0
 /**
  * Create XML definition on an AMF service class
  *
  * @param  string $serviceClass Service class name
  * @param  array $options invocation options
  * @return string XML with service class introspection
  */
 public function introspect($serviceClass, $options = array())
 {
     $this->_options = $options;
     if (strpbrk($serviceClass, '\\/<>')) {
         return $this->_returnError('Invalid service name');
     }
     // Transform com.foo.Bar into com\foo\Bar
     $serviceClass = str_replace('.', '\\', $serviceClass);
     // Introspect!
     if (!class_exists($serviceClass)) {
         if (!$this->_loadClass($serviceClass)) {
             return $this->_returnError('Invalid service name; class does not exist');
         }
     }
     $serv = $this->_xml->createElement('service-description');
     $serv->setAttribute('xmlns', 'http://ns.adobe.com/flex/service-description/2008');
     $this->_types = $this->_xml->createElement('types');
     $this->_ops = $this->_xml->createElement('operations');
     $r = Reflection::reflectClass($serviceClass);
     $this->_addService($r, $this->_ops);
     $serv->appendChild($this->_types);
     $serv->appendChild($this->_ops);
     $this->_xml->appendChild($serv);
     return $this->_xml->saveXML();
 }
Ejemplo n.º 3
0
 /**
  * Generate the WSDL for a set of functions.
  *
  * @return Zend\Soap\Wsdl
  */
 protected function _generateFunctions()
 {
     $methods = array();
     foreach (array_unique($this->_functions) as $func) {
         $methods[] = $this->_reflection->reflectFunction($func);
     }
     return $this->_generateWsdl($methods);
 }
 protected function loadClassInfo()
 {
     $class_info = Reflection::reflectClass($this);
     $this->namespace = $class_info->getNamespaceName();
     $dir = dirname($class_info->getFileName());
     if (strstr($dir, "src/{$this->namespace}")) {
         $dir = dirname(dirname($dir));
     }
     $this->dir = $dir;
 }
Ejemplo n.º 5
0
 /**
  * Reflect methods in given class and set retrieved data into reader.
  *
  * @param $className
  * @return array
  */
 public function reflectClassMethods($className)
 {
     $data = array('controller' => $className);
     $serverReflection = new Reflection();
     foreach ($serverReflection->reflectClass($className)->getMethods() as $methodReflection) {
         try {
             $method = $this->getMethodNameWithoutVersionSuffix($methodReflection);
         } catch (InvalidArgumentException $e) {
             /** Resources can contain methods that should not be exposed through API. */
             continue;
         }
         $version = $this->getMethodVersion($methodReflection);
         if ($version) {
             $data['versions'][$version]['methods'][$method] = $this->extractMethodData($methodReflection);
         }
     }
     // Sort versions array for further fallback.
     ksort($data['versions']);
     return array('resources' => array($this->_helper->translateResourceName($className) => $data));
 }
Ejemplo n.º 6
0
 /**
  * Register a class with the server
  *
  * @param  string $class
  * @param  string $namespace Ignored
  * @param  mixed $argv Ignored
  * @return Server
  */
 public function setClass($class, $namespace = '', $argv = null)
 {
     if (2 < func_num_args()) {
         $argv = func_get_args();
         $argv = array_slice($argv, 2);
     }
     $reflection = Reflection::reflectClass($class, $argv, $namespace);
     foreach ($reflection->getMethods() as $method) {
         $definition = $this->_buildSignature($method, $class);
         $this->_addMethodServiceMap($definition);
     }
     return $this;
 }
Ejemplo n.º 7
0
 /**
  * Attach class methods as XMLRPC method handlers
  *
  * $class may be either a class name or an object. Reflection is done on the
  * class or object to determine the available public methods, and each is
  * attached to the server as an available method; if a $namespace has been
  * provided, that namespace is used to prefix the XMLRPC method names.
  *
  * Any additional arguments beyond $namespace will be passed to a method at
  * invocation.
  *
  * @param string|object $class
  * @param string $namespace Optional
  * @param mixed $argv Optional arguments to pass to methods
  * @return void
  * @throws Server\Exception\InvalidArgumentException on invalid input
  */
 public function setClass($class, $namespace = '', $argv = null)
 {
     if (is_string($class) && !class_exists($class)) {
         throw new Server\Exception\InvalidArgumentException('Invalid method class', 610);
     }
     if (2 < func_num_args()) {
         $argv = func_get_args();
         $argv = array_slice($argv, 2);
     }
     $dispatchable = Reflection::reflectClass($class, $argv, $namespace);
     foreach ($dispatchable->getMethods() as $reflection) {
         $this->_buildSignature($reflection, $class);
     }
 }
Ejemplo n.º 8
0
 /**
  * reflectFunction() test; test namespaces
  */
 public function testReflectFunction2()
 {
     $reflection = Reflection::reflectFunction('ZendTest\\Server\\reflectionTestFunction', false, 'zsr');
     $this->assertEquals('zsr', $reflection->getNamespace());
 }
Ejemplo n.º 9
0
    /**
     * Attach a function to the server
     *
     * Additional arguments to pass to the function at dispatch may be passed;
     * any arguments following the namespace will be aggregated and passed at
     * dispatch time.
     *
     * @param  string|array $function Valid callback
     * @param  string $namespace Optional namespace prefix
     * @return Server
     * @throws Exception\InvalidArgumentException
     */
    public function addFunction($function, $namespace = '')
    {
        if (!is_string($function) && !is_array($function)) {
            throw new Exception\InvalidArgumentException('Unable to attach function');
        }

        $argv = null;
        if (2 < func_num_args()) {
            $argv = array_slice(func_get_args(), 2);
        }

        $function = (array) $function;
        foreach ($function as $func) {
            if (!is_string($func) || !function_exists($func)) {
                throw new Exception\InvalidArgumentException('Unable to attach function');
            }
            $this->_methods[] = Reflection::reflectFunction($func, $argv, $namespace);
        }

        $this->_buildDispatchTable();
        return $this;
    }
Ejemplo n.º 10
0
 /**
  * (non-PHPdoc).
  *
  * @see \Zend\Json\Server\Server::setClass()
  */
 public function setClass($class, $namespace = '', $argv = null)
 {
     if (2 < func_num_args()) {
         $argv = func_get_args();
         $argv = array_slice($argv, 2);
     }
     $methods = [];
     if (is_array($class)) {
         $methods = $class['methods'];
         $class = $class['class'];
     }
     $obj = $class;
     if ($this->container->has($class)) {
         $obj = $this->container->get($class);
     }
     $reflection = Reflection::reflectClass($obj, $argv, $namespace);
     foreach ($reflection->getMethods() as $method) {
         $docComment = $method->getDocComment();
         if ($docComment !== false && (new DocBlockReflection($docComment))->hasTag('invokable') || in_array($method->getName(), $methods)) {
             $definition = $this->_buildSignature($method, $class);
             $this->addMethodServiceMap($definition);
         }
     }
     return $this;
 }