PATH:
lib
/
python3.6
/
site-packages
#!/usr/bin/env python """ SocksiPy + urllib2 handler version: 0.3 author: e<e@tr0ll.in> This module provides a Handler which you can use with urllib2 to allow it to tunnel your connection through a socks.sockssocket socket, with out monkey patching the original socket... """ import ssl try: import urllib2 import httplib except ImportError: # Python 3 import urllib.request as urllib2 import http.client as httplib import socks # $ pip install PySocks def merge_dict(a, b): d = a.copy() d.update(b) return d class SocksiPyConnection(httplib.HTTPConnection): def __init__(self, proxytype, proxyaddr, proxyport=None, rdns=True, username=None, password=None, *args, **kwargs): self.proxyargs = (proxytype, proxyaddr, proxyport, rdns, username, password) httplib.HTTPConnection.__init__(self, *args, **kwargs) def connect(self): self.sock = socks.socksocket() self.sock.setproxy(*self.proxyargs) if type(self.timeout) in (int, float): self.sock.settimeout(self.timeout) self.sock.connect((self.host, self.port)) class SocksiPyConnectionS(httplib.HTTPSConnection): def __init__(self, proxytype, proxyaddr, proxyport=None, rdns=True, username=None, password=None, *args, **kwargs): self.proxyargs = (proxytype, proxyaddr, proxyport, rdns, username, password) httplib.HTTPSConnection.__init__(self, *args, **kwargs) def connect(self): sock = socks.socksocket() sock.setproxy(*self.proxyargs) if type(self.timeout) in (int, float): sock.settimeout(self.timeout) sock.connect((self.host, self.port)) self.sock = ssl.wrap_socket(sock, self.key_file, self.cert_file) class SocksiPyHandler(urllib2.HTTPHandler, urllib2.HTTPSHandler): def __init__(self, *args, **kwargs): self.args = args self.kw = kwargs urllib2.HTTPHandler.__init__(self) def http_open(self, req): def build(host, port=None, timeout=0, **kwargs): kw = merge_dict(self.kw, kwargs) conn = SocksiPyConnection(*self.args, host=host, port=port, timeout=timeout, **kw) return conn return self.do_open(build, req) def https_open(self, req): def build(host, port=None, timeout=0, **kwargs): kw = merge_dict(self.kw, kwargs) conn = SocksiPyConnectionS(*self.args, host=host, port=port, timeout=timeout, **kw) return conn return self.do_open(build, req) if __name__ == "__main__": import sys try: port = int(sys.argv[1]) except (ValueError, IndexError): port = 9050 opener = urllib2.build_opener(SocksiPyHandler(socks.PROXY_TYPE_SOCKS5, "localhost", port)) print("HTTP: " + opener.open("http://httpbin.org/ip").read().decode()) print("HTTPS: " + opener.open("https://httpbin.org/ip").read().decode())
[+]
dnfpluginscore
[+]
pycparser
[+]
dateutil
[-] bcc-0.25.0-py3.6.egg-info
[edit]
[+]
OpenSSL
[+]
dns
[-] slip.dbus-0.6.4-py3.6.egg-info
[edit]
[+]
pip-9.0.3.dist-info
[+]
iotop
[+]
firewall
[+]
idna
[+]
pkg_resources
[+]
slip
[-] sockshandler.py
[edit]
[+]
netaddr
[-] pciutils-2.3.6-py3.6.egg-info
[edit]
[+]
pycparser-2.14-py3.6.egg-info
[-] pyparsing.py
[edit]
[+]
syspurpose-1.28.44-py3.6.egg-info
[+]
tuned
[+]
isc
[+]
dnf-plugins
[+]
python_linux_procfs-0.7.3-py3.6.egg-info
[+]
PySocks-1.6.8-py3.6.egg-info
[+]
html2text
[+]
chardet-3.0.4-py3.6.egg-info
[-] rhnlib-2.8.6-py3.6.egg-info
[edit]
[-] hwdata.py
[edit]
[+]
..
[-] nftables-0.1-py3.6.egg-info
[edit]
[-] slip-0.6.4-py3.6.egg-info
[edit]
[-] easy_install.py
[edit]
[+]
setuptools
[+]
syspurpose
[+]
idna-2.5-py3.6.egg-info
[+]
python_dateutil-2.6.1-py3.6.egg-info
[+]
pyudev
[-] iotop-0.6-py3.6.egg-info
[edit]
[+]
dnspython-1.15.0-py3.6.egg-info
[+]
ply
[+]
html2text-2019.9.26-py3.6.egg-info
[+]
pip
[-] isc-2.0-py3.6.egg-info
[edit]
[+]
urllib3-1.24.2-py3.6.egg-info
[+]
netaddr-0.7.19-py3.6.egg-info
[+]
urllib3
[+]
setuptools-39.2.0.dist-info
[+]
dnf
[+]
__pycache__
[-] decorator.py
[edit]
[+]
rhn
[+]
pyudev-0.21.0-py3.6.egg-info
[+]
decorator-4.2.1-py3.6.egg-info
[-] socks.py
[edit]
[+]
six-1.11.0.dist-info
[+]
requests
[+]
requests-2.20.0-py3.6.egg-info
[+]
up2date_client
[+]
pyOpenSSL-19.0.0-py3.6.egg-info
[+]
bcc
[+]
ply-3.9-py3.6.egg-info
[+]
procfs
[+]
chardet
[+]
nftables
[-] six.py
[edit]
[+]
pyparsing-2.1.10.dist-info