CreateAccountAlias.php 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. <?php
  2. namespace ThurData\Servers\KerioEmail\App\Libs\Kerio\Components\Api\Soap\Services\Create;
  3. use ThurData\Servers\KerioEmail\App\Enums\ProductParams;
  4. use ThurData\Servers\KerioEmail\App\Libs\Kerio\Components\Api\Soap\Interfaces\ApiService;
  5. use ThurData\Servers\KerioEmail\App\Libs\Kerio\Components\Api\Soap\Models\AccountAlias;
  6. use ThurData\Servers\KerioEmail\App\Libs\Kerio\Components\Api\Soap\Traits\ProductManagerHandler;
  7. /**
  8. *
  9. * Created by PhpStorm.
  10. * User: ThurData
  11. * Date: 09.10.19
  12. * Time: 09:08
  13. * Class CreateAccountAlias
  14. */
  15. class CreateAccountAlias extends ApiService
  16. {
  17. use ProductManagerHandler;
  18. /**
  19. * @return bool|void
  20. */
  21. public function isValid()
  22. {
  23. $limit = $this->productManager->get(ProductParams::ALIAS_LIMIT);
  24. $createdAlias = $this->api->repository()->accounts->getAccountAliasesByDomainName($this->formData['domain']);
  25. if(is_countable($createdAlias)){
  26. if(count($createdAlias) >= $limit && $limit !== ProductParams::SIZE_UNLIMITED)
  27. {
  28. $this->setError('Account alias limit has been reached');
  29. return false;
  30. }
  31. }
  32. return true;
  33. }
  34. /**
  35. * @return mixed|void
  36. */
  37. public function process()
  38. {
  39. /**
  40. * prepare model
  41. */
  42. $alias = $alias = $this->formData['aliasName'].'@'.$this->formData['domain'];
  43. $aliasAccount = new AccountAlias();
  44. $aliasAccount->setAlias($alias);
  45. $aliasAccount->setAccountId($this->formData['mailbox']);
  46. /**
  47. * create account alias in API
  48. */
  49. $result = $this->api->account->createAlias($aliasAccount);
  50. /**
  51. * problem with create account
  52. */
  53. if(!$result)
  54. {
  55. $this->setError($this->api->account->getLastResult()->getLastErrorCode());
  56. return false;
  57. }
  58. return $result;
  59. }
  60. }