Skip to content

HI6Cypher/HI6ToolKit

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

71 Commits
 
 
 
 
 
 
 
 

Repository files navigation

HI6ToolKit :|

Classes :

from hi6toolkit import Sniff, DoS_SYN, HTTP_Request, Tunnel

Usage :

  • raw code :

    https://raw.githubusercontent.com/HI6Cypher/HI6ToolKit/main/hi6toolkit.py

  • To Sniff packets :

    python hi6toolkit.py sniff -if [interface(like wlo1, eth0 etc.)] -t [to tmp in file]
  • Example of a Ethernet frame with arp type

        [+][DATALINK]________________1726738881________________
    
        Ethernet Frame :
                Source MAC : 55:c7:42:f7:aa:d3
                Destination MAC : ee:5d:47:fe:ab:11
                Ethernet Type : ARP
    
        Arp Datagram :
                Hardware Type : Ethernet(1)
                Protocol Type : IPv4
                Hardware Length : 6
                Protocol Length : 4
                Opcode : ARP REQ
                Sender Hardware Address : 55:c7:42:f7:aa:d3
                Sender Protocol Address : 192.168.53.1
                Target Hardware Address : 00:00:00:00:00:00
                Target Protocol Address : 192.168.53.240
    
    
    
  • Example of a Ethernet frame with IPv4 type and tcp protocol

        [+][DATALINK]________________1726751606________________
    
        Ethernet Frame :
                Source MAC : cc:47:40:fc:7b:05
                Destination MAC : 74:a5:28:cd:d5:d3
                Ethernet Type : IPv4
    
        IPv4 Datagram :
                Version : 4  Header Length : 20  Time of Service : 0
                Total Length : 389  Identification : 59656  Flags : 2
                Fragment Offset : 0  TTL : 64  Protocol : TCP
                Checksum : 0x6f49  Source : 192.168.53.240  Destination : 54.171.166.213
    
        TCP Segment :
                Source Port : 35448
                Destination Port : 80
                Sequence : 1270847567
                Acknowledgment : 1039940062
                Data Offset : 32
                Flags :
                    URG:0  ACK:1  PSH:1
                    RST:0  SYN:0  FIN:0
                Window : 502
                Checksum : 0x8e62
                Urgent Pointer : 0
                Raw Data :
                    GET / HTTP/1.1\r\nHost: skip.com\r\nUser-Agent: Mozilla/5.0
                     (X11; Linux x86_64; rv:109.0) Gecko/20100101 Firefox/115.0\r\nA
                    ccept: text/html,application/xhtml+xml,application/xml;q=0.9,ima
                    ge/avif,image/webp,*/*;q=0.8\r\nAccept-Language: en-US,en;q=0.5\
                    r\nAccept-Encoding: gzip, deflate\r\nConnection: keep-alive\r\nU
                    pgrade-Insecure-Requests: 1\r\n\r\n
    
  • To use Sniff class :

    from hi6toolkit import Sniff
    
    raw_packets = list()
    sniff = Sniff(iface = "wlo1", parse = True, tmp = True, saddr = None, daddr = None) # use ifconfig or socket.if_nameindex() to list your interfaces (or whatever method u want)
    for parsed_packet, raw_packet in sniff :
        raw_packets.append(raw_packet)
        print(packet)
  • To launch a DoS attack(SYN FLOOD) :

    python hi6toolkit.py dos -x [host] -p [port] -r [rate]
  • Example of SYN flood to (127.0.0.1) :

    
    
            [System] : [LINUX, Thu Aug 29 21:31:07 2024]
            [Hostname] : [hi6cypher]
            [Python] : [Cpython 3.11]
    
            [GitHub] : [github.com/HI6Cypher]
            [Email] : [[email protected]]
    
    
    
    Press ENTER to continue...
    
    [+] //////////////////////////////// [4096/4096]
    [+] all SYN segments have sent
    [+] 0.71s
    
    
  • To sending HTTP request :

    python hi6toolkit.py http -x [host] -p [port/default=80] -e [endpoint/default="/"] -s(for https/be sure u change port(changing default value))
  • To receiving file(Tunnel) : u can use curl or whatever u want to upload file(note that the request http header must indicate Content-Length value)

    python hi6toolkit.py tunnel -x [host/default=0.0.0.0] -p [port/default=80] -t [timeout/default=60] -b [buffer/default=2048]
  • To print some information :

    python hi6toolkit.py info
  • Note : HI6ToolKit is a script, but it can use as module

    from hi6toolkit import HTTP_Request
    
    serv = "www.example.com"
    
    http = HTTP_Request(host = serv, port = 80, method = "GET", header = None, end = "/", https = False)
    http.request() # Note that this class doesn't implement appropriate data parsing algorithm!!!!!!, it is useful for RESTful APIs
    # Note that you can deploy your custom http-header in header argument
    
    print(http.request_header, http.response_header, "\n\n", http.response)
    #output
    
    GET / HTTP/1.1
    Host: www.example.com
    User-Agent: HI6ToolKit
    Accept: */*
    Connection: close
    
    HTTP/1.1 200 OK
    Accept-Ranges: bytes
    Age: 315458
    Cache-Control: max-age=604800
    Content-Type: text/html; charset=UTF-8
    Date: Mon, 03 Jun 2024 10:19:22 GMT
    Etag: "3147526947+gzip"
    Expires: Mon, 10 Jun 2024 10:19:22 GMT
    Last-Modified: Thu, 17 Oct 2019 07:18:26 GMT
    Server: ECAcc (dcd/7D4F)
    Vary: Accept-Encoding
    X-Cache: HIT
    Content-Length: 1256
    Connection: close
    
     <!doctype html>
    <html>
    <head>
        <title>Example Domain</title>
    
        <meta charset="utf-8" />
        <meta http-equiv="Content-type" content="text/html; charset=utf-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1" />
        <style type="text/css">
        body {
            background-color: #f0f0f2;
            margin: 0;
            padding: 0;
            font-family: -apple-system, system-ui, BlinkMacSystemFont, "Segoe UI", "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;
    
        }
        div {
            width: 600px;
            margin: 5em auto;
            padding: 2em;
            background-color: #fdfdff;
            border-radius: 0.5em;
            box-shadow: 2px 3px 7px 2px rgba(0,0,0,0.02);
        }
        a:link, a:visited {
            color: #38488f;
            text-decoration: none;
        }
        @media (max-width: 700px) {
            div {
                margin: 0 auto;
                width: auto;
            }
        }
        </style>
    </head>
    
    <body>
    <div>
        <h1>Example Domain</h1>
        <p>This domain is for use in illustrative examples in documents. You may use this
        domain in literature without prior coordination or asking for permission.</p>
        <p><a href="https://www.iana.org/domains/example">More information...</a></p>
    </div>
    </body>
    </html>
  • Exception :

    HTTP_Request : Note that this class doesn't implement appropriate data parsing algorithm!!!!!!, it is useful for RESTful APIs

    To send TCP/IP packet we need raw socket with socket.IPPROTO_TCP that we have limitations :\ on raw socket in some Windows versions(7, XP, Vista, ,...) to more information visit Site

    so because of many incompatibility i limited hi6toolkit.py to use non-windows OS hi6toolkit has been tested on Linux & Unix(unix-based like darwin)

    for Sniff, DoS_SYN and Tunnel u have to have root access:).

GitHub : github.com/HI6Cypher :)

Email : [email protected] :)

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages