ufoscan.py 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-"
  3. """
  4. UFONet - Denial of Service Toolkit - 2018 - by psy (epsylon@riseup.net)
  5. You should have received a copy of the GNU General Public License along
  6. with UFONet; if not, write to the Free Software Foundation, Inc., 51
  7. Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
  8. """
  9. import sys, time, urlparse
  10. try:
  11. from scapy.all import *
  12. except:
  13. print "\nError importing: scapy lib. \n\n To install it on Debian based systems:\n\n $ 'sudo apt-get install python-scapy' or 'pip install scapy'\n"
  14. sys.exit(2)
  15. # UFONet port scanner (UFOSCAN) class
  16. def randInt():
  17. x = random.randint(1,65535) # TCP ports
  18. return x
  19. def scan(self, ip, port, openp, closed):
  20. src_port = RandShort()
  21. seq = randInt()
  22. window = randInt()
  23. p = IP(dst=ip)/TCP(sport=src_port, dport=port, seq=seq, window=window, flags='S')
  24. resp = sr1(p, timeout=2)
  25. if str(type(resp)) == "<type 'NoneType'>":
  26. closed = closed + 1
  27. elif resp.haslayer(TCP):
  28. if resp.getlayer(TCP).flags == 0x12:
  29. send_rst = sr(IP(dst=ip)/TCP(sport=src_port, dport=port, flags='AR'), timeout=1)
  30. openp.append(port) # open port found!
  31. print "\n" + "="*54
  32. print "[Info] [AI] [UFOSCAN] OPEN port found! [ " + str(port) + " ]"
  33. print "="*54 + "\n"
  34. elif resp.getlayer(TCP).flags == 0x14:
  35. closed = closed + 1
  36. return openp, closed
  37. def is_up(ip):
  38. p = IP(dst=ip)/ICMP()
  39. resp = sr1(p, timeout=10)
  40. if resp == None:
  41. return False
  42. elif resp.haslayer(ICMP):
  43. return True
  44. class UFOSCAN(object):
  45. def scanning(self, target, portX, portY):
  46. print "[Info] [AI] [UFOSCAN] Emitting X-Ray into range: [ "+str(portX)+"-"+str(portY)+" ]\n"
  47. print "="*74, "\n"
  48. if target.startswith('http://'):
  49. target = target.replace('http://','')
  50. elif target.startswith('https://'):
  51. target = target.replace('https://','')
  52. else:
  53. print "[Error] [AI] [UFOSCAN] Target url not valid ("+target+")! -> It should starts with 'http(s)://'\n"
  54. return
  55. try:
  56. ip = socket.gethostbyname(target)
  57. except:
  58. try:
  59. import dns.resolver
  60. r = dns.resolver.Resolver()
  61. r.nameservers = ['8.8.8.8', '8.8.4.4'] # google DNS resolvers
  62. url = urlparse(target)
  63. a = r.query(url.netloc, "A") # A record
  64. for rd in a:
  65. ip = str(rd)
  66. except:
  67. ip = target
  68. if ip == "127.0.0.1" or ip == "localhost":
  69. print "[Info] [AI] [UFOSCAN] Sending message '1/0 %====D 2 Ur ;-0' to 'localhost' -> [OK!]\n"
  70. return
  71. start_time = time.time()
  72. try:
  73. ports = range(int(portX), int(portY+1))
  74. except:
  75. portX = 1
  76. portY = 1024 # 1024
  77. print "[Info] [AI] [UFOSCAN] Not any range of ports selected. Using by default: [ 1-1024 ]\n"
  78. ports = range(int(portX), int(portY+1))
  79. portX = str(portX)
  80. portY = str(portY+1)
  81. if is_up(ip):
  82. openp = []
  83. closed = 0
  84. print "\n" + "="*44
  85. print "[Info] [AI] [UFOSCAN] Host %s is UP!" % ip
  86. print "="*44
  87. print "-"*22
  88. for port in ports:
  89. openp, closed = scan(self, ip, port, openp, closed)
  90. duration = time.time()-start_time
  91. print "-"*22
  92. print "="*44, "\n"
  93. print "[Info] [AI] [UFOSCAN] Scan completed in: [ %s ]" % duration
  94. if closed == len(ports):
  95. print "\n[Info] [AI] [UFOSCAN] [ %s/%d ] CLOSED ports. -> [Exiting!]\n" % (closed, len(ports)-1)
  96. else:
  97. print "\n[Info] [AI] [UFOSCAN] [ %s/%d ] OPEN ports FOUND!\n" % (len(openp), len(ports)-1)
  98. print " [-] Target: [ " + str(ip) + " ]\n"
  99. for o in openp:
  100. print " [+] OPEN PORT: [ " + str(o) + " ]"
  101. print ""
  102. else:
  103. duration = time.time()-start_time
  104. print "-"*22
  105. print "="*44, "\n"
  106. print "[Info] [AI] [UFOSCAN] Host %s is DOWN!" % ip
  107. print "\n[Info] [AI] [UFOSCAN] Scan completed in: [ %s ]" % duration + "\n"