Account.php 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311
  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. if(!$result->getLastError())
  69. {
  70. return $alias;
  71. }
  72. $this->setError($result->getLastError());
  73. return false;
  74. }
  75. /**
  76. * @param \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account
  77. * @return bool|\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account
  78. */
  79. public function update(\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account)
  80. {
  81. $params = [
  82. new SoapParam($account->getId(), "id"),
  83. ];
  84. /**
  85. * add account params
  86. */
  87. foreach ($account->getAttrs() as $key => $value)
  88. {
  89. $params[] = new SoapVar('<ns1:a n="' . $key . '">' . $value . '</ns1:a>', XSD_ANYXML);
  90. }
  91. $result = $this->connection->request("ModifyAccountRequest", $params);
  92. if($accountData = $result->getResponseBody()['MODIFYACCOUNTRESPONSE']['ACCOUNT'])
  93. {
  94. $account->fill($accountData);
  95. return $account;
  96. }
  97. $this->setError($result->getLastError());
  98. return false;
  99. }
  100. public function setPassword(\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account)
  101. {
  102. $params = [
  103. new SoapParam($account->getId(), "id"),
  104. new SoapParam($account->getPassword(), "newPassword"),
  105. ];
  106. $result = $this->connection->request("SetPasswordRequest", $params);
  107. if($result->getLastError())
  108. {
  109. $this->setError($result->getLastError());
  110. return false;
  111. }
  112. return true;
  113. }
  114. /**
  115. * @param \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account
  116. * @return bool
  117. */
  118. public function delete(\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account)
  119. {
  120. $params = [
  121. new SoapParam($account->getId(), "id"),
  122. ];
  123. $result = $this->connection->request("DeleteAccountRequest", $params);
  124. if($result->getLastError())
  125. {
  126. $this->setError($result->getLastError());
  127. return false;
  128. }
  129. return true;
  130. }
  131. /**
  132. * @param \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\AccountAlias $alias
  133. * @return bool
  134. */
  135. public function deleteAlias(\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\AccountAlias $alias)
  136. {
  137. $params = [
  138. new SoapParam($alias->getAccountId(), "id"),
  139. new SoapParam($alias->getAlias(), "alias"),
  140. ];
  141. $result = $this->connection
  142. ->request("RemoveAccountAliasRequest", $params);
  143. if(!$result->getLastError())
  144. {
  145. return true;
  146. }
  147. return false;
  148. }
  149. /**
  150. * @param $name
  151. * @return \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Response
  152. */
  153. public function getAccountId($name)
  154. {
  155. $params = [
  156. new SoapVar('<ns1:account by="name">' . $name . '</ns1:account>', XSD_ANYXML),
  157. ];
  158. return $this->connection->cleanResponse()->request("GetAccountInfoRequest", $params);
  159. }
  160. /**
  161. * @param \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account
  162. * @return \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Response
  163. */
  164. public function getAccountInfo(\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account)
  165. {
  166. if($value = $account->getId())
  167. {
  168. $type = 'id';
  169. }elseif($value =$account->getName())
  170. {
  171. $type = 'name';
  172. }
  173. $result = null;
  174. $params = [
  175. new SoapVar('<ns1:account by="' . $type . '">' . $value . '</ns1:account>', XSD_ANYXML),
  176. ];
  177. return $this->connection->request("GetAccountInfoRequest", $params);
  178. }
  179. /**
  180. * @param \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account
  181. * @return \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Response
  182. */
  183. public function delegateAuth(\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account)
  184. {
  185. if($value = $account->getId())
  186. {
  187. $type = 'id';
  188. }elseif($value =$account->getName())
  189. {
  190. $type = 'name';
  191. }
  192. $result = null;
  193. $params = [
  194. new SoapVar('<ns1:account by="' . $type . '">' . $value . '</ns1:account>', XSD_ANYXML),
  195. ];
  196. $result = $this->connection->cleanResponse()->request("DelegateAuthRequest", $params);
  197. if($result->getLastError())
  198. {
  199. $this->setError($result->getLastError());
  200. return false;
  201. }
  202. return $result;
  203. }
  204. /**
  205. * @param \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account
  206. * @return \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Response
  207. */
  208. public function getAccountOptions(\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Account $account)
  209. {
  210. if($value = $account->getId())
  211. {
  212. $type = 'id';
  213. }elseif($value =$account->getName())
  214. {
  215. $type = 'name';
  216. }
  217. $params = [
  218. new SoapVar('<ns1:account by="' . $type . '">' . $value . '</ns1:account>', XSD_ANYXML),
  219. ];
  220. return $this->connection
  221. ->cleanResponse()
  222. ->request("GetAccountRequest", $params);
  223. }
  224. /**
  225. * @param \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Domain $domain
  226. * @return \ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Response
  227. */
  228. public function getAllByDomain(\ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Models\Domain $domain)
  229. {
  230. if($value = $domain->getId())
  231. {
  232. $type = 'id';
  233. }elseif($value =$domain->getName())
  234. {
  235. $type = 'name';
  236. }
  237. $params = [
  238. new SoapVar('<ns1:domain by="' . $type . '">' . $value . '</ns1:domain>', XSD_ANYXML),
  239. ];
  240. $result = $this->connection->request("GetAllAccountsRequest", $params);
  241. return $result;
  242. }
  243. public function getAllAccounts($idOrNameDomain, $type = "auto")
  244. {
  245. if ($type == "auto")
  246. {
  247. //$realType = getDomainType($idOrNameDomain);
  248. }
  249. else
  250. {
  251. $realType = $type;
  252. }
  253. $result = null;
  254. $params = [
  255. new SoapVar('<ns1:domain by="' . $realType . '">' . $idOrNameDomain . '</ns1:domain>', XSD_ANYXML),
  256. ];
  257. return $this->connection->request("GetAllAccountsRequest", $params);
  258. }
  259. }