MySoapClient.php 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. <?php
  2. namespace ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap;
  3. use SoapClient;
  4. /**
  5. *
  6. * Created by PhpStorm.
  7. * User: Tomasz Bielecki ( tomasz.bi@modulesgarden.com )
  8. * Date: 27.08.19
  9. * Time: 15:47
  10. * Class MySoapClient
  11. */
  12. class MySoapClient extends SoapClient
  13. {
  14. /**
  15. * @param string $request
  16. * @param string $location
  17. * @param string $action
  18. * @param int $version
  19. * @return string
  20. */
  21. public function __doRequest($request, $location, $action, $version)
  22. {
  23. if(stripos($request, 'DistributionListActionRequest') !== false)
  24. {
  25. $request = str_replace(array('ns1:DistributionListActionRequest', 'xmlns:ns2="urn:zimbra"'), array('ns2:DistributionListActionRequest', 'xmlns:ns2="urn:zimbraAccount"'), $request);
  26. }
  27. return parent::__doRequest($request, $location, $action, $version);
  28. }
  29. /**
  30. * @param string $function_name
  31. * @param array $arguments
  32. * @param array|null $options
  33. * @param null $input_headers
  34. * @param array|null $output_headers
  35. * @return mixed|void
  36. */
  37. public function __soapCall($function_name, array $arguments, array $options = null, $input_headers = null, array &$output_headers = null)
  38. {
  39. logModuleCall(
  40. 'zimbraEmail',
  41. __FUNCTION__,
  42. $function_name,
  43. "Debug10",
  44. parent
  45. );
  46. //todo logg
  47. $result = parent::__soapCall($function_name, $arguments, $options, $input_headers, $output_headers);
  48. logModuleCall(
  49. 'zimbraEmail',
  50. __FUNCTION__,
  51. $function_name,
  52. "Debug11",
  53. $result
  54. );
  55. return $result;
  56. }
  57. }