19 declare(strict_types=1);
46 $this->log = $DIC->logger()->wsrv();
48 $this->use_wsdl =
true;
49 $timeout = (
int) $this->
settings->get(
'soap_connect_timeout', (
string) self::DEFAULT_CONNECT_TIMEOUT);
51 $this->connect_timeout = $timeout;
53 $this->connect_timeout = $timeout;
55 $this->response_timeout = (
int) $this->
settings->get(
'soap_response_timeout', (
string) self::DEFAULT_RESPONSE_TIMEOUT);
65 $this->connect_timeout = $a_timeout;
75 $this->response_timeout = $a_timeout;
85 $this->use_wsdl = $a_stat;
93 public function init(): bool
95 $internal_path = $this->
settings->get(
'soap_internal_wsdl_path');
98 $this->uri = $internal_path;
99 } elseif (trim($this->
settings->get(
'soap_wsdl_path',
'')) !==
'') {
100 $this->uri = $this->
settings->get(
'soap_wsdl_path',
'');
106 $this->log->debug(
'Using wsdl: ' . $this->
getServer());
107 $this->log->debug(
'Using connection timeout: ' . $this->
getTimeout());
111 $this->
client =
new SoapClient(
114 'exceptions' =>
true,
117 'stream_context' => $this->uri === $internal_path ? stream_context_create([
119 'verify_peer' => (
bool) $this->
settings->get(
'soap_internal_wsdl_verify_peer',
'1'),
120 'verify_peer_name' => (bool) $this->
settings->get(
'soap_internal_wsdl_verify_peer_name',
'1'),
121 'allow_self_signed' => (bool) $this->
settings->get(
'soap_internal_wsdl_allow_self_signed',
''),
128 $this->log->warning(
'Soap init failed with message: ' . $ex->getMessage());
138 $this->stored_socket_timeout = (
int) ini_get(
'default_socket_timeout');
139 $this->log->debug(
'Default socket timeout is: ' . $this->stored_socket_timeout);
142 $this->log->debug(
'WSDL mode, using socket timeout: ' . $this->
getTimeout());
143 ini_set(
'default_socket_timeout', (
string) $this->
getTimeout());
145 $this->log->debug(
'Non WSDL mode, using socket timeout: ' . $this->
getResponseTimeout());
157 ini_set(
'default_socket_timeout', (
string) $this->stored_socket_timeout);
158 $this->log->debug(
'Restoring default socket timeout to: ' . $this->stored_socket_timeout);
167 public function call(
string $a_operation, array $a_params)
169 $this->log->debug(
'Calling webservice: ' . $a_operation);
173 return $this->
client->__call($a_operation, $a_params);
175 $this->log->error(
'Calling webservice failed with message: ' . $exception->getMessage());
176 $this->log->debug((
string) $this->
client->__getLastResponseHeaders());
177 $this->log->debug((
string) $this->
client->__getLastResponse());
180 $this->log->error(
'Caught unknown exception with message: ' . $exception->getMessage());
181 $this->log->debug((
string) $this->
client->__getLastResponseHeaders());
182 $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)
while($session_entry=$r->fetchRow(ilDBConstants::FETCHMODE_ASSOC)) return null
call(string $a_operation, array $a_params)
__construct(string $a_uri='')
setSocketTimeout(bool $a_wsdl_mode)
client()
description: > This example shows how a Progress Bar can be rendered and used on the client...