TestConnection.php 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. <?php
  2. namespace ModulesGarden\Servers\ZimbraEmail\App\Http\Actions;
  3. use ModulesGarden\Servers\ZimbraEmail\App\Helpers\ZimbraManager;
  4. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Api;
  5. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Client;
  6. use ModulesGarden\Servers\ZimbraEmail\App\Traits\ExtensionsCheckerTrait;
  7. use ModulesGarden\Servers\ZimbraEmail\Core\App\Controllers\Instances\AddonController;
  8. /**
  9. *
  10. * Created by PhpStorm.
  11. * User: Tomasz Bielecki ( tomasz.bi@modulesgarden.com )
  12. * Date: 27.08.19
  13. * Time: 14:54
  14. * Class TestConnection
  15. */
  16. class TestConnection extends AddonController
  17. {
  18. use ExtensionsCheckerTrait;
  19. /**
  20. *
  21. *
  22. * @param null $params
  23. * @return array
  24. */
  25. public function execute($params = null)
  26. {
  27. try{
  28. /**
  29. *
  30. */
  31. $this->checkExtensionOrThrowError();
  32. /**
  33. * zimbra API manager
  34. */
  35. $manager = (new ZimbraManager());
  36. /**
  37. * set API params
  38. */
  39. if($params['serverusername'] )
  40. {
  41. /**
  42. *
  43. * override secure param
  44. */
  45. $params['serversecure'] = $params['serversecure'] ? 'on' : 'off';
  46. $api = $manager->getApi()->setParams($params);
  47. }else{
  48. $api = $manager->getApiByServer($params['serverid']);
  49. }
  50. /**
  51. * API Connection
  52. */
  53. $connection = $api->soap->getConnection();
  54. /**
  55. * check if connected and return true
  56. */
  57. if($connection->isConnected())
  58. {
  59. return ['success' => true];
  60. }
  61. /**
  62. *
  63. * return connection error
  64. */
  65. return ['error' => $connection->getConnectionError()];
  66. }
  67. catch (\Exception $ex)
  68. {
  69. /**
  70. * return some crit error
  71. */
  72. return ['error' => $ex->getMessage()];
  73. }
  74. }
  75. }