Accounts.php 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  1. <?php
  2. namespace ThurData\Servers\KerioEmail\App\UI\Client\EmailAccount\Pages;
  3. use ThurData\Servers\KerioEmail\App\Helpers\BuildUrlExtended;
  4. use ThurData\Servers\KerioEmail\App\Helpers\KerioManager;
  5. use ThurData\Servers\KerioEmail\App\Libs\Product\ProductManager;
  6. use ThurData\Servers\KerioEmail\App\Libs\Kerio\Components\Api\Soap\Connection;
  7. use ThurData\Servers\KerioEmail\App\Libs\Kerio\Components\Api\Soap\Helpers\AccountHelper;
  8. use ThurData\Servers\KerioEmail\App\Libs\Kerio\Components\Api\Soap\Models\Account;
  9. use ThurData\Servers\KerioEmail\App\Libs\Kerio\Components\Api\Soap\Repository\ClassOfServices;
  10. use ThurData\Servers\KerioEmail\App\Libs\Kerio\Components\Filters\EmailAccounts\FilterByCosId;
  11. use ThurData\Servers\KerioEmail\App\UI\Admin\Custom\Fields\EnabledField;
  12. use ThurData\Servers\KerioEmail\App\UI\Client\EmailAccount\Buttons\AddAccountButton;
  13. use ThurData\Servers\KerioEmail\App\UI\Client\EmailAccount\Buttons\ChangePasswordButton;
  14. use ThurData\Servers\KerioEmail\App\UI\Client\EmailAccount\Buttons\ChangeStatusButton;
  15. use ThurData\Servers\KerioEmail\App\UI\Client\EmailAccount\Buttons\DeleteAccountButton;
  16. use ThurData\Servers\KerioEmail\App\UI\Client\EmailAccount\Buttons\EditAccountButton;
  17. use ThurData\Servers\KerioEmail\App\UI\Client\EmailAccount\Buttons\LoginToPanelButton;
  18. use ThurData\Servers\KerioEmail\App\UI\Client\EmailAccount\Buttons\MassChangeStatusButton;
  19. use ThurData\Servers\KerioEmail\App\UI\Client\EmailAccount\Buttons\MassDeleteAccountButton;
  20. use ThurData\Servers\KerioEmail\App\UI\Client\EmailAccount\Buttons\SpanDropdownButton;
  21. use function ThurData\Servers\KerioEmail\Core\Helper\di;
  22. use ThurData\Servers\KerioEmail\Core\Models\Whmcs\Hosting;
  23. use ThurData\Servers\KerioEmail\Core\UI\Widget\Buttons\DropdawnButtonWrappers\ButtonDropdown;
  24. use ThurData\Servers\KerioEmail\Core\UI\Widget\DataTable\Column;
  25. use ThurData\Servers\KerioEmail\Core\UI\Widget\DataTable\DataProviders\DataProvider;
  26. use ThurData\Servers\KerioEmail\Core\UI\Interfaces\ClientArea;
  27. use ThurData\Servers\KerioEmail\Core\UI\Widget\DataTable\DataProviders\Providers\ArrayDataProvider;
  28. use ThurData\Servers\KerioEmail\Core\UI\Widget\DataTable\DataTable;
  29. use ThurData\Servers\KerioEmail\Api\KerioWhmcs;
  30. /**
  31. *
  32. * Created by PhpStorm.
  33. * User: ThurData
  34. * Date: 10.09.19
  35. * Time: 10:51
  36. * Class Accounts
  37. */
  38. class Accounts extends DataTable implements ClientArea
  39. {
  40. /**
  41. * labels for statuses
  42. */
  43. const STATUS_LABEL = [
  44. 'active' => 'success',
  45. 'locked' => 'default',
  46. 'maintenance' => 'warning',
  47. 'closed' => 'default',
  48. 'lockout' => 'info',
  49. 'pending' => 'warning',
  50. 'default' => 'default'
  51. ];
  52. protected $id = 'accounts';
  53. protected $name = 'accounts';
  54. protected $title = null;
  55. /**
  56. * load columns
  57. */
  58. protected function loadHtml()
  59. {
  60. $this
  61. ->addColumn((new Column('mailbox'))
  62. ->setOrderable(DataProvider::SORT_ASC)
  63. ->setSearchable(true, Column::TYPE_STRING))
  64. ->addColumn((new Column('last_login'))
  65. ->setOrderable()
  66. ->setSearchable(true))
  67. ->addColumn((new Column('size'))
  68. ->setOrderable()
  69. ->setSearchable(true, Column::TYPE_INT))
  70. ->addColumn((new Column('quota'))
  71. ->setOrderable()
  72. ->setSearchable(true, Column::TYPE_INT))
  73. ->addColumn((new Column('status'))
  74. ->setOrderable()
  75. ->setSearchable(true));
  76. }
  77. /**
  78. * @param $key
  79. * @param $row
  80. * @return mixed
  81. */
  82. public function replaceFieldStatus($key, $row)
  83. {
  84. $status = self::STATUS_LABEL[$row[$key]] ? self::STATUS_LABEL[$row[$key]] : self::STATUS_LABEL['default'];
  85. $label = di('lang')->absoluteT('kerio','account','status',$row[$key]);
  86. $field = new EnabledField();
  87. $field->setRawType($status);
  88. $field->setRawTitle($label);
  89. return $field->getHtml();
  90. }
  91. /**
  92. * @param $key
  93. * @param $row
  94. * @return mixed
  95. */
  96. public function replaceFieldLast_login($key, $row)
  97. {
  98. return $row[$key] ? $row[$key] : '-';
  99. }
  100. /**
  101. * load buttons
  102. */
  103. public function initContent()
  104. {
  105. $productManager = new ProductManager();
  106. $productManager->loadByHostingId($this->getRequestValue('id'));
  107. $this->addMassActionButton(new MassChangeStatusButton());
  108. $this->addMassActionButton(new MassDeleteAccountButton());
  109. $this->addButton(new AddAccountButton());
  110. $this->addActionButton(new EditAccountButton());
  111. $this->addActionButton(new DeleteAccountButton());
  112. $actions = new SpanDropdownButton('actions');
  113. $actions->addButton(new ChangeStatusButton());
  114. $actions->addButton(new ChangePasswordButton());
  115. $this->addActionButton($actions);
  116. }
  117. /**
  118. * load data
  119. */
  120. public function loadData()
  121. {
  122. /**
  123. * load hosting
  124. */
  125. $hosting = Hosting::where('id', $this->getRequestValue('id'))->first();
  126. $api = new KerioWhmcs('whmcsKerioEmail', 'Thurdata', '1.0');
  127. try {
  128. $api->login($this->getWhmcsParamByKey('serverhostname'), $this->getWhmcsParamByKey('serverusername'), $this->getWhmcsParamByKey('serverpassword'));
  129. $domains = $api->getDomains(['id','name']);
  130. } catch (KerioApiException $error) {
  131. logModuleCall(
  132. 'kerioEmail',
  133. __FUNCTION__,
  134. $error,
  135. 'Debug Error',
  136. $error->getMessage()
  137. );
  138. return ['error' => $error->getMessage()];
  139. }
  140. foreach($domains as $maildomain) {
  141. if(($maildomain['name']) === $this->getWhmcsParamByKey('domain')){
  142. $this->maildomainID = $maildomain['id'];
  143. $this->maildomain = $maildomain['name'];
  144. }
  145. }
  146. $productManager = new ProductManager();
  147. $productManager->loadByHostingId($hosting->id);
  148. $fields = array(
  149. "id",
  150. "loginName",
  151. "isEnabled",
  152. "diskSizeLimit",
  153. "consumedSize",
  154. "lastLoginInfo");
  155. try {
  156. $accounts = $api->getUsers($fields,$this->maildomainID);
  157. } catch (KerioApiException $error) {
  158. logModuleCall(
  159. 'kerioEmail',
  160. __FUNCTION__,
  161. $error,
  162. 'Debug Error',
  163. $error->getMessage()
  164. );
  165. return ['error' => $error->getMessage()];
  166. }
  167. $api->logout();
  168. $data = [];
  169. foreach ($accounts as $account)
  170. {
  171. $accountArray = [
  172. 'id' => $account['id'],
  173. 'mailbox' => $account['loginName'] . '@' . $this->maildomain,
  174. 'last_login' => AccountHelper::getFormattedData($account['lastLoginInfo']['dateTime'], 'd/m/Y H:i'),
  175. 'size' => AccountHelper::getQuotaAsMb($account['consumedSize']['value'],$account['consumedSize']['unit']),
  176. 'quota' => $account['diskSizeLimit']['isActive'] ? AccountHelper::getQuotaAsMb($account['diskSizeLimit']['limit']['value'],$account['diskSizeLimit']['limit']['units']) : '∞',
  177. 'status' => $account['isEnabled'] ? 'active' : 'default',
  178. ];
  179. $data[] = $accountArray;
  180. }
  181. $dataProv = new ArrayDataProvider();
  182. $dataProv->setDefaultSorting('mailbox', 'ASC')->setData($data);
  183. $this->setDataProvider($dataProv);
  184. }
  185. }