EditAccountDataProvider.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357
  1. <?php
  2. namespace ModulesGarden\Servers\ZimbraEmail\App\UI\Client\EmailAccount\Providers;
  3. use ModulesGarden\Servers\ZimbraEmail\App\Enums\Zimbra;
  4. use ModulesGarden\Servers\ZimbraEmail\App\Helpers\ZimbraManager;
  5. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Product\ProductManager;
  6. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account;
  7. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\ClassOfService;
  8. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Repository;
  9. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Repository\ClassOfServices;
  10. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Response;
  11. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Update\UpdateAccount;
  12. use ModulesGarden\Servers\ZimbraEmail\App\Services\ConfigurableOptions\Strategy\Types\ClassOfServicesOptions;
  13. use function ModulesGarden\Servers\ZimbraEmail\Core\Helper\di;
  14. use ModulesGarden\Servers\ZimbraEmail\Core\Models\Whmcs\Hosting;
  15. use ModulesGarden\Servers\ZimbraEmail\Core\UI\ResponseTemplates\HtmlDataJsonResponse;
  16. use ModulesGarden\Servers\ZimbraEmail\Core\UI\Widget\Forms\DataProviders\BaseDataProvider;
  17. /**
  18. *
  19. * Created by PhpStorm.
  20. * User: Tomasz Bielecki ( tomasz.bi@modulesgarden.com )
  21. * Date: 18.09.19
  22. * Time: 09:35
  23. * Class EditAccountDataProvider
  24. */
  25. class EditAccountDataProvider extends BaseDataProvider
  26. {
  27. /**
  28. *
  29. */
  30. public function read()
  31. {
  32. /**
  33. * hosting id
  34. */
  35. $hid = $this->getRequestValue('id');
  36. /**
  37. * load hosting
  38. */
  39. $hosting = Hosting::where('id', $hid)->first();
  40. /**
  41. * load api
  42. */
  43. $api = (new ZimbraManager())->getApiByServer($hosting->server);
  44. $repository = new Repository($api->soap);
  45. $result = $repository->accounts->getAccountOptionsById($this->actionElementId);
  46. if($result instanceof Response && $result->getLastError())
  47. {
  48. throw new \Exception($result->getLastError());
  49. }
  50. $mailBoxParams = explode('@', $result->getName());
  51. $this->data['id'] = $result->getId();
  52. $this->data['username'] = $mailBoxParams[0];
  53. $this->data['domain'] = $mailBoxParams[1];
  54. $this->data['firstname'] = $result->getDataResourceA(Account::ATTR_FIRSTNAME);
  55. $this->data['lastname'] = $result->getDataResourceA(Account::ATTR_LASTNAME);
  56. $this->data['display_name'] = $result->getDataResourceA(Account::ATTR_DISPLAY_NAME);
  57. $this->data['status'] = $result->getDataResourceA(Account::ATTR_ACCOUNT_STATUS);
  58. $this->data['company'] = $result->getDataResourceA(Account::ATTR_COMPANY);
  59. $this->data['title'] = $result->getDataResourceA(Account::ATTR_PROF_TITLE);
  60. $this->data['phone'] = $result->getDataResourceA(Account::ATTR_PHONE);
  61. $this->data['home_phone'] = $result->getDataResourceA(Account::ATTR_HOME_PHONE);
  62. $this->data['mobile_phone'] = $result->getDataResourceA(Account::ATTR_MOBILE_PHONE);
  63. $this->data['fax'] = $result->getDataResourceA(Account::ATTR_FAX);
  64. $this->data['pager'] = $result->getDataResourceA(Account::ATTR_PAGER);
  65. $this->data['country'] = $result->getDataResourceA(Account::ATTR_COUNTRY);
  66. $this->data['city'] = $result->getDataResourceA(Account::ATTR_CITY);
  67. $this->data['street'] = $result->getDataResourceA(Account::ATTR_STREET);
  68. $this->data['post_code'] = $result->getDataResourceA(Account::ATTR_POSTAL_CODE);
  69. $this->data['currentCosId'] = $result->getDataResourceA(Account::ATTR_CLASS_OF_SERVICE_ID);
  70. $this->data['cosId'] = $result->getDataResourceA(Account::ATTR_CLASS_OF_SERVICE_ID);
  71. $this->data['state'] = $result->getDataResourceA(Account::ATTR_STATE);
  72. $this->data['zimbraPrefMailForwardingAddress'] = $result->getDataResourceA(Account::ATTR_MAIL_FORWARD);
  73. if (empty($this->data['zimbraPrefMailForwardingAddress'])) {
  74. $this->data['forward'] = 'off';
  75. } else {
  76. $this->data['forward'] = 'on';
  77. }
  78. $lang = di('lang');
  79. $this->availableValues['status'] = [
  80. Zimbra::ACC_STATUS_ACTIVE => $lang->absoluteT('zimbra','account','status','active'),
  81. Zimbra::ACC_STATUS_LOCKED => $lang->absoluteT('zimbra','account','status','locked'),
  82. Zimbra::ACC_STATUS_MAINTENANCE => $lang->absoluteT('zimbra','account','status','maintenance'),
  83. Zimbra::ACC_STATUS_CLOSED => $lang->absoluteT('zimbra','account','status','closed'),
  84. Zimbra::ACC_STATUS_LOCKOUT => $lang->absoluteT('zimbra','account','status','lockout'),
  85. Zimbra::ACC_STATUS_PENDING => $lang->absoluteT('zimbra','account','status','pending')
  86. ];
  87. $this->readCosParams();
  88. }
  89. /**
  90. * @return HtmlDataJsonResponse
  91. */
  92. public function update()
  93. {
  94. /**
  95. * hosting id
  96. */
  97. $hid = $this->request->get('id');
  98. $fieldToProtection = ['firstname', 'lastname', 'display_name', 'company', 'title', 'country', 'state', 'city', 'street', 'post_code' ];
  99. foreach ($this->formData as $field => &$value)
  100. {
  101. $value = in_array($field, $fieldToProtection) ? htmlentities($value) : $value;
  102. }
  103. /**
  104. * product manager allow to check product settings
  105. */
  106. $productManager = new ProductManager();
  107. $productManager->loadByHostingId($hid);
  108. /**
  109. *
  110. * get soap create domain service
  111. */
  112. $service =(new ZimbraManager())
  113. ->getApiByHosting($hid)
  114. ->soap
  115. ->service()
  116. ->updateAccount($productManager->get('cos_name'));
  117. /**
  118. *
  119. * set product manager & form data to service
  120. */
  121. $service
  122. ->setProductManager($productManager)
  123. ->setFormData($this->formData);
  124. /**
  125. * run service
  126. */
  127. $result = $service->run();
  128. /**
  129. * return success or error response
  130. */
  131. if(!$result)
  132. {
  133. return (new HtmlDataJsonResponse())->setMessageAndTranslate($service->getError())->setStatusError();
  134. }
  135. return (new HtmlDataJsonResponse())->setMessageAndTranslate('emailAccountHasBeenUpdated')->setStatusSuccess();
  136. }
  137. /**
  138. * @return HtmlDataJsonResponse
  139. */
  140. public function updateStatus()
  141. {
  142. /**
  143. * hosting id
  144. */
  145. $hid = $this->request->get('id');
  146. /**
  147. * product manager allow to check product settings
  148. */
  149. $productManager = new ProductManager();
  150. $productManager->loadByHostingId($hid);
  151. /**
  152. *
  153. * get soap create domain service
  154. */
  155. $service =(new ZimbraManager())
  156. ->getApiByHosting($hid)
  157. ->soap
  158. ->service()
  159. ->updateAccountStatus()
  160. ->setProductManager($productManager)
  161. ;
  162. /**
  163. *
  164. * set product manager & form data to service
  165. */
  166. /**
  167. * run service for each id
  168. */
  169. $service->setFormData($this->formData);
  170. $result = $service->run();
  171. if(!$result)
  172. {
  173. return (new HtmlDataJsonResponse())->setMessageAndTranslate($service->getError())->setStatusError();
  174. }
  175. /**
  176. * return success
  177. */
  178. return (new HtmlDataJsonResponse())->setMessageAndTranslate('emailAccountStatusHasBeenUpdated')->setStatusSuccess();
  179. }
  180. /**
  181. * @return HtmlDataJsonResponse
  182. */
  183. public function changePassword()
  184. {
  185. /**
  186. * hosting id
  187. */
  188. $hid = $this->request->get('id');
  189. /**
  190. * product manager allow to check product settings
  191. */
  192. $productManager = new ProductManager();
  193. $productManager->loadByHostingId($hid);
  194. /**
  195. *
  196. * get soap create domain service
  197. */
  198. $service =(new ZimbraManager())
  199. ->getApiByHosting($hid)
  200. ->soap
  201. ->service()
  202. ->updateAccountPassword()
  203. ->setProductManager($productManager)
  204. ;
  205. /**
  206. *
  207. * set product manager & form data to service
  208. */
  209. /**
  210. * run service for each id
  211. */
  212. $service->setFormData($this->formData);
  213. $result = $service->run();
  214. if(!$result)
  215. {
  216. return (new HtmlDataJsonResponse())->setMessageAndTranslate($service->getError())->setStatusError();
  217. }
  218. return (new HtmlDataJsonResponse())->setMessageAndTranslate('passwordChangedSuccessfully')->setStatusSuccess();
  219. }
  220. /**
  221. *
  222. */
  223. public function readCosParams()
  224. {
  225. $hid = $this->getRequestValue('id');
  226. /**
  227. * product manager allow to check product settings
  228. */
  229. $productManager = new ProductManager();
  230. $productManager->loadByHostingId($hid);
  231. if($productManager->get('cos_name') === ClassOfServices::CLASS_OF_SERVICE_QUOTA)
  232. {
  233. /**
  234. *
  235. * get soap create domain service
  236. */
  237. $api =(new ZimbraManager())
  238. ->getApiByHosting($hid)
  239. ->soap;
  240. /**
  241. *
  242. * get cos from API
  243. */
  244. $classOfServices = $api->repository()->cos->all();
  245. /**
  246. *
  247. * load configurable options coses
  248. */
  249. $supportedCos = $productManager->getSettingCos();
  250. /**
  251. *
  252. * add COS to array
  253. */
  254. $configoptions = $this->getFilteredCosConfigurableOptions();
  255. foreach($classOfServices as $cos)
  256. {
  257. /**
  258. *
  259. *
  260. * skip COS which is not used in configurable options
  261. */
  262. if(!($supportedCos && array_key_exists($cos->getId(), $supportedCos)))
  263. {
  264. continue;
  265. }
  266. /**
  267. *
  268. * skip if class of services doesnt exists in config option list
  269. */
  270. if($configoptions && !array_key_exists('cosQuota_'.$cos->getId(), $configoptions))
  271. {
  272. continue;
  273. }
  274. /**
  275. * skip not purchased as CO
  276. */
  277. if ($configoptions && $configoptions['cosQuota_'.$cos->getId()] == 0)
  278. {
  279. continue;
  280. }
  281. /**
  282. * 1. check if config opts are not available
  283. * 2. skip if quantity === 0
  284. */
  285. if(!$configoptions && $supportedCos[$cos->getId()] == 0)
  286. {
  287. continue;
  288. }
  289. /* @var $cos ClassOfService*/
  290. $this->availableValues['cosId'][$cos->getId()] = $cos->getMbMailQuote().' MB';
  291. }
  292. }
  293. }
  294. /**
  295. * @return bool|mixed
  296. */
  297. protected function getFilteredCosConfigurableOptions()
  298. {
  299. $configoptions = $this->getWhmcsParamByKey('configoptions');
  300. foreach($configoptions as $key => $value)
  301. {
  302. if(strpos($key, ClassOfServicesOptions::COS_CONFIG_OPT_PREFIX) === false)
  303. {
  304. unset($configoptions[$key]);
  305. }
  306. }
  307. return $configoptions;
  308. }
  309. }