diff --git a/proxyfuzz.py.txt b/proxyfuzz.py.txt
deleted file mode 100644
index 1023586..0000000
--- a/proxyfuzz.py.txt
+++ /dev/null
@@ -1,244 +0,0 @@
-#!/usr/bin/python2
-# Proxyfuzz - On the fly TCP and UDP network fuzzer
-# Copyright (C) 2011 Rodrigo Marcos
-#
-# This program is free software: you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation, either version 3 of the License, or
-# (at your option) any later version.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program. If not, see .
-#
-# Proxyfuzz: a TCP and UDP proxy man-in-the-middle fuzzer
-# v 0.1
-# By Rodrigo Marcos
-# http://www.secforce.co.uk
-
-from twisted.protocols import portforward
-from twisted.internet.protocol import DatagramProtocol
-from twisted.internet import reactor
-import getopt, sys
-from random import randint
-
-
-# UDP Proxy stuff
-
-class Client(DatagramProtocol):
- def __init__(self, server, host, port):
- self.server = server
- self.host = host
- self.port = port
-
- def startProtocol(self):
- self.transport.connect(desthost, destport)
-
- def datagramReceived(self, data, (host, port)):
- global verbose
- global notuntil
- global request
- global testclient
-
- if testclient:
- if request < notuntil:
- request = request + 1
- else:
- data = fuzz(data)
- if verbose:
- print "Server ------> Client"
- print "%r" % data
-
- self.server.transport.write(data, (self.host, self.port))
-
-class Server(DatagramProtocol):
- client = None
-
- def datagramReceived(self, data, (host, port)):
- if not self.client or self.client.host != host or self.client.port != port:
- self.client = Client(self, host, port)
- reactor.listenUDP(0, self.client)
-
- global verbose
- global notuntil
- global request
- global testserver
-
- if testserver:
- if request < notuntil:
- request = request + 1
- else:
- data = fuzz(data)
- if verbose:
- print "Client ------> Server"
- print "%r" % data
- self.client.transport.write(data, (desthost, destport))
-
-# TCP proxy stuff
-
-def server_dataReceived(self, data):
- global verbose
- global notuntil
- global request
- global testserver
-
- if testserver:
- if request < notuntil:
- request = request + 1
- else:
- data = fuzz(data)
-
- if verbose:
- print "Client ------> server"
- print "%r" % data
-
- portforward.Proxy.dataReceived(self, data)
-
-portforward.ProxyServer.dataReceived = server_dataReceived
-
-def client_dataReceived(self, data):
- global verbose
- global notuntil
- global request
- global testclient
-
- if testclient:
- if request < notuntil:
- request = request + 1
- else:
- data = fuzz(data)
- if verbose:
- print "Server ------> Client"
- print "%r" % data
-
- portforward.Proxy.dataReceived(self, data)
-
-portforward.ProxyClient.dataReceived = client_dataReceived
-
-
-overflowstrings = ["A" * 255, "A" * 256, "A" * 257, "A" * 420, "A" * 511, "A" * 512, "A" * 1023, "A" * 1024, "A" * 2047, "A" * 2048, "A" * 4096, "A" * 4097, "A" * 5000, "A" * 10000, "A" * 20000, "A" * 32762, "A" * 32763, "A" * 32764, "A" * 32765, "A" * 32766, "A" * 32767, "A" * 32768, "A" * 65534, "A" * 65535, "A" * 65536, "%x" * 1024, "%n" * 1025 , "%s" * 2048, "%s%n%x%d" * 5000, "%s" * 30000, "%s" * 40000, "%.1024d", "%.2048d", "%.4096d", "%.8200d", "%99999999999s", "%99999999999d", "%99999999999x", "%99999999999n", "%99999999999s" * 1000, "%99999999999d" * 1000, "%99999999999x" * 1000, "%99999999999n" * 1000, "%08x" * 100, "%%20s" * 1000,"%%20x" * 1000,"%%20n" * 1000,"%%20d" * 1000, "%#0123456x%08x%x%s%p%n%d%o%u%c%h%l%q%j%z%Z%t%i%e%g%f%a%C%S%08x%%#0123456x%%x%%s%%p%%n%%d%%o%%u%%c%%h%%l%%q%%j%%z%%Z%%t%%i%%e%%g%%f%%a%%C%%S%%08x"]
-
-def bitflipping(data):
- l = len(data)
- n = int(l*7/100) # 7% of the bytes to be modified
-
- for i in range(0,n): # We change the bytes
- r = randint(0,l-1)
- data = data[0:r] + chr(randint(0,255)) + data[r+1:]
- return data
-
-def bofinjection(data):
- l = len(data)
- r = randint(0,len(overflowstrings)-1)
- data = data[0:r] + overflowstrings[r] + data[r-l:]
- return data
-
-def fuzz(data):
-
- r = randint(0,5)
- if r==0:
- data = bitflipping(data)
-
- r = randint(0,5)
- if r==0:
- data = bofinjection(data)
- return data
-
-def startudpproxy():
- reactor.listenUDP(localport, Server())
- reactor.run()
-
-def starttcpproxy():
- reactor.listenTCP(localport, portforward.ProxyFactory(desthost, destport))
- reactor.run()
-
-def usage():
- #print "###############################################################"
- print
- print "ProxyFuzz 0.1, Simple fuzzing proxy by Rodrigo Marcos"
- print "http://www.secforce.co.uk"
- print
- print "usage():"
- #print
- print "python proxyfuzz -l -r -p [options]"
- print
- print " [options]"
- print " -c: Fuzz only client side (both otherwise)"
- print " -s: Fuzz only server side (both otherwise)"
- print " -w: Number of requests to send before start fuzzing"
- print " -u: UDP protocol (otherwise TCP is used)"
- print " -v: Verbose (outputs network traffic)"
- print " -h: Help page"
-
-
-verbose = False
-notuntil = 0
-request = 0
-proto = "tcp"
-localport = 0
-desthost = ""
-destport = 0
-testclient = 1
-testserver = 1
-def main():
- global verbose
- global notuntil
- global proto
- global localport
- global desthost
- global destport
- global testclient
- global testserver
-
- try:
- opts, args = getopt.getopt(sys.argv[1:], "uvhcsl:r:p:w:", ["help"])
- except getopt.GetoptError:
- usage()
- sys.exit(2)
- try:
- for o, a in opts:
- if o in ("-h", "--help"):
- usage()
- sys.exit()
- if o == "-l":
- localport=int(a)
- if o == "-r":
- desthost=a
- if o == "-p":
- destport=int(a)
- if o == "-v":
- verbose = True
- if o == "-w":
- notuntil=int(a)
- if o == "-u":
- proto="udp"
- if o == "-c": # Only client
- testserver=0
- if o == "-s": # Only server
- testclient=0
-
-
- except:
- usage()
- sys.exit(2)
-
- if testserver==0 and testclient==0:
- usage()
- sys.exit(2)
- elif localport==0 or desthost=="" or destport==0:
- usage()
- sys.exit(2)
- else:
- if proto=="tcp":
- starttcpproxy()
- else: # UDP
- startudpproxy()
-
-if __name__ == "__main__":
- main()
-
-
diff --git a/proxyfuzz.spec b/proxyfuzz.spec
index 76c9720..e54e1ec 100644
--- a/proxyfuzz.spec
+++ b/proxyfuzz.spec
@@ -5,13 +5,13 @@ Release: 13%{?dist}
Summary: Man-in-the-middle non-deterministic network fuzzer
License: GPLv3+
-URL: http://www.secforce.co.uk/research/tools.html
-Source0: http://www.secforce.co.uk/media/tools/proxyfuzz.py.txt
+URL: https://github.com/SECFORCE
+Source0: https://raw.githubusercontent.com/SECFORCE/proxyfuzz/master/proxyfuzz.py
Source1: README-Fedora
BuildArch: noarch
-Requires: python2-twisted
-BuildRequires: python2-devel
+Requires: python3-twisted
+BuildRequires: python3-devel
%if 0%{?with_python3}
BuildRequires: python3-devel
%endif # if with_python3