kerioEmail_mx.php 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256
  1. <?php
  2. use WHMCS\Database\Capsule;
  3. if (!defined("WHMCS"))
  4. {
  5. die("This file cannot be accessed directly");
  6. }
  7. require_once 'Net/DNS2.php';
  8. const NS1 = '185.163.51.130';
  9. const NS2 = '185.163.51.131';
  10. const MX = 'mail3.seecure.ch';
  11. const SPF = 'v=spf1 mx a:mail3.seecure.ch ip4:185.163.51.0/24 ip4:89.35.78.0/23 ~all';
  12. const DMARC = 'v=DMARC1; p=reject; rua=mailto:technik@thurdata.ch; ruf=mailto:technik@thurdata.ch';
  13. function KerioEmail_ClientAreaCustomButtonArray ($params)
  14. {
  15. return array(
  16. // 'DNS-Settings' => 'DNS',
  17. );
  18. }
  19. function KerioEmail_ClientAreaAllowedFunctions ($params)
  20. {
  21. return array(
  22. 'MX konfigurieren' => 'setMX',
  23. 'SPF konfigurieren' => 'setSPF',
  24. );
  25. }
  26. function KerioEmail_DNS($params)
  27. {
  28. $vars = KerioEmailCheckDNS($params);
  29. return array(
  30. 'breadcrumb' => array(
  31. 'clientarea.php?action=productdetails&id=' . $params['serviceid'] . '&modop=custom&a=DNS' => 'DNS Mail Settings',
  32. ),
  33. 'templatefile' => 'kerioEmail_help_mx',
  34. 'vars' => $vars,
  35. );
  36. }
  37. function KerioEmail_setMX($params)
  38. {
  39. $zoneIDcollection = Capsule::table('dns_manager2_zone')
  40. ->select('id')
  41. ->where('name', '=', $params['domain'])
  42. ->get();
  43. $zoneIDobj = $zoneIDcollection[0];
  44. $zoneID = $zoneIDobj->{'id'};
  45. if(!isset($zoneID)) {
  46. return 'Error: zone ID not found for domain ' . $params['domain'];
  47. }
  48. $dnsZone = localAPI('dnsmanager', array( 'dnsaction' => 'getZone', 'zone_id' => $zoneID));
  49. if($dnsZone['result'] != 'success') {
  50. return 'Error: cloud not fetch zone for ID ' . $zoneID;
  51. }
  52. $zoneRecords = array();
  53. $mxRecord = array(
  54. 'line' => $params['domain'].'.|MX|0',
  55. 'name' => '@',
  56. 'type' => 'MX',
  57. 'class' => 'IN',
  58. 'data' => array(
  59. 'preference' => '10',
  60. 'exchange' => MX,
  61. ),
  62. );
  63. array_push($zoneRecords, $mxRecord);
  64. foreach($dnsZone['data']->records as $record) {
  65. if($record->type != 'MX') {
  66. array_push($zoneRecords, $record);
  67. };
  68. }
  69. $result = localAPI('dnsmanager' ,
  70. array(
  71. 'dnsaction' => 'updateZone',
  72. 'zone_id' => $zoneID,
  73. 'records' => $zoneRecords,
  74. )
  75. );
  76. if($result['result'] != 'success') {
  77. return 'Error: cloud not update zone for ID ' . $zoneID;
  78. }
  79. return 'success';
  80. }
  81. function KerioEmail_setSPF($params)
  82. {
  83. $zoneIDcollection = Capsule::table('dns_manager2_zone')
  84. ->select('id')
  85. ->where('name', '=', $params['domain'])
  86. ->get();
  87. $zoneIDobj = $zoneIDcollection[0];
  88. $zoneID = $zoneIDobj->{'id'};
  89. if(!isset($zoneID)) {
  90. return 'Error: zone ID not found for domain ' . $params['domain'];
  91. }
  92. $dnsZone = localAPI('dnsmanager', array( 'dnsaction' => 'getZone', 'zone_id' => $zoneID));
  93. if($dnsZone['result'] != 'success') {
  94. return 'Error: cloud not fetch zone for ID ' . $zoneID;
  95. }
  96. $zoneRecords = array();
  97. $spfRecord = array(
  98. 'line' => $params['domain'].'.|TXT|0',
  99. 'name' => '@',
  100. 'type' => 'TXT',
  101. 'class' => 'IN',
  102. 'data' => SPF
  103. );
  104. array_push($zoneRecords, $spfRecord);
  105. foreach($dnsZone['data']->records as $record) {
  106. if(!$record->type === 'TXT'){
  107. array_push($zoneRecords, $record);
  108. } elseif (!preg_match('/^v=spf(.*)$/i', trim($record->rdata->txtdata,'"'))) {
  109. array_push($zoneRecords, $record);
  110. };
  111. }
  112. $result = localAPI('dnsmanager' ,
  113. array(
  114. 'dnsaction' => 'updateZone',
  115. 'zone_id' => $zoneID,
  116. 'records' => $zoneRecords,
  117. )
  118. );
  119. if($result['result'] != 'success') {
  120. return 'Error: cloud not update zone for ID ' . $zoneID;
  121. }
  122. return 'success';
  123. }
  124. function KerioEmailCheckDNS($params)
  125. {
  126. unset($zoneID);
  127. unset($mxStatus);
  128. unset($dnsData);
  129. unset($vars);
  130. $vars['maildomain'] = $params['domain'];
  131. $clientDomains = localAPI('GetClientsDomains', array('clientid' => $params['userid']));
  132. $nameserver = array(
  133. NS1,
  134. NS2);
  135. $resolver = new Net_DNS2_Resolver(array('nameservers' => $nameserver));
  136. try {
  137. $result = $resolver->query($params['domain'], 'MX');
  138. } catch(Net_DNS2_Exception $e) {
  139. echo "::query() failed: ", $e->getMessage(), "\n";
  140. }
  141. $domainMX = $result->answer;
  142. try {
  143. $result = $resolver->query($params['domain'], 'TXT');
  144. } catch(Net_DNS2_Exception $e) {
  145. echo "::query() failed: ", $e->getMessage(), "\n";
  146. }
  147. $domainTXT = $result->answer;
  148. $domainSPF = array();
  149. $domainDKIM = array();
  150. $domainDMARC = array();
  151. foreach($domainTXT as $txtRecord) {
  152. foreach($txtRecord->text as $txtData) {
  153. if(strstr($txtData,'v=spf')) {
  154. array_push($domainSPF,$txtData);
  155. }
  156. if(strstr($txtData,'v=DKIM')) {
  157. array_push($domainDKIM,$txtData);
  158. }
  159. if(strstr($txtData,'v=DMARC')) {
  160. array_push($domainDMARC,$txtData);
  161. }
  162. }
  163. }
  164. # self hosted DNS
  165. $vars['selfDNS'] = FALSE;
  166. if(!empty($clientDomains['domains'])) {
  167. for($i=$clientDomains['startnumber'];$i<=$clientDomains['numreturned'];$i++) {
  168. if($params['domain'] == $clientDomains['domains']['domain'][$i]['domainname']) {
  169. $vars['selfDNS'] = TRUE;
  170. $vars['domainId'] = $clientDomains['domains']['domain'][$i]['id'];
  171. }
  172. }
  173. }
  174. # SPF
  175. if (count($domainSPF) > 1) {
  176. $vars['multiSPF'] = TRUE;
  177. } else {
  178. $vars['multiSPF'] = FALSE;
  179. }
  180. $vars['spf'] = 'wrong';
  181. if (empty($domainSPF)) {
  182. $vars['spf'] = 'unset';
  183. } else {
  184. foreach($domainSPF as $spf) {
  185. if($spf === SPF) {
  186. $vars['spf'] = 'set';
  187. }
  188. }
  189. }
  190. $vars['domainSPF'] = $domainSPF;
  191. # DKIM
  192. if (count($domainDKIM) > 1) {
  193. $vars['multiDKIM'] = TRUE;
  194. } else {
  195. $vars['multiDKIM'] = FALSE;
  196. }
  197. if (empty($domainDKIM)) {
  198. $vars['dkim'] = 'unset';
  199. } else {
  200. $vars['dkim'] = 'set';
  201. }
  202. $vars['domainDKIM'] = $domainDKIM;
  203. # DMARC
  204. if (count($domainDMARC) > 1) {
  205. $vars['multiDMARC'] = TRUE;
  206. } else {
  207. $vars['multiDMARC'] = FALSE;
  208. }
  209. $vars['dmarc'] = 'wrong';
  210. if (empty($domainDMARC)) {
  211. $vars['dmarc'] = 'unset';
  212. } else {
  213. foreach($domainDMARC as $dmarc) {
  214. if($dmarc === DMARC) {
  215. $vars['dmarc'] = 'set';
  216. }
  217. }
  218. }
  219. $vars['domainDMARC'] = $domainDMARC;
  220. # MX
  221. if(count($domainMX) > 1) {
  222. $vars['multiMX'] = TRUE;
  223. } else {
  224. $vars['multiMX'] = FALSE;
  225. }
  226. if(empty($domainMX)){
  227. $vars['mx'] = 'unset';
  228. $vars['mxtarget'] = MX;
  229. } else {
  230. $vars['domainMX'] = $domainMX;
  231. $domainMXrecord = array_shift($domainMX);
  232. $vars['mxtarget'] = $domainMXrecord->exchange;
  233. if($domainMXrecord->exchange == MX) {
  234. $vars['mx'] = 'set';
  235. } else {
  236. $var['mx'] = 'wrong';
  237. }
  238. }
  239. return $vars;
  240. }