/** * 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; }
/** * 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(); }
/** * 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; }
/** * 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)); }
/** * 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; }
/** * 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); } }
/** * reflectFunction() test; test namespaces */ public function testReflectFunction2() { $reflection = Reflection::reflectFunction('ZendTest\\Server\\reflectionTestFunction', false, 'zsr'); $this->assertEquals('zsr', $reflection->getNamespace()); }
/** * 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; }
/** * (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; }