-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathspoofable.py
executable file
·84 lines (76 loc) · 2.57 KB
/
spoofable.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
#!/usr/bin/env python
# Author: Brandon Rossi
# 2/24/2020
# Domains are spoofable if any of the following conditions are met:
# Lack of SPF Record
# Lack of DMARC Record
# SPF Record does not specify ~all or -all
# DMARC policy is set to p=none
# DMARC policy is nonexistant
import dns.resolver
import re
import sys
from colorama import Fore, init, Style
def getSPF(resolver, domain):
spfRegex = re.compile("^\"(v=spf1).*\"$")
try:
answer = resolver.query(domain, 'txt')
for item in answer.response.answer:
for line in item.items:
if spfRegex.match(line.to_text()):
return str(line)
except dns.resolver.NoAnswer:
return False
def getDMARC(resolver, domain):
spfRegex = re.compile("^\"(v=DMARC).*\"$")
try:
answer = resolver.query("_dmarc." + domain, 'txt')
for item in answer.response.answer:
for line in item.items:
if spfRegex.match(line.to_text()):
return str(line)
except (dns.resolver.NoAnswer, dns.resolver.NXDOMAIN) as e:
return False
def main():
domain = sys.argv[1]
resolver = dns.resolver.Resolver()
spfRecord = getSPF(resolver, domain)
spoofable = False
if spfRecord:
spfRecord = spfRecord.strip('"')
print("[" + Fore.BLUE + "X" + Style.RESET_ALL + "] SPF record found: ")
print(spfRecord)
if "~all" not in spfRecord and "-all" not in spfRecord:
print("[" + Fore.GREEN + "+" + Style.RESET_ALL + "] " + domain + " does not contain \"-all\" or \"~all\" in the SPF record.")
spoofable = True
else:
print("[" + Fore.GREEN + "+" + Style.RESET_ALL + "] SPF record not found for " + domain)
spoofable = True
dmarcRecord = getDMARC(resolver, domain)
dmarcTagRegex = r";\s*p=([^;]*)\s*;"
dmarcTagMatch = None
if dmarcRecord:
dmarcRecord = dmarcRecord.strip('"')
dmarcTagMatch = re.search(dmarcTagRegex, dmarcRecord)
dmarcTag = None
if dmarcTagMatch:
dmarcTag = dmarcTagMatch.group(1)
if dmarcRecord:
print("[" + Fore.BLUE + "X" + Style.RESET_ALL + "] DMARC record found: ")
print(dmarcRecord)
if not dmarcTagMatch:
print("[" + Fore.GREEN + "+" + Style.RESET_ALL + "] " + domain + " does not have a policy set in the DMARC record.")
spoofable = True
elif dmarcTag == "none":
print("[" + Fore.GREEN + "+" + Style.RESET_ALL + "] " + domain + " has policy set to \"none\" in the DMARC record.")
spoofable = True
else:
print("[" + Fore.GREEN + "+" + Style.RESET_ALL + "] DMARC record not found for " + domain)
spoofable = True
if spoofable:
print("\n" + Fore.GREEN + domain + " is spoofable.")
else:
print("\n" + Fore.RED + domain + " is NOT spoofable.")
if __name__== "__main__":
init(autoreset=True)
main()