|made-with-python| |PyPI-version| |Hit-Count| |Downloads| |Downloads-month| |Downloads-week|
.. |made-with-python| image:: https://img.shields.io/badge/Made%20with-Python-1f425f.svg :target: https://www.python.org/ .. |PyPI-version| image:: https://badge.fury.io/py/pvpn.svg :target: https://pypi.python.org/pypi/pvpn/ .. |Hit-Count| image:: http://hits.dwyl.io/qwj/python-vpn.svg :target: https://pypi.python.org/pypi/pvpn/ .. |Downloads| image:: https://pepy.tech/badge/pvpn :target: https://pepy.tech/project/pvpn .. |Downloads-month| image:: https://pepy.tech/badge/pvpn/month :target: https://pepy.tech/project/pvpn .. |Downloads-week| image:: https://pepy.tech/badge/pvpn/week :target: https://pepy.tech/project/pvpn
VPN Server implemented in pure Python. (For Research Purposes Only)
All VPN softwares are stupid, clumsy and hard to configure. So comes python-vpn.
Press "RETURN" to start, "CTRL+C" to stop.
.. code:: rst
$ pip3 install pvpn Successfully installed pvpn-0.2.1 $ pvpn -p yourpassword Serving on UDP :500 :4500... ^C $ pvpn -wg 9000 Serving on UDP :500 :4500... Serving on UDP :9000 (WIREGUARD)... ^C
Open server's UDP port :500 :4500 to your device. In device's system setting, add an "IPSec" (iOS) or "IPSec IKE PSK" (Android) node, write down the server address and password "yourpassword". Connect.
If you prefer wireguard VPN, specify "-wg (port)" parameter and open server's (port) UDP port to your device. Paste the printed server public key to wireguard client settings, write down the server address:port. Connect.
You should modify the default password "test" with a good one. See "pvpn -h" for more options.
+-------------------+----------------+-------------------+----------------+------------------+ | Protocol Name | Name in iOS | Name in Android | Name in MacOS | Name in Windows | +===================+================+===================+================+==================+ | L2TP PSK ✔ | L2TP | "L2TP/IPSec PSK" | L2TP/IPSec | L2TP | +-------------------+----------------+-------------------+----------------+------------------+ | IKEv1 PSK ✔ | IPsec [1] | "IPSec Xauth PSK" | Cisco IPSec | IPSec | +-------------------+----------------+-------------------+----------------+------------------+ | IKEv2 PSK ✔ | IKEv2 [2] | "IPSec IKEv2 PSK" | IKEv2 | IKEv2 | +-------------------+----------------+-------------------+----------------+------------------+ | WireGuard ✔ | WireGuard App [3] | +-------------------+----------------+-------------------+----------------+------------------+
| [1] Do not use certificates | [2] Turn off "user authentication" | [3] Turn off "preshared key"
TCP Tunnel
.. code:: rst
If the remote host match in file "rules.country", tunnel through http proxy.
$ pvpn -r http://remote_server:port?rules.country
UDP Tunnel
.. code:: rst
Redirect all DNS requests to 8.8.8.8.
$ pvpn -ur tunnel://8.8.8.8:53?{53}
IPSec/ESP
RFC2406 <https://tools.ietf.org/html/rfc2406>
_ IP Encapsulating Security Payload (ESP)RFC3947 <https://tools.ietf.org/html/rfc3947>
_ Negotiation of NAT-Traversal in the IKERFC3948 <https://tools.ietf.org/html/rfc3948>
_ UDP Encapsulation of IPsec ESP PacketsIKE/ISAKMP
RFC2407 <https://tools.ietf.org/html/rfc2407>
_ The Internet IP Security Domain of Interpretation for ISAKMPRFC2408 <https://tools.ietf.org/html/rfc2408>
_ Internet Security Association and Key Management Protocol (ISAKMP)RFC2409 <https://tools.ietf.org/html/rfc2409>
_ The Internet Key Exchange (IKE)IANA_01 <https://www.iana.org/assignments/ipsec-registry/ipsec-registry.xhtml>
_ Internet Key Exchange (IKE) AttributesIANA_02 <https://www.iana.org/assignments/isakmp-registry/isakmp-registry.xhtml>
_ "Magic Numbers" for ISAKMP ProtocolDRAFT_1 <https://tools.ietf.org/html/draft-dukes-ike-mode-cfg-01>
_ The ISAKMP Configuration MethodDRAFT_2 <https://tools.ietf.org/html/draft-beaulieu-ike-xauth-02>
_ Extended Authentication within IKE (XAUTH)IKEv2
RFC7296 <https://tools.ietf.org/html/rfc7296>
_ Internet Key Exchange Protocol Version 2 (IKEv2)IANA_03 <https://www.iana.org/assignments/ikev2-parameters/ikev2-parameters.xhtml>
_ Internet Key Exchange Version 2 (IKEv2) ParametersRFC3748 <https://tools.ietf.org/html/rfc3748>
_ Extensible Authentication Protocol (EAP)RFC5106 <https://tools.ietf.org/html/rfc5106>
_ The Extensible Authentication Protocol-Internet Key Exchange Protocol version 2 (EAP-IKEv2) MethodDiffie Hellman
RFC3526 <https://tools.ietf.org/html/rfc3526>
_ More Modular Exponential (MODP) Diffie-Hellman groups for Internet Key Exchange (IKE)RFC5903 <https://tools.ietf.org/html/rfc5903>
_ Elliptic Curve Groups modulo a Prime (ECP Groups) for IKE and IKEv2RFC5114 <https://tools.ietf.org/html/rfc5114>
_ Additional Diffie-Hellman Groups for Use with IETF StandardsL2TP
RFC2661 <https://tools.ietf.org/html/rfc2661>
_ Layer Two Tunneling Protocol "L2TP"RFC3193 <https://tools.ietf.org/html/rfc3193>
_ Securing L2TP using IPsecRFC1549 <https://tools.ietf.org/html/rfc1549>
_ PPP in HDLC FramingRFC1661 <https://tools.ietf.org/html/rfc1661>
_ The Point-to-Point Protocol (PPP)RFC1332 <https://tools.ietf.org/html/rfc1332>
_ The PPP Internet Protocol Control Protocol (IPCP)WireGuard
RFC7748 <https://tools.ietf.org/html/rfc7748>
_ Elliptic Curves for SecurityWireGuard <https://www.wireguard.com/protocol/>
_ Protocol Specification