Services.php 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325
  1. <?php
  2. namespace ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap;
  3. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Repository\ClassOfServices;
  4. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Create\CreateAccount;
  5. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Create\CreateAccountAlias;
  6. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Create\CreateAccountCos;
  7. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Create\CreateAccountCosQuota;
  8. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Create\CreateDistributionList;
  9. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Create\CreateDomain;
  10. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Create\CreateDomainAlias;
  11. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Create\CreateRessource;
  12. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Delete\DeleteAccount;
  13. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Delete\DeleteAccountAlias;
  14. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Delete\DeleteDistributionList;
  15. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Delete\DeleteDomain;
  16. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Delete\DeleteDomainAlias;
  17. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Delete\DeleteRessource;
  18. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Sso\ClientSingleSignOn;
  19. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Sso\ClientSingleSignOnToken;
  20. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Update\ChangePackage;
  21. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Update\ChangePackageConfigOptions;
  22. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Update\ChangePackageCosQuota;
  23. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Update\ChangePackageDedicatedCos;
  24. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Update\SuspendDomain;
  25. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Update\UpdateDomain;
  26. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Update\UnsuspendDomain;
  27. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Update\UpdateAccount;
  28. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Update\UpdateAccountCosQuota;
  29. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Update\UpdateAccountPassword;
  30. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Update\UpdateAccountStatus;
  31. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Update\UpdateDistributionList;
  32. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Services\Update\UpdateRessource;
  33. use ModulesGarden\Servers\ZimbraEmail\App\Libs\Zimbra\Components\Api\Soap\Traits\ApiClientHandler;
  34. /**
  35. *
  36. * Class return supported services
  37. *
  38. * Created by PhpStorm.
  39. * User: Tomasz Bielecki ( tomasz.bi@modulesgarden.com )
  40. * Date: 03.10.19
  41. * Time: 13:15
  42. * Class Services
  43. */
  44. class Services
  45. {
  46. /**
  47. * API Client handler
  48. */
  49. use ApiClientHandler;
  50. /**
  51. * Services constructor.
  52. * @param Client $api
  53. */
  54. public function __construct(Client $api)
  55. {
  56. $this->setApi($api);
  57. }
  58. /**
  59. *
  60. * create account in zimbra, depends of product configuration
  61. * @param string $type
  62. * @return CreateAccount|CreateAccountCos|CreateAccountCosQuota
  63. */
  64. public function createAccount($type = ClassOfServices::CUSTOM_ZIMBRA)
  65. {
  66. switch ($type)
  67. {
  68. case ClassOfServices::CUSTOM_ZIMBRA:
  69. $service = new CreateAccount($this->getApi());
  70. break;
  71. case ClassOfServices::ZIMBRA_CONFIG_OPTIONS:
  72. $service = new CreateAccountCosQuota($this->getApi());
  73. break;
  74. case ClassOfServices::CLASS_OF_SERVICE_QUOTA:
  75. $service = new CreateAccountCosQuota($this->getApi());
  76. break;
  77. default:
  78. $service = new CreateAccountCosQuota($this->getApi());
  79. break;
  80. }
  81. return $service;
  82. }
  83. /**
  84. * create alias for account in zimbra
  85. *
  86. * @return CreateAccountAlias
  87. */
  88. public function createAccountAlias()
  89. {
  90. return new CreateAccountAlias($this->getApi());
  91. }
  92. /**
  93. * create distribution list (mailing list)
  94. *
  95. * @return CreateDistributionList
  96. */
  97. public function createDistributionList()
  98. {
  99. return new CreateDistributionList($this->getApi());
  100. }
  101. /**
  102. * create domain in zimbra (main domain for account)
  103. *
  104. *
  105. * @return CreateDomain
  106. */
  107. public function createDomain()
  108. {
  109. return new CreateDomain($this->getApi());
  110. }
  111. /**
  112. * create alias domain for account
  113. *
  114. * @return CreateDomainAlias
  115. */
  116. public function createDomainAlias()
  117. {
  118. return new CreateDomainAlias($this->getApi());
  119. }
  120. /**
  121. * create ressource for account
  122. *
  123. * @return CreateRessource
  124. */
  125. public function createRessource()
  126. {
  127. return new CreateRessource($this->getApi());
  128. }
  129. /**
  130. *
  131. * change product package
  132. *
  133. * @return ChangePackage
  134. */
  135. public function changePackages($type = ClassOfServices::CUSTOM_ZIMBRA)
  136. {
  137. switch ($type)
  138. {
  139. case ClassOfServices::CUSTOM_ZIMBRA:
  140. $service = new ChangePackage($this->getApi());
  141. break;
  142. case ClassOfServices::ZIMBRA_CONFIG_OPTIONS:
  143. $service = new ChangePackageConfigOptions($this->getApi());
  144. break;
  145. case ClassOfServices::CLASS_OF_SERVICE_QUOTA:
  146. $service = new ChangePackageCosQuota($this->getApi());
  147. break;
  148. default:
  149. $service = new ChangePackageDedicatedCos($this->getApi());
  150. break;
  151. }
  152. return $service;
  153. }
  154. /**
  155. * update account in panel
  156. *
  157. * @param string $type
  158. * @return UpdateAccount|UpdateAccountCosQuota
  159. */
  160. public function updateAccount($type = ClassOfServices::CUSTOM_ZIMBRA)
  161. {
  162. switch ($type)
  163. {
  164. case ClassOfServices::CUSTOM_ZIMBRA:
  165. $service = new UpdateAccount($this->getApi());
  166. break;
  167. case ClassOfServices::ZIMBRA_CONFIG_OPTIONS:
  168. $service = new UpdateAccount($this->getApi());
  169. break;
  170. case ClassOfServices::CLASS_OF_SERVICE_QUOTA:
  171. $service = new UpdateAccountCosQuota($this->getApi());
  172. break;
  173. default:
  174. $service = new UpdateAccount($this->getApi());
  175. break;
  176. }
  177. return $service;
  178. }
  179. /**
  180. * update account status
  181. *
  182. * @return UpdateAccountStatus
  183. */
  184. public function updateAccountStatus()
  185. {
  186. return new UpdateAccountStatus($this->getApi());
  187. }
  188. /**
  189. * update ressource
  190. *
  191. * @return UpdateRessource
  192. */
  193. public function updateRessource()
  194. {
  195. return new UpdateRessource($this->getApi());
  196. }
  197. /**
  198. * change password service
  199. *
  200. * @return UpdateAccountPassword
  201. */
  202. public function updateAccountPassword()
  203. {
  204. return new UpdateAccountPassword($this->getApi());
  205. }
  206. /**
  207. * distribution (mailing) list update service
  208. *
  209. * @return UpdateDistributionList
  210. */
  211. public function updateDistributionList()
  212. {
  213. return new UpdateDistributionList($this->getApi());
  214. }
  215. /**
  216. * suspend domain in zimbra
  217. *
  218. * @return SuspendDomain
  219. */
  220. public function suspendDomain()
  221. {
  222. return new SuspendDomain($this->getApi());
  223. }
  224. /**
  225. * unsuspend domain
  226. *
  227. * @return UnsuspendDomain
  228. */
  229. public function unsuspendDomain()
  230. {
  231. return new UnsuspendDomain($this->getApi());
  232. }
  233. /**
  234. * delete account in panel
  235. *
  236. * @return DeleteAccount
  237. */
  238. public function deleteAccount()
  239. {
  240. return new DeleteAccount($this->getApi());
  241. }
  242. /**
  243. * delete ressource in panel
  244. *
  245. * @return DeleteRessource
  246. */
  247. public function deleteRessource()
  248. {
  249. return new DeleteRessource($this->getApi());
  250. }
  251. /**
  252. * delete domain & each related things
  253. *
  254. * @return DeleteDomain
  255. */
  256. public function deleteDomain()
  257. {
  258. return new DeleteDomain($this->getApi());
  259. }
  260. /**
  261. * delete account alias
  262. *
  263. * @return DeleteAccountAlias
  264. */
  265. public function deleteAccountAlias()
  266. {
  267. return new DeleteAccountAlias($this->getApi());
  268. }
  269. /**
  270. * delete distribution list (mailing list)
  271. *
  272. * @return DeleteDistributionList
  273. */
  274. public function deleteDistributionList()
  275. {
  276. return new DeleteDistributionList($this->getApi());
  277. }
  278. /**
  279. * delete domain alias
  280. *
  281. * @return DeleteDomainAlias
  282. */
  283. public function deleteDomainAlias()
  284. {
  285. return new DeleteDomainAlias($this->getApi());
  286. }
  287. /**
  288. *
  289. * return sso token
  290. * @return ClientSingleSignOnToken
  291. */
  292. public function clientSingleSignOnToken()
  293. {
  294. return new ClientSingleSignOnToken($this->getApi());
  295. }
  296. }