Accounts.php 6.3 KB

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