Merge remote-tracking branch 'origin/master' into client
This commit is contained in:
commit
ec3866d5d1
|
@ -31,3 +31,59 @@ Controller
|
||||||
return $this->container->get('besimple.soap.response')->setReturnValue("Hello ".implode(', ', $names));
|
return $this->container->get('besimple.soap.response')->setReturnValue("Hello ".implode(', ', $names));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Global header
|
||||||
|
-------------
|
||||||
|
|
||||||
|
If you want use a header for all actions of your controller you can declare the header like this:
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
|
||||||
|
namespace My\App\Controller;
|
||||||
|
|
||||||
|
use BeSimple\SoapBundle\ServiceDefinition\Annotation as Soap;
|
||||||
|
use Symfony\Component\DependencyInjection\ContainerAware;
|
||||||
|
use Symfony\Component\DependencyInjection\ContainerInterface;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Soap\Header("api_key", phpType = "string")
|
||||||
|
*/
|
||||||
|
class DemoController extends ContainerAware
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @Soap\Method("hello")
|
||||||
|
* @Soap\Param("names", phpType = "string[]")
|
||||||
|
* @Soap\Result(phpType = "string")
|
||||||
|
*/
|
||||||
|
public function helloAction(array $names)
|
||||||
|
{
|
||||||
|
return $this->container->get('besimple.soap.response')->setReturnValue("Hello ".implode(', ', $names));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Soap\Method("welcome")
|
||||||
|
* @Soap\Param("names", phpType = "string[]")
|
||||||
|
* @Soap\Result(phpType = "string")
|
||||||
|
*/
|
||||||
|
public function welcomeAction()
|
||||||
|
{
|
||||||
|
return $this->container->get('besimple.soap.response')->setReturnValue("Welcome ".implode(', ', $names));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setContainer(ContainerInterface $container = null)
|
||||||
|
{
|
||||||
|
parent::setContainer($container);
|
||||||
|
|
||||||
|
$this->checkApiKeyHeader();
|
||||||
|
}
|
||||||
|
|
||||||
|
private function checkApiKeyHeader()
|
||||||
|
{
|
||||||
|
$soapHeaders = $this->container->get('request')->getSoapHeaders();
|
||||||
|
|
||||||
|
// You can use '1234' !== (string) $soapHeaders->get('api_key')
|
||||||
|
if (!$soapHeaders->has('api_key') || '1234' !== $soapHeaders->get('api_key')->getData()) {
|
||||||
|
throw new \SoapFault("INVALID_API_KEY", "The api_key is invalid.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -67,17 +67,12 @@ class RpcLiteralResponseMessageBinder implements MessageBinderInterface
|
||||||
|
|
||||||
$this->messageRefs[$hash] = $message;
|
$this->messageRefs[$hash] = $message;
|
||||||
|
|
||||||
$class = $phpType;
|
if (!$message instanceof $phpType) {
|
||||||
if ($class[0] == '\\') {
|
throw new \InvalidArgumentException(sprintf('The instance class must be "%s", "%s" given.', get_class($message), $phpType));
|
||||||
$class = substr($class, 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$message instanceof $class) {
|
|
||||||
throw new \InvalidArgumentException(sprintf('The instance class must be "%s", "%s" given.', get_class($message), $class));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$r = new \ReflectionClass($message);
|
$r = new \ReflectionClass($message);
|
||||||
foreach ($this->definitionComplexTypes[$class] as $type) {
|
foreach ($this->definitionComplexTypes[$phpType] as $type) {
|
||||||
$p = $r->getProperty($type->getName());
|
$p = $r->getProperty($type->getName());
|
||||||
if ($p->isPublic()) {
|
if ($p->isPublic()) {
|
||||||
$value = $message->{$type->getName()};
|
$value = $message->{$type->getName()};
|
||||||
|
@ -91,7 +86,7 @@ class RpcLiteralResponseMessageBinder implements MessageBinderInterface
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$type->isNillable() && null === $value) {
|
if (!$type->isNillable() && null === $value) {
|
||||||
throw new \InvalidArgumentException(sprintf('"%s::%s" cannot be null.', $class, $type->getName()));
|
throw new \InvalidArgumentException(sprintf('"%s::%s" cannot be null.', $phpType, $type->getName()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -58,15 +58,29 @@ class AnnotationClassLoader implements LoaderInterface
|
||||||
$class = new \ReflectionClass($class);
|
$class = new \ReflectionClass($class);
|
||||||
$definition = new Definition\ServiceDefinition();
|
$definition = new Definition\ServiceDefinition();
|
||||||
|
|
||||||
|
$serviceMethodHeaders = array();
|
||||||
|
foreach ($this->reader->getClassAnnotations($class) as $annotation) {
|
||||||
|
if ($annotation instanceof Annotation\Header) {
|
||||||
|
$serviceMethodHeaders[$annotation->getValue()] = $annotation;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
foreach ($class->getMethods() as $method) {
|
foreach ($class->getMethods() as $method) {
|
||||||
$serviceArguments =
|
$serviceArguments =
|
||||||
$serviceHeaders = array();
|
$serviceHeaders = array();
|
||||||
$serviceMethod =
|
$serviceMethod =
|
||||||
$serviceReturn = null;
|
$serviceReturn = null;
|
||||||
|
|
||||||
foreach ($this->reader->getMethodAnnotations($method) as $i => $annotation) {
|
foreach ($serviceMethodHeaders as $annotation) {
|
||||||
|
$serviceHeaders[$annotation->getValue()] = new Definition\Header(
|
||||||
|
$annotation->getValue(),
|
||||||
|
$this->getArgumentType($method, $annotation)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($this->reader->getMethodAnnotations($method) as $annotation) {
|
||||||
if ($annotation instanceof Annotation\Header) {
|
if ($annotation instanceof Annotation\Header) {
|
||||||
$serviceHeaders[] = new Definition\Header(
|
$serviceHeaders[$annotation->getValue()] = new Definition\Header(
|
||||||
$annotation->getValue(),
|
$annotation->getValue(),
|
||||||
$this->getArgumentType($method, $annotation)
|
$this->getArgumentType($method, $annotation)
|
||||||
);
|
);
|
||||||
|
|
|
@ -30,6 +30,11 @@ class Type
|
||||||
|
|
||||||
public function setPhpType($phpType)
|
public function setPhpType($phpType)
|
||||||
{
|
{
|
||||||
|
$phpType = $phpType;
|
||||||
|
if ($phpType[0] == '\\') {
|
||||||
|
$phpType = substr($phpType, 1);
|
||||||
|
}
|
||||||
|
|
||||||
$this->phpType = $phpType;
|
$this->phpType = $phpType;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -136,7 +136,7 @@ class RpcLiteralRequestMessageBinderTest extends \PHPUnit_Framework_TestCase
|
||||||
|
|
||||||
$foo = new Fixtures\FooRecursive('foo', '');
|
$foo = new Fixtures\FooRecursive('foo', '');
|
||||||
$bar = new Fixtures\BarRecursive($foo, 10394);
|
$bar = new Fixtures\BarRecursive($foo, 10394);
|
||||||
$foo->setBar($bar);
|
$foo->bar = $bar;
|
||||||
|
|
||||||
$result = $messageBinder->processMessage(
|
$result = $messageBinder->processMessage(
|
||||||
new Definition\Method('prevent_infinite_recursion', null, array(), array(
|
new Definition\Method('prevent_infinite_recursion', null, array(), array(
|
||||||
|
|
|
@ -1,227 +0,0 @@
|
||||||
<?php
|
|
||||||
/*
|
|
||||||
* This file is part of the BeSimpleSoapBundle.
|
|
||||||
*
|
|
||||||
* (c) Christian Kerl <christian-kerl@web.de>
|
|
||||||
*
|
|
||||||
* This source file is subject to the MIT license that is bundled
|
|
||||||
* with this source code in the file LICENSE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
namespace BeSimple\SoapBundle\Tests\ServiceBinding;
|
|
||||||
|
|
||||||
use BeSimple\SoapBundle\ServiceDefinition\Method;
|
|
||||||
use BeSimple\SoapBundle\ServiceDefinition\Type;
|
|
||||||
use BeSimple\SoapBundle\ServiceDefinition\Strategy\PropertyComplexType;
|
|
||||||
use BeSimple\SoapBundle\ServiceDefinition\Strategy\MethodComplexType;
|
|
||||||
use BeSimple\SoapBundle\ServiceBinding\RpcLiteralResponseMessageBinder;
|
|
||||||
use BeSimple\SoapBundle\Util\Collection;
|
|
||||||
use BeSimple\SoapBundle\Tests\ServiceBinding\fixtures\Attributes;
|
|
||||||
use BeSimple\SoapBundle\Tests\ServiceBinding\fixtures\ComplexType;
|
|
||||||
use BeSimple\SoapBundle\Tests\ServiceBinding\fixtures\Setters;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* UnitTest for \BeSimple\SoapBundle\ServiceBinding\RpcLiteralRequestMessageBinder.
|
|
||||||
*
|
|
||||||
* @author Francis Besset <francis.besset@gmail.com>
|
|
||||||
*/
|
|
||||||
class RpcLiteralResponseMessageBinderTest extends \PHPUnit_Framework_TestCase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* @dataProvider messageProvider
|
|
||||||
*/
|
|
||||||
public function testProcessMessage(Method $method, $message, $assert)
|
|
||||||
{
|
|
||||||
$messageBinder = new RpcLiteralResponseMessageBinder();
|
|
||||||
$result = $messageBinder->processMessage($method, $message);
|
|
||||||
|
|
||||||
$this->assertSame($assert, $result);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testProcessMessageWithComplexType()
|
|
||||||
{
|
|
||||||
$definitionComplexTypes = $this->getDefinitionComplexTypes();
|
|
||||||
|
|
||||||
$attributes = new Attributes();
|
|
||||||
$attributes->foo = 'foobar';
|
|
||||||
$attributes->bar = 20349;
|
|
||||||
$messageBinder = new RpcLiteralResponseMessageBinder();
|
|
||||||
$result = $messageBinder->processMessage(
|
|
||||||
new Method('complextype', null, array(), array(), new Type('\BeSimple\SoapBundle\Tests\ServiceBinding\fixtures\Attributes')),
|
|
||||||
$attributes,
|
|
||||||
$definitionComplexTypes
|
|
||||||
);
|
|
||||||
|
|
||||||
$this->assertInstanceOf('stdClass', $result);
|
|
||||||
$this->assertSame('foobar', $result->foo);
|
|
||||||
$this->assertSame(20349, $result->bar);
|
|
||||||
|
|
||||||
$attributes1 = new Attributes();
|
|
||||||
$attributes1->foo = 'bar';
|
|
||||||
$attributes1->bar = 2929;
|
|
||||||
$attributes2 = new Attributes();
|
|
||||||
$attributes2->foo = 'foo';
|
|
||||||
$attributes2->bar = 123992;
|
|
||||||
$message = array($attributes1, $attributes2);
|
|
||||||
$messageBinder = new RpcLiteralResponseMessageBinder();
|
|
||||||
$result = $messageBinder->processMessage(
|
|
||||||
new Method('complextype_argument', null, array(), array(), new Type('\BeSimple\SoapBundle\Tests\ServiceBinding\fixtures\Attributes[]')),
|
|
||||||
$message,
|
|
||||||
$definitionComplexTypes
|
|
||||||
);
|
|
||||||
|
|
||||||
$this->assertTrue(is_array($result));
|
|
||||||
|
|
||||||
$this->assertInstanceOf('stdClass', $result[0]);
|
|
||||||
$this->assertSame('bar', $result[0]->foo);
|
|
||||||
$this->assertSame(2929, $result[0]->bar);
|
|
||||||
|
|
||||||
$this->assertInstanceOf('stdClass', $result[1]);
|
|
||||||
$this->assertSame('foo', $result[1]->foo);
|
|
||||||
$this->assertSame(123992, $result[1]->bar);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testProcessMessageWithComplexTypeMethods()
|
|
||||||
{
|
|
||||||
$setters = new Setters();
|
|
||||||
$setters->setFoo('foobar');
|
|
||||||
$setters->setBar(42);
|
|
||||||
|
|
||||||
$messageBinder = new RpcLiteralResponseMessageBinder();
|
|
||||||
$result = $messageBinder->processMessage(
|
|
||||||
new Method('complextype_methods', null, array(), array(), new Type('\BeSimple\SoapBundle\Tests\ServiceBinding\fixtures\Setters')),
|
|
||||||
$setters,
|
|
||||||
$this->getDefinitionComplexTypes()
|
|
||||||
);
|
|
||||||
|
|
||||||
$this->assertInstanceOf('stdClass', $result);
|
|
||||||
$this->assertSame('foobar', $result->foo);
|
|
||||||
$this->assertSame(42, $result->bar);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testProcessMessageWithComplexTypeIntoComplexType()
|
|
||||||
{
|
|
||||||
$complexType = new ComplexType();
|
|
||||||
|
|
||||||
$foo = new Attributes();
|
|
||||||
$foo->foo = 'Hello world!';
|
|
||||||
$foo->bar = 4242;
|
|
||||||
$complexType->setFoo($foo);
|
|
||||||
|
|
||||||
$bar = new Setters();
|
|
||||||
$bar->setFoo('bar foo');
|
|
||||||
$bar->setBar(2424);
|
|
||||||
$complexType->bar = $bar;
|
|
||||||
|
|
||||||
$messageBinder = new RpcLiteralResponseMessageBinder();
|
|
||||||
$result = $messageBinder->processMessage(
|
|
||||||
new Method('complextype_complextype', null, array(), array(), new Type('\BeSimple\SoapBundle\Tests\ServiceBinding\fixtures\ComplexType')),
|
|
||||||
$complexType,
|
|
||||||
$this->getDefinitionComplexTypes()
|
|
||||||
);
|
|
||||||
|
|
||||||
$this->assertInstanceOf('stdClass', $result);
|
|
||||||
|
|
||||||
$this->assertInstanceOf('stdClass', $result->foo);
|
|
||||||
$this->assertSame('Hello world!', $result->foo->foo);
|
|
||||||
$this->assertSame(4242, $result->foo->bar);
|
|
||||||
|
|
||||||
$this->assertInstanceOf('stdClass', $result->bar);
|
|
||||||
$this->assertSame('bar foo', $result->bar->foo);
|
|
||||||
$this->assertSame(2424, $result->bar->bar);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testProcessMessageWithComplexTypeReferences()
|
|
||||||
{
|
|
||||||
$attributes = new Attributes();
|
|
||||||
$attributes->foo = 'bar';
|
|
||||||
$attributes->bar = 2929;
|
|
||||||
|
|
||||||
$message = array($attributes, $attributes);
|
|
||||||
$messageBinder = new RpcLiteralResponseMessageBinder();
|
|
||||||
$result = $messageBinder->processMessage(
|
|
||||||
new Method('complextype_argument', null, array(), array(), new Type('\BeSimple\SoapBundle\Tests\ServiceBinding\fixtures\Attributes[]')),
|
|
||||||
$message,
|
|
||||||
$this->getDefinitionComplexTypes()
|
|
||||||
);
|
|
||||||
|
|
||||||
$this->assertInstanceOf('stdClass', $result[0]);
|
|
||||||
$this->assertSame($result[0], $result[1]);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function messageProvider()
|
|
||||||
{
|
|
||||||
$messages = array();
|
|
||||||
|
|
||||||
$messages[] = array(
|
|
||||||
new Method('boolean', null, array(), array(), new Type('boolean')),
|
|
||||||
true,
|
|
||||||
true,
|
|
||||||
);
|
|
||||||
|
|
||||||
$messages[] = array(
|
|
||||||
new Method('strings', null, array(), array(), new Type('string[]')),
|
|
||||||
array('hello', 'world'),
|
|
||||||
array('hello', 'world'),
|
|
||||||
);
|
|
||||||
|
|
||||||
return $messages;
|
|
||||||
}
|
|
||||||
|
|
||||||
private function getDefinitionComplexTypes()
|
|
||||||
{
|
|
||||||
$this->definitionComplexTypes = array();
|
|
||||||
|
|
||||||
$this->definitionComplexTypes['\BeSimple\SoapBundle\Tests\ServiceBinding\fixtures\Attributes'] = $this->createPropertiesCollection(array(
|
|
||||||
array('foo', 'string'),
|
|
||||||
array('bar', 'int'),
|
|
||||||
));
|
|
||||||
|
|
||||||
$this->definitionComplexTypes['\BeSimple\SoapBundle\Tests\ServiceBinding\fixtures\Setters'] = $this->createMethodsCollection(array(
|
|
||||||
array('foo', 'string', 'getFoo', 'setFoo'),
|
|
||||||
array('bar', 'int', 'getBar', 'setBar'),
|
|
||||||
));
|
|
||||||
|
|
||||||
$collection = $this->createMethodsCollection(array(
|
|
||||||
array('foo', '\BeSimple\SoapBundle\Tests\ServiceBinding\fixtures\Attributes', 'getFoo', 'setFoo'),
|
|
||||||
));
|
|
||||||
$this->createPropertiesCollection(array(
|
|
||||||
array('bar', '\BeSimple\SoapBundle\Tests\ServiceBinding\fixtures\Setters'),
|
|
||||||
), $collection);
|
|
||||||
$this->definitionComplexTypes['\BeSimple\SoapBundle\Tests\ServiceBinding\fixtures\ComplexType'] = $collection;
|
|
||||||
|
|
||||||
return $this->definitionComplexTypes;
|
|
||||||
}
|
|
||||||
|
|
||||||
private function createPropertiesCollection(array $properties, Collection $collection = null)
|
|
||||||
{
|
|
||||||
$collection = $collection ?: new Collection('getName');
|
|
||||||
|
|
||||||
foreach ($properties as $property) {
|
|
||||||
$collectionProperty = new PropertyComplexType();
|
|
||||||
$collectionProperty->setName($property[0]);
|
|
||||||
$collectionProperty->setValue($property[1]);
|
|
||||||
|
|
||||||
$collection->add($collectionProperty);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $collection;
|
|
||||||
}
|
|
||||||
|
|
||||||
private function createMethodsCollection(array $methods, Collection $collection = null)
|
|
||||||
{
|
|
||||||
$collection = $collection ?: new Collection('getName');
|
|
||||||
|
|
||||||
foreach ($methods as $method) {
|
|
||||||
$collectionMethod = new MethodComplexType();
|
|
||||||
$collectionMethod->setName($method[0]);
|
|
||||||
$collectionMethod->setValue($method[1]);
|
|
||||||
$collectionMethod->setOriginalName($method[2]);
|
|
||||||
$collectionMethod->setSetter($method[3]);
|
|
||||||
|
|
||||||
$collection->add($collectionMethod);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $collection;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -0,0 +1,13 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace BeSimple\SoapBundle\Tests\fixtures\ServiceBinding;
|
||||||
|
|
||||||
|
class BarRecursive
|
||||||
|
{
|
||||||
|
private $foo;
|
||||||
|
|
||||||
|
public function __construct(FooRecursive $foo)
|
||||||
|
{
|
||||||
|
$this->foo = $foo;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,8 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace BeSimple\SoapBundle\Tests\fixtures\ServiceBinding;
|
||||||
|
|
||||||
|
class FooRecursive
|
||||||
|
{
|
||||||
|
public $bar;
|
||||||
|
}
|
Loading…
Reference in New Issue