Account.php 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321
  1. <?php
  2. namespace ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Actions;
  3. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Interfaces\AbstractAction;
  4. use SoapFault;
  5. use SoapParam;
  6. use SoapVar;
  7. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Helpers\XmlParser;
  8. /**
  9. *
  10. * Created by PhpStorm.
  11. * User: Tomasz Bielecki ( tomasz.bi@modulesgarden.com )
  12. * Date: 28.08.19
  13. * Time: 13:46
  14. * Class Account
  15. */
  16. class Account extends AbstractAction
  17. {
  18. public function read()
  19. {
  20. }
  21. /**
  22. * @description create account in Zimbra API
  23. * @param \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account
  24. * @return bool|void
  25. */
  26. public function create(\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account)
  27. {
  28. /**
  29. *
  30. */
  31. $params = [
  32. new SoapParam($account->getName(), "name"),
  33. new SoapParam($account->getPassword(), "password"),
  34. ];
  35. /**
  36. * add account params
  37. */
  38. foreach ($account->getAttrs() as $key => $value)
  39. {
  40. $params[] = new SoapVar('<ns1:a n="' . $key . '">' . $value . '</ns1:a>', XSD_ANYXML);
  41. }
  42. /**
  43. * run request
  44. */
  45. $result = $this->connection->request("CreateAccountRequest", $params);
  46. /**
  47. * load response to model
  48. */
  49. if($accountData = $result->getResponseBody()['CREATEACCOUNTRESPONSE']['ACCOUNT'])
  50. {
  51. $account->fill($accountData);
  52. return $account;
  53. }
  54. $this->setError($result->getLastError());
  55. return false;
  56. }
  57. /**
  58. * @param \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\AccountAlias $alias
  59. * @return \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\AccountAlias
  60. */
  61. public function createAlias(\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\AccountAlias $alias)
  62. {
  63. $params = [
  64. new SoapParam($alias->getAccountId(), "id"),
  65. new SoapParam($alias->getAlias(), "alias"),
  66. ];
  67. $result = $this->connection->request("AddAccountAliasRequest", $params);
  68. logModuleCall(
  69. 'zimbraEmail',
  70. __FUNCTION__,
  71. $result,
  72. 'debug',
  73. $result->getLastError()
  74. );
  75. if(!$result->getLastError())
  76. {
  77. return $alias;
  78. }
  79. $this->setError($result->getLastError());
  80. return false;
  81. }
  82. /**
  83. * @param \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account
  84. * @return bool|\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account
  85. */
  86. public function update(\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account)
  87. {
  88. $params = [
  89. new SoapParam($account->getId(), "id"),
  90. ];
  91. /**
  92. * add account params
  93. */
  94. foreach ($account->getAttrs() as $key => $value)
  95. {
  96. $params[] = new SoapVar('<ns1:a n="' . $key . '">' . $value . '</ns1:a>', XSD_ANYXML);
  97. }
  98. $result = $this->connection->request("ModifyAccountRequest", $params);
  99. if($accountData = $result->getResponseBody()['MODIFYACCOUNTRESPONSE']['ACCOUNT'])
  100. {
  101. $account->fill($accountData);
  102. return $account;
  103. }
  104. $this->setError($result->getLastError());
  105. return false;
  106. }
  107. public function setPassword(\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account)
  108. {
  109. $params = [
  110. new SoapParam($account->getId(), "id"),
  111. new SoapParam($account->getPassword(), "newPassword"),
  112. ];
  113. $result = $this->connection->request("SetPasswordRequest", $params);
  114. if($result->getLastError())
  115. {
  116. $this->setError($result->getLastError());
  117. return false;
  118. }
  119. return true;
  120. }
  121. /**
  122. * @param \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account
  123. * @return bool
  124. */
  125. public function delete(\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account)
  126. {
  127. $params = [
  128. new SoapParam($account->getId(), "id"),
  129. ];
  130. $result = $this->connection->request("DeleteAccountRequest", $params);
  131. if($result->getLastError())
  132. {
  133. $this->setError($result->getLastError());
  134. return false;
  135. }
  136. return true;
  137. }
  138. /**
  139. * @param \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\AccountAlias $alias
  140. * @return bool
  141. */
  142. public function deleteAlias(\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\AccountAlias $alias)
  143. {
  144. $params = [
  145. new SoapParam($alias->getAccountId(), "id"),
  146. new SoapParam($alias->getAlias(), "alias"),
  147. ];
  148. $result = $this->connection
  149. ->request("RemoveAccountAliasRequest", $params);
  150. if(!$result->getLastError())
  151. {
  152. return true;
  153. }
  154. $this->setError($result->getLastError());
  155. return false;
  156. }
  157. /**
  158. * @param $name
  159. * @return \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Response
  160. */
  161. public function getAccountId($name)
  162. {
  163. $params = [
  164. new SoapVar('<ns1:account by="name">' . $name . '</ns1:account>', XSD_ANYXML),
  165. ];
  166. return $this->connection->cleanResponse()->request("GetAccountInfoRequest", $params);
  167. }
  168. /**
  169. * @param \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account
  170. * @return \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Response
  171. */
  172. public function getAccountInfo(\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account)
  173. {
  174. if($value = $account->getId())
  175. {
  176. $type = 'id';
  177. }elseif($value =$account->getName())
  178. {
  179. $type = 'name';
  180. }
  181. $result = null;
  182. $params = [
  183. new SoapVar('<ns1:account by="' . $type . '">' . $value . '</ns1:account>', XSD_ANYXML),
  184. ];
  185. return $this->connection->request("GetAccountInfoRequest", $params);
  186. }
  187. /**
  188. * @param \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account
  189. * @return \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Response
  190. */
  191. public function delegateAuth(\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account)
  192. {
  193. if($value = $account->getId())
  194. {
  195. $type = 'id';
  196. }elseif($value =$account->getName())
  197. {
  198. $type = 'name';
  199. }
  200. $result = null;
  201. $params = [
  202. new SoapVar('<ns1:account by="' . $type . '">' . $value . '</ns1:account>', XSD_ANYXML),
  203. ];
  204. $result = $this->connection->cleanResponse()->request("DelegateAuthRequest", $params);
  205. if($result->getLastError())
  206. {
  207. $this->setError($result->getLastError());
  208. return false;
  209. }
  210. return $result;
  211. }
  212. /**
  213. * @param \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account
  214. * @return \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Response
  215. */
  216. public function getAccountOptions(\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account)
  217. {
  218. if($value = $account->getId())
  219. {
  220. $type = 'id';
  221. }elseif($value =$account->getName())
  222. {
  223. $type = 'name';
  224. }
  225. $params = [
  226. new SoapVar('<ns1:account by="' . $type . '">' . $value . '</ns1:account>', XSD_ANYXML),
  227. ];
  228. return $this->connection
  229. ->cleanResponse()
  230. ->request("GetAccountRequest", $params);
  231. }
  232. /**
  233. * @param \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Domain $domain
  234. * @return \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Response
  235. */
  236. public function getAllByDomain(\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Domain $domain)
  237. {
  238. if($value = $domain->getId())
  239. {
  240. $type = 'id';
  241. }elseif($value =$domain->getName())
  242. {
  243. $type = 'name';
  244. }
  245. $params = [
  246. new SoapVar('<ns1:domain by="' . $type . '">' . $value . '</ns1:domain>', XSD_ANYXML),
  247. ];
  248. $result = $this->connection->request("GetAllAccountsRequest", $params);
  249. return $result;
  250. }
  251. public function getAllAccounts($idOrNameDomain, $type = "auto")
  252. {
  253. if ($type == "auto")
  254. {
  255. //$realType = getDomainType($idOrNameDomain);
  256. }
  257. else
  258. {
  259. $realType = $type;
  260. }
  261. $result = null;
  262. $params = [
  263. new SoapVar('<ns1:domain by="' . $realType . '">' . $idOrNameDomain . '</ns1:domain>', XSD_ANYXML),
  264. ];
  265. return $this->connection->request("GetAllAccountsRequest", $params);
  266. }
  267. }