Account.php 9.5 KB

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