Initial commit

This commit is contained in:
Francis Besset
2011-09-03 21:15:51 +02:00
commit fd162d8ca6
7 changed files with 567 additions and 0 deletions

View File

@ -0,0 +1,143 @@
<?php
/*
* This file is part of the BeSimpleSoapBundle.
*
* (c) Christian Kerl <christian-kerl@web.de>
* (c) Francis Besset <francis.besset@gmail.com>
*
* This source file is subject to the MIT license that is bundled
* with this source code in the file LICENSE.
*/
namespace BeSimple\SoapClient\Soap;
/**
* @author Francis Besset <francis.besset@gmail.com>
*/
class SoapClient
{
protected $wsdl;
protected $soapClient;
/**
* @param string $wsdl
* @param array $options
*/
public function __construct($wsdl, array $options = array())
{
$this->wsdl = $wsdl;
$this->setOptions($options);
}
public function setOptions(array $options)
{
$this->options = array(
'cache_dir' => null,
'debug' => false,
);
// check option names and live merge, if errors are encountered Exception will be thrown
$invalid = array();
$isInvalid = false;
foreach ($options as $key => $value) {
if (array_key_exists($key, $this->options)) {
$this->options[$key] = $value;
} else {
$isInvalid = true;
$invalid[] = $key;
}
}
if ($isInvalid) {
throw new \InvalidArgumentException(sprintf(
'The "%s" class does not support the following options: "%s".',
get_class($this),
implode('\', \'', $invalid)
));
}
}
/**
* @param string $name The name
* @param mixed $value The value
*
* @throws \InvalidArgumentException
*/
public function setOption($name, $value)
{
if (!array_key_exists($name, $this->options)) {
throw new \InvalidArgumentException(sprintf(
'The "%s" class does not support the "%s" option.',
get_class($this),
$name
));
}
$this->options[$name] = $value;
}
public function getOptions()
{
return $this->options;
}
/**
* @param string $key The key
*
* @return mixed The value
*
* @throws \InvalidArgumentException
*/
public function getOption($key)
{
if (!array_key_exists($key, $this->options)) {
throw new \InvalidArgumentException(sprintf(
'The "%s" class does not support the "%s" option.',
get_class($this),
$key
));
}
return $this->options[$key];
}
/**
* @param SoapRequest $soapRequest
*
* @return mixed
*/
public function send(SoapRequest $soapRequest)
{
return $this->getNativeSoapClient()->__soapCall(
$soapRequest->getFunction(),
$soapRequest->getArguments(),
$soapRequest->getOptions()
);
}
/**
* @return \SoapClient
*/
public function getNativeSoapClient()
{
if (!$this->soapClient) {
$this->soapClient = new \SoapClient($this->wsdl, $this->getSoapOptions());
}
return $this->soapClient;
}
/**
* @return array The \SoapClient options
*/
public function getSoapOptions()
{
$options = array();
$options['cache_wsdl'] = $this->options['debug'] ? WSDL_CACHE_NONE : WSDL_CACHE_DISK;
$options['trace'] = $this->options['debug'];
return $options;
}
}

View File

@ -0,0 +1,159 @@
<?php
/*
* This file is part of the BeSimpleSoapBundle.
*
* (c) Christian Kerl <christian-kerl@web.de>
* (c) Francis Besset <francis.besset@gmail.com>
*
* This source file is subject to the MIT license that is bundled
* with this source code in the file LICENSE.
*/
namespace BeSimple\SoapClient\Soap;
/**
* @author Francis Besset <francis.besset@gmail.com>
*/
class SoapRequest
{
protected $function;
protected $arguments;
protected $options;
public function __construct($function = null, array $arguments = array(), array $options = array())
{
$this->function = $function;
$this->arguments = $arguments;
$this->options = $options;
}
/**
* @return string The function name
*/
public function getFunction()
{
return $this->function;
}
/**
* @param string The function name
*
* @return SoapRequest
*/
public function setFunction($function)
{
$this->function = $function;
return $this;
}
/**
* @return array An array with all arguments
*/
public function getArguments()
{
return $this->arguments;
}
/**
* @param string The name of the argument
* @param mixed The default value returned if the argument is not exists
*
* @return mixed
*/
public function getArgument($name, $default = null)
{
return $this->hasArgument($name) ? $this->arguments[$name] : $default;
}
/**
* @param string The name of the argument
*
* @return boolean
*/
public function hasArgument($name)
{
return isset($this->arguments[$name]);
}
/**
* @param array An array with arguments
*
* @return SoapRequest
*/
public function setArguments(array $arguments)
{
$this->arguments = $arguments;
return $this;
}
/**
* @param string The name of argument
* @param mixed The value of argument
*
* @return SoapRequest
*/
public function addArgument($name, $value)
{
$this->arguments[$name] = $value;
return $this;
}
/**
* @return array An array with all options
*/
public function getOptions()
{
return $this->options;
}
/**
* @param string The name of the option
* @param mixed The default value returned if the option is not exists
*
* @return mixed
*/
public function getOption($name, $default = null)
{
return $this->hasOption($name) ? $this->options[$name] : $default;
}
/**
* @param string The name of the option
*
* @return boolean
*/
public function hasOption($name)
{
return isset($this->options[$name]);
}
/**
* @param array An array with options
*
* @return SoapRequest
*/
public function setOptions(array $options)
{
$this->options = $options;
return $this;
}
/**
* @param string The name of option
* @param mixed The value of option
*
* @return SoapRequest
*/
public function addOption($name, $value)
{
$this->options[$name] = $value;
return $this;
}
}