3 declare(strict_types=1);
33 $this->log = $DIC->logger()->wsrv();
35 $this->use_wsdl =
true;
36 $timeout = (
int) $this->
settings->get(
'soap_connect_timeout', (
string) self::DEFAULT_CONNECT_TIMEOUT);
38 $this->connect_timeout = $timeout;
40 $this->connect_timeout = $timeout;
42 $this->response_timeout = (
int) $this->
settings->get(
'soap_response_timeout',(
string) self::DEFAULT_RESPONSE_TIMEOUT);
52 $this->connect_timeout = $a_timeout;
62 $this->response_timeout = $a_timeout;
72 $this->use_wsdl = $a_stat;
80 public function init(): bool
83 if (trim($this->
settings->get(
'soap_wsdl_path',
'')) !==
'') {
84 $this->uri = $this->
settings->get(
'soap_wsdl_path',
'');
90 $this->log->debug(
'Using wsdl: ' . $this->
getServer());
91 $this->log->debug(
'Using connection timeout: ' . $this->
getTimeout());
95 $this->client =
new SoapClient(
105 $this->log->warning(
'Soap init failed with message: ' . $ex->getMessage());
115 $this->stored_socket_timeout = (
int) ini_get(
'default_socket_timeout');
116 $this->log->debug(
'Default socket timeout is: ' . $this->stored_socket_timeout);
119 $this->log->debug(
'WSDL mode, using socket timeout: ' . $this->
getTimeout());
120 ini_set(
'default_socket_timeout', (
string) $this->
getTimeout());
122 $this->log->debug(
'Non WSDL mode, using socket timeout: ' . $this->
getResponseTimeout());
134 ini_set(
'default_socket_timeout', (
string) $this->stored_socket_timeout);
135 $this->log->debug(
'Restoring default socket timeout to: ' . $this->stored_socket_timeout);
144 public function call(
string $a_operation, array $a_params)
146 $this->log->debug(
'Calling webservice: ' . $a_operation);
150 return $this->client->__call($a_operation, $a_params);
152 $this->log->error(
'Calling webservice failed with message: ' . $exception->getMessage());
153 $this->log->debug((
string) $this->client->__getLastResponseHeaders());
154 $this->log->debug((
string) $this->client->__getLastResponse());
157 $this->log->error(
'Caught unknown exception with message: ' . $exception->getMessage());
158 $this->log->debug((
string) $this->client->__getLastResponseHeaders());
159 $this->log->debug((
string) $this->client->__getLastResponse());
resetSocketTimeout()
Reset socket default timeout to defaults.
const DEFAULT_RESPONSE_TIMEOUT
const DEFAULT_CONNECT_TIMEOUT
setResponseTimeout(int $a_timeout)
int $stored_socket_timeout
setTimeout(int $a_timeout)
call(string $a_operation, array $a_params)
__construct(string $a_uri='')
setSocketTimeout(bool $a_wsdl_mode)