Settings.php 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. <?php
  2. namespace ThurData\Servers\KerioEmail\App\UI\Client\Setting\Pages;
  3. use ThurData\Servers\KerioEmail\App\UI\Admin\Custom\Fields\EnabledField;
  4. use ThurData\Servers\KerioEmail\App\UI\Client\Setting\Buttons\EditSettingButton;
  5. use function ThurData\Servers\KerioEmail\Core\Helper\di;
  6. use ThurData\Servers\KerioEmail\Core\UI\Widget\DataTable\Column;
  7. use ThurData\Servers\KerioEmail\Core\UI\Widget\DataTable\DataProviders\DataProvider;
  8. use ThurData\Servers\KerioEmail\Core\UI\Interfaces\ClientArea;
  9. use ThurData\Servers\KerioEmail\Core\UI\Widget\DataTable\DataProviders\Providers\ArrayDataProvider;
  10. use ThurData\Servers\KerioEmail\Core\UI\Widget\DataTable\DataTable;
  11. use ThurData\Servers\KerioEmail\Api\KerioWhmcs;
  12. use ThurData\Servers\KerioEmail\App\Libs\Product\ProductManager;
  13. use ThurData\Servers\KerioEmail\Core\Helper\DnsHelper;
  14. /**
  15. *
  16. * Created by PhpStorm.
  17. * User: ThurData
  18. * Date: 10.09.19
  19. * Time: 10:51
  20. * Class Setting
  21. */
  22. class Settings extends DataTable implements ClientArea
  23. {
  24. use \ThurData\Servers\KerioEmail\Core\UI\Traits\DisableButtonByColumnValue;
  25. /**
  26. * labels for statuses
  27. */
  28. const STATUS_LABEL = [
  29. 'active' => 'success',
  30. 'inactive' => 'success',
  31. 'default' => 'default'
  32. ];
  33. protected $id = 'Setting';
  34. protected $name = 'Setting';
  35. protected $title = null;
  36. /**
  37. * load columns
  38. */
  39. protected function loadHtml()
  40. {
  41. $this
  42. ->addColumn((new Column('domain'))
  43. ->setOrderable(DataProvider::SORT_ASC)
  44. ->setSearchable(true, Column::TYPE_STRING))
  45. ->addColumn((new Column('mxactive'))
  46. ->setOrderable()
  47. ->setSearchable(true, Column::TYPE_STRING))
  48. ->addColumn((new Column('spf'))
  49. ->setOrderable()
  50. ->setSearchable(true, Column::TYPE_STRING))
  51. ->addColumn((new Column('dmarc'))
  52. ->setOrderable()
  53. ->setSearchable(true, Column::TYPE_STRING))
  54. ->addColumn((new Column('dkim'))
  55. ->setOrderable()
  56. ->setSearchable(true))
  57. ->addColumn((new Column('selfdns'))
  58. ->setOrderable()
  59. ->setSearchable(true))
  60. ->addColumn((new Column('selfdomain'))
  61. ->setOrderable()
  62. ->setSearchable(true))
  63. ;
  64. }
  65. /**
  66. * @param $key
  67. * @param $row
  68. * @return mixed
  69. */
  70. public function replaceFieldSelfdns($key, $row)
  71. {
  72. $status = self::STATUS_LABEL[$row[$key]] ? self::STATUS_LABEL[$row[$key]] : self::STATUS_LABEL['default'];
  73. $label = di('lang')->absoluteT('kerio','account','status',$row[$key]);
  74. $field = new EnabledField();
  75. $field->setRawType($status);
  76. $field->setRawTitle($label);
  77. return $field->getHtml();
  78. }
  79. /**
  80. * @param $key
  81. * @param $row
  82. * @return mixed
  83. */
  84. public function replaceFieldMxactive($key, $row)
  85. {
  86. $status = self::STATUS_LABEL[$row[$key]] ? self::STATUS_LABEL[$row[$key]] : self::STATUS_LABEL['default'];
  87. $label = di('lang')->absoluteT('kerio','account','status',$row[$key]);
  88. $field = new EnabledField();
  89. $field->setRawType($status);
  90. $field->setRawTitle($label);
  91. return $field->getHtml();
  92. }
  93. /**
  94. * @param $key
  95. * @param $row
  96. * @return mixed
  97. */
  98. public function replaceFieldLast_login($key, $row)
  99. {
  100. return $row[$key] ? $row[$key] : '-';
  101. }
  102. /**
  103. * @param $key
  104. * @param $row
  105. * @return mixed
  106. */
  107. public function replaceFieldType($key, $row)
  108. {
  109. // return $row[$key] == 'Room' ? di('lang')->absoluteT('kerio','setting','type','location') : di('lang')->absoluteT('kerio','setting','type','equipment');
  110. }
  111. /**
  112. * load buttons
  113. */
  114. public function initContent()
  115. {
  116. $this->addActionButton(new EditSettingButton());
  117. }
  118. /**
  119. * load data
  120. */
  121. public function loadData()
  122. {
  123. $maildomain = $this->getWhmcsParamByKey('domain');
  124. $api = new KerioWhmcs('whmcsKerioEmail', 'Thurdata', '1.0');
  125. try {
  126. $api->login($this->getWhmcsParamByKey('serverhostname'), $this->getWhmcsParamByKey('serverusername'), $this->getWhmcsParamByKey('serverpassword'));
  127. $domains = $api->getDomains(['id','name','aliasList']);
  128. $dkimSet = $api->getDkimDnsRecord($maildomain);
  129. } catch (KerioApiException $error) {
  130. logModuleCall(
  131. 'kerioEmail',
  132. __FUNCTION__,
  133. $error,
  134. 'Debug Error',
  135. $error->getMessage()
  136. );
  137. return ['error' => $error->getMessage()];
  138. }
  139. foreach($domains as $domain) {
  140. if(($domain['name']) === $maildomain){
  141. $aliasList = $domain['aliasList'];
  142. }
  143. }
  144. $api->logout();
  145. $domains = [$maildomain];
  146. foreach($aliasList as $aliasDomain){
  147. array_push($domains,$aliasDomain);
  148. }
  149. // format dkim response
  150. $dkimArray = explode(PHP_EOL,$dkimSet['detail']);
  151. $dkimValue = explode(":",$dkimArray[1]);
  152. $this->domainKey = ltrim($dkimValue[1]);
  153. $dkimName = explode(":",$dkimArray[0]);
  154. $this->dkimName = ltrim($dkimName[1]);
  155. // get settings from product configuration
  156. $productManager = new ProductManager();
  157. $productManager->loadById($this->getWhmcsParamByKey('pid'));
  158. $this->spfConfig = $productManager->get('spf_string');
  159. $this->dmarcConfig = $productManager->get('dmarc_string');
  160. $clientDomains = localAPI('GetClientsDomains', array('clientid' => $params['userid']));
  161. $dns = new DnsHelper();
  162. /**
  163. * format model to array
  164. */
  165. $data = [];
  166. foreach($domains as $domain){
  167. in_array($domain,$clientDomains) ? $selfdomain = 'active' : $selfdomain = 'inactive';
  168. $selfDns = 'inactive';
  169. $dnsRecords = $dns->getRecords($domain);
  170. $dnsRecords['selfdns'] ? $selfDns = 'active' : $selfDns = 'inactive';
  171. in_array($params['serverhostname'],$dnsRecords['mx']) ? $mx = 'active' : $mx = 'inactive';
  172. $spf = 'inactive';
  173. if(!empty($dnsRecords['spf']) && !(count($dnsRecords['spf']) > 1)) {
  174. if($dnsRecords['spf'][0] === $this->spfConfig){
  175. $spf = 'active';
  176. }
  177. }
  178. $dmarc = 'inactive';
  179. if(!empty($dnsRecords['dmarc']) && !(count($dnsRecords['dmarc']) > 1)) {
  180. if($dnsRecords['dmarc'][0] === $this->dmarcConfig){
  181. $spf = 'active';
  182. }
  183. }
  184. $dkim = 'inactive';
  185. in_array($this->domainKey, $dnsRecords['dkim']) ? $dkim = 'active' : $dkim = 'inactive';
  186. $tmp = [
  187. 'domain' => $domain,
  188. 'mxactive' => $mx,
  189. 'spf' => $spf,
  190. 'dmarc' => $dmarc,
  191. 'dkim' => $dkim,
  192. 'selfdns' => $selfDns,
  193. 'selfdomain' => $selfdomain
  194. ];
  195. $data[] = $tmp;
  196. }
  197. $dataProv = new ArrayDataProvider();
  198. $dataProv->setDefaultSorting('setting', 'ASC')->setData($data);
  199. $this->setDataProvider($dataProv);
  200. $this->setDisableByColumnValue('selfdns', 'inactive');
  201. }
  202. }