\n It does not show if these features are properly configured or safe.
\nGet a deeper analysis of the SPF, DKIM, and DMARC configuration at spf.access.nu.
\n `),a+='SPF record found
',a+=`${e[0]}
`;const o=[];e.forEach((e=>{const n=e.match(/include:([^\s]+)/g);n&&o.push(...n)})),o.length>0&&(a+="Includes:
",a+="No SPF record found
'}else a+='No SPF record found
';a+="DKIM records found
',a+="No DKIM records found for common selectors
',a+="This doesn't necessarily mean DKIM isn't configured. The domain might use custom selectors.
"),a+="${e.name} is configured
`);d+=`${e.name} is not configured
`}catch(o){d+=`${e.name} is not configured
`}}));Promise.all(r).then((()=>{a+=d,a+="Checking for potential mail servers
",e.mxHosts&&e.mxHosts.forEach((e=>{isValidHostname(e)&&s.set(e,"MX Record")})),e.spfHosts&&e.spfHosts.forEach((e=>{isValidHostname(e)&&(s.has(e)?s.set(e,s.get(e)+", SPF Record"):s.set(e,"From SPF Record"))}));const t=`autodiscover.${o}`;try{const e=await dnsRequest(t,"A");e.Answer&&e.Answer.length>0&&s.set(t,"This subdomain is used by Exchange Server")}catch(e){}if(e.ipAddresses)for(const o of e.ipAddresses)if(isValidIpAddress(o)){const e=await getPtrRecord(o);e&&isValidHostname(e)&&(s.has(e)?s.set(e,s.get(e)+", SPF Record"):s.set(e,"Reverse DNS for IP "+o+" in SPF Record"))}if(s.size>0){n.innerHTML="Checking for potential mail servers
";const e=[],t=[];for(const[o,n]of s.entries()){const n=testHttpsServer(o).then((n=>{n&&e.push(o)}));t.push(n)}if(await Promise.all(t),e.length>0){let t=`You may want to check if one of the following could be the mailserver for ${o}:
No potential mail servers found for ${o}.
`}async function getPtrRecord(e){try{const o=e.split(".").reverse().join("."),n=await dnsRequest(`${o}.in-addr.arpa`,"PTR");return n.Answer&&n.Answer.length>0?n.Answer[0].data.replace(/\.$/,""):null}catch(e){return null}}function isValidHostname(e){if(!e)return!1;return/^(([a-zA-Z0-9]|[a-zA-Z0-9][a-zA-Z0-9\-]*[a-zA-Z0-9])\.)*([A-Za-z0-9]|[A-Za-z0-9][A-Za-z0-9\-]*[A-Za-z0-9])$/.test(e)}function isValidIpAddress(e){if(!e)return!1;if(!/^(\d{1,3})\.(\d{1,3})\.(\d{1,3})\.(\d{1,3})$/.test(e))return!1;return e.split(".").every((e=>parseInt(e)<=255))}async function testHttpsServer(e){try{const o=new AbortController,n=setTimeout((()=>o.abort()),3e3);await fetch(`https://${e}`,{method:"HEAD",mode:"no-cors",signal:o.signal});return clearTimeout(n),!0}catch(e){return!1}}function copyDirect(){const e=document.getElementById("domain").value.trim(),o=window.location.origin+window.location.pathname+"?domain="+encodeURIComponent(e);navigator.clipboard.writeText(o).then((()=>{const e=document.querySelector("button.access-link-button");e.textContent="Link copied!",setTimeout((()=>{e.textContent="Copy link to this provider check"}),2e3)})).catch((e=>{console.error("Could not copy text: ",e)}))}function copyDirect(){const e=document.getElementById("domain").value.trim(),o=window.location.origin+window.location.pathname+"?domain="+encodeURIComponent(e);navigator.clipboard.writeText(o).then((()=>{const e=document.querySelector("button.access-link-button");e.textContent="Link copied!",setTimeout((()=>{e.textContent="Copy link to this provider check"}),2e3)})).catch((e=>{console.error("Could not copy text: ",e)}))}function getParameterByName(e,o=window.location.href){e=e.replace(/[\[\]]/g,"\\$&");var n=new RegExp("[?&]"+e+"(=([^]*)|&|#|$)").exec(o);return n?n[2]?decodeURIComponent(n[2].replace(/\+/g," ")):"":null}window.onload=function(){const e=getParameterByName("domain");e?(document.getElementById("domain").value=e,checkDomain()):document.getElementById("domain").select()},document.getElementById("domain").addEventListener("keyup",(function(e){"Enter"===e.key&&checkDomain()}))