ufoscan.py 4.5 KB

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