ILIAS  trunk Revision v11.0_alpha-1689-g66c127b4ae8
All Data Structures Namespaces Files Functions Variables Enumerations Enumerator Modules Pages
class.ilSoapClient.php
Go to the documentation of this file.
1 <?php
2 
19 declare(strict_types=1);
28 {
29  public const DEFAULT_CONNECT_TIMEOUT = 10;
30  public const DEFAULT_RESPONSE_TIMEOUT = 5;
31 
32  private ilLogger $log;
34  private ?SoapClient $client = null;
35  private string $uri;
36  private bool $use_wsdl = true;
37  private int $connect_timeout = self::DEFAULT_CONNECT_TIMEOUT;
38  private int $response_timeout = self::DEFAULT_RESPONSE_TIMEOUT;
39  private ?int $stored_socket_timeout = null;
40 
41  public function __construct(string $a_uri = '')
42  {
43  global $DIC;
44 
45  $this->settings = $DIC->settings();
46  $this->log = $DIC->logger()->wsrv();
47  $this->uri = $a_uri;
48  $this->use_wsdl = true;
49  $timeout = (int) $this->settings->get('soap_connect_timeout', (string) self::DEFAULT_CONNECT_TIMEOUT);
50  if ($timeout) {
51  $this->connect_timeout = $timeout;
52  }
53  $this->connect_timeout = $timeout;
54 
55  $this->response_timeout = (int) $this->settings->get('soap_response_timeout', (string) self::DEFAULT_RESPONSE_TIMEOUT);
56  }
57 
58  public function getServer(): string
59  {
60  return $this->uri;
61  }
62 
63  public function setTimeout(int $a_timeout): void
64  {
65  $this->connect_timeout = $a_timeout;
66  }
67 
68  public function getTimeout(): int
69  {
71  }
72 
73  public function setResponseTimeout(int $a_timeout): void
74  {
75  $this->response_timeout = $a_timeout;
76  }
77 
78  public function getResponseTimeout(): int
79  {
81  }
82 
83  public function enableWSDL(bool $a_stat): void
84  {
85  $this->use_wsdl = $a_stat;
86  }
87 
88  public function enabledWSDL(): bool
89  {
90  return $this->use_wsdl;
91  }
92 
93  public function init(): bool
94  {
95  $internal_path = $this->settings->get('soap_internal_wsdl_path');
96  if (trim($this->getServer()) === '') {
97  if ($internal_path) {
98  $this->uri = $internal_path;
99  } elseif (trim($this->settings->get('soap_wsdl_path', '')) !== '') {
100  $this->uri = $this->settings->get('soap_wsdl_path', '');
101  } else {
102  $this->uri = ilUtil::_getHttpPath() . '/public/soap/server.php?wsdl';
103  }
104  }
105  try {
106  $this->log->debug('Using wsdl: ' . $this->getServer());
107  $this->log->debug('Using connection timeout: ' . $this->getTimeout());
108  $this->log->debug('Using response timeout: ' . $this->getResponseTimeout());
109 
110  $this->setSocketTimeout(true);
111  $this->client = new SoapClient(
112  $this->uri,
113  array(
114  'exceptions' => true,
115  'trace' => 1,
116  'connection_timeout' => $this->getTimeout(),
117  'stream_context' => $this->uri === $internal_path ? stream_context_create([
118  'ssl' => [
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', ''),
122  ]
123  ]) : null
124  )
125  );
126  return true;
127  } catch (SoapFault $ex) {
128  $this->log->warning('Soap init failed with message: ' . $ex->getMessage());
129  $this->resetSocketTimeout();
130  return false;
131  } finally {
132  $this->resetSocketTimeout();
133  }
134  }
135 
136  protected function setSocketTimeout(bool $a_wsdl_mode): bool
137  {
138  $this->stored_socket_timeout = (int) ini_get('default_socket_timeout');
139  $this->log->debug('Default socket timeout is: ' . $this->stored_socket_timeout);
140 
141  if ($a_wsdl_mode) {
142  $this->log->debug('WSDL mode, using socket timeout: ' . $this->getTimeout());
143  ini_set('default_socket_timeout', (string) $this->getTimeout());
144  } else {
145  $this->log->debug('Non WSDL mode, using socket timeout: ' . $this->getResponseTimeout());
146  ini_set('default_socket_timeout', (string) $this->getResponseTimeout());
147  }
148 
149  return true;
150  }
151 
155  protected function resetSocketTimeout(): bool
156  {
157  ini_set('default_socket_timeout', (string) $this->stored_socket_timeout);
158  $this->log->debug('Restoring default socket timeout to: ' . $this->stored_socket_timeout);
159  return true;
160  }
161 
167  public function call(string $a_operation, array $a_params)
168  {
169  $this->log->debug('Calling webservice: ' . $a_operation);
170 
171  $this->setSocketTimeout(false);
172  try {
173  return $this->client->__call($a_operation, $a_params);
174  } catch (SoapFault $exception) {
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());
178  return false;
179  } catch (Exception $exception) {
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());
183  } finally {
184  $this->resetSocketTimeout();
185  }
186 
187  return false;
188  }
189 }
resetSocketTimeout()
Reset socket default timeout to defaults.
const DEFAULT_RESPONSE_TIMEOUT
enableWSDL(bool $a_stat)
SoapClient $client
const DEFAULT_CONNECT_TIMEOUT
setResponseTimeout(int $a_timeout)
setTimeout(int $a_timeout)
while($session_entry=$r->fetchRow(ilDBConstants::FETCHMODE_ASSOC)) return null
call(string $a_operation, array $a_params)
global $DIC
Definition: shib_login.php:22
__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...
Definition: client.php:37
static _getHttpPath()