CreateAccount.php 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. <?php
  2. namespace ThurData\Servers\KerioEmail\App\Http\Actions;
  3. use ThurData\Servers\KerioEmail\App\Enums\Response;
  4. use ThurData\Servers\KerioEmail\App\Helpers\KerioManager;
  5. use ThurData\Servers\KerioEmail\App\Libs\Product\ProductManager;
  6. use ThurData\Servers\KerioEmail\App\Libs\Kerio\Components\Api\Soap\Models\Domain;
  7. use ThurData\Servers\KerioEmail\App\Libs\Kerio\Components\Api\Soap\Traits\ProductManagerHandler;
  8. use ThurData\Servers\KerioEmail\App\Traits\ExtensionsCheckerTrait;
  9. use ThurData\Servers\KerioEmail\Core\App\Controllers\Instances\AddonController;
  10. use ThurData\Servers\KerioEmail\App\Traits\HostingService;
  11. use \ThurData\Servers\KerioEmail\Core\UI\Traits\WhmcsParams;
  12. use ThurData\Servers\KerioEmail\Api\KerioWhmcs;
  13. /**
  14. *
  15. * Created by PhpStorm.
  16. * User: ThurData
  17. * Date: 09.09.19
  18. * Time: 15:14
  19. * Class CreateAccount
  20. */
  21. class CreateAccount extends AddonController
  22. {
  23. use ExtensionsCheckerTrait;
  24. use HostingService;
  25. use WhmcsParams;
  26. /**
  27. * create domain in kerio
  28. *
  29. * @param null $params
  30. * @return string
  31. */
  32. public function execute($params = null)
  33. {
  34. try{
  35. /**
  36. * check if extensions are installed
  37. */
  38. $this->checkExtensionOrThrowError();
  39. //update domain
  40. if($params['customfields']['maildomain']){
  41. $params['domain'] = $params['customfields']['maildomain'];
  42. $this->hosting()->domain = $params['domain'];
  43. $this->hosting()->save();
  44. }
  45. /**
  46. * run kerio service
  47. */
  48. $result = $this->kerioRunService($params);
  49. return $result;
  50. }catch (\Exception $ex)
  51. {
  52. /**
  53. * return some crit error
  54. */
  55. return $ex->getMessage();
  56. }
  57. }
  58. /**
  59. * @param null $params
  60. * @return mixed|string
  61. */
  62. protected function kerioRunService($params = null)
  63. {
  64. $api = new KerioWhmcs('whmcsKerioEmail', 'Thurdata', '1.0');
  65. try {
  66. $api->login($params['serverhostname'], $params['serverusername'], $params['serverpassword']);
  67. $result = $api->createDomain($params['domain']);
  68. $domainID = $result['result'][0]['id'];
  69. } catch (KerioApiException $error) {
  70. logModuleCall(
  71. 'kerioEmail',
  72. __FUNCTION__,
  73. $error,
  74. 'Debug Error',
  75. $error->getMessage()
  76. );
  77. return ['error' => $error->getMessage()];
  78. }
  79. // check and calculate limits
  80. $productManager = new ProductManager();
  81. $productManager->loadById($params['pid']);
  82. $acc_limit = $productManager->get('acc_limit');
  83. $accounts = $productManager->get('acc_base') + $params['configoptions']['acc_add'] + $params['configoptions']['acc_new'];
  84. if ($acc_limit >= 0) {
  85. $attr['userMaxCountCheckbox'] = TRUE;
  86. if ($accounts > $acc_limit) {
  87. $accounts = $acc_limit;
  88. }
  89. $attr['userMaxCount'] = $accounts;
  90. } else {
  91. $attr['userMaxCountCheckbox'] = FALSE;
  92. }
  93. $domainMaxSize = $productManager->get('domainMaxSize');
  94. $domainSize = $productManager->get('domainBaseSize') + $params['configoptions']['domainAddSize'] + $params['configoptions']['domainNewSize'];
  95. if ($domainMaxSize >= 0) {
  96. $attr['domainQuota']['diskSizeLimit']['isActive'] = TRUE;
  97. if ($domainSize > $domainMaxSize) {
  98. $domainSize = $domainMaxSize;
  99. }
  100. $attr['domainQuota']['diskSizeLimit']['limit']['value'] = $domainSize;
  101. $attr['domainQuota']['diskSizeLimit']['limit']['units'] = 'GigaBytes';
  102. } else {
  103. $attr['domainQuota']['diskSizeLimit']['isActive'] = FALSE;
  104. }
  105. logModuleCall(
  106. 'kerioEmail',
  107. __FUNCTION__,
  108. $attr,
  109. 'Debug ID',
  110. $params
  111. );
  112. try {
  113. $result = $api->modifyDomain($domainID, $attr);
  114. } catch (KerioApiException $error) {
  115. logModuleCall(
  116. 'kerioEmail',
  117. __FUNCTION__,
  118. $error,
  119. 'Debug Error',
  120. $error->getMessage()
  121. );
  122. return ['error' => $error->getMessage()];
  123. }
  124. logModuleCall(
  125. 'kerioEmail',
  126. __FUNCTION__,
  127. $attr,
  128. 'Debug ID',
  129. $result
  130. );
  131. $api->logout();
  132. /**
  133. * return success response
  134. */
  135. return Response::SUCCESS;
  136. }
  137. }