PyPAC: Proxy auto-config for Python
===================================
.. image:: https://img.shields.io/pypi/v/pypac.svg?maxAge=2592000
:target: https://pypi.python.org/pypi/pypac
.. image:: https://img.shields.io/pypi/pyversions/pypac.svg
:target: https://pypi.python.org/pypi/pypac
.. image:: https://readthedocs.org/projects/pypac/badge/?version=latest
:target: https://pypac.readthedocs.io/en/latest/?badge=latest
.. image:: https://github.com/carsonyl/pypac/actions/workflows/tests.yml/badge.svg
:target: https://github.com/carsonyl/pypac/actions/workflows/tests.yml
PyPAC is a Python library for finding `proxy auto-config (PAC)`_ files and making HTTP requests
that respect them. PAC files are often used in organizations that need fine-grained and centralized control
of proxy settings.
PyPAC can find PAC files according to the DNS portion of the `Web Proxy Auto-Discovery (WPAD)`_ protocol.
On Windows, PyPAC will automatically get the PAC file URL from the Internet Options dialog.
On macOS, PyPAC will automatically get the PAC file URL from System Preferences.
.. _proxy auto-config (PAC): https://en.wikipedia.org/wiki/Proxy_auto-config
PyPAC provides a subclass of a `Requests <http://docs.python-requests.org/en/master/>`_ ``Session``,
so you can start using it immediately, with any PAC file transparently discovered and honoured:
.. code-block:: python
>>> from pypac import PACSession
>>> session = PACSession()
>>> session.get('http://example.org')
...
If a PAC file isn't found, then ``PACSession`` behaves like a regular ``Session``.
.. _Web Proxy Auto-Discovery (WPAD): https://en.wikipedia.org/wiki/Web_Proxy_Autodiscovery_Protocol
If you're looking to add *basic* PAC functionality to a library that you're using,
try the ``pac_context_for_url()`` context manager:
.. code-block:: python
from pypac import pac_context_for_url
import boto3
with pac_context_for_url('https://example.amazonaws.com'):
client = boto3.client('sqs')
client.list_queues()
This sets up proxy environment variables at the start of the scope, based on any auto-discovered PAC and the given URL.
``pac_context_for_url()`` should work for any library
that honours proxy environment variables.
Features
--------
* The same Requests API that you already know and love
* Honour PAC setting from Windows Internet Options and macOS System Preferences
* Follow DNS Web Proxy Auto-Discovery protocol
* Proxy authentication pass-through
* Proxy failover and load balancing
* Generic components for adding PAC support to other code
PyPAC supports Python 2.7 and 3.5+.
Installation
------------
Install PyPAC using `pip <https://pip.pypa.io>`_::
$ python -m pip install pypac
Documentation
-------------
PyPAC's documentation is available at http://pypac.readthedocs.io/.
0.16.5 (2024-12-24)
-------------------
- Log warning for rejected PAC content-type. (#79) Thanks @jmkerloch.
- Remove Python 2.7, 3.7 from CIB test matrix.
0.16.4 (2023-04-24)
-------------------
- Release using `Trusted Publishing <https://blog.pypi.org/posts/2023-04-20-introducing-trusted-publishers/>`_.
0.16.3 (2023-03-31)
-------------------
- ``isInNet()``: Return False immediately for invalid host arg. (#71)
0.16.2 (2023-03-26)
-------------------
- Handle boolean args to ``isInNet()``. (#69)
- Remove Python 3.5, 3.6 from CIB test matrix.
- Windows Python 2.7 CIB: Pin to dukpy 0.2.3.
0.16.1 (2022-11-08)
-------------------
- Disable ``tldextract`` caching. (#64) Thanks @mpkuth.
0.16.0 (2022-01-01)
-------------------
- Change ``tld`` dependency to ``tldextract``. (#61)
0.15.0 (2021-02-27)
-------------------
- Drop support for Python 3.4. (#48)
- Support more proxy keywords: HTTP, HTTPS, SOCKS4, SOCKS5. (#41)
- Absorb any exception from ``tld.get_tld()``, not just TldDomainNotFound. (#30) Thanks @santiavenda2.
- Reimplement ``dnsDomainIs(host, domain)`` as case-insensitive 'host ends with domain'. (#42, #57)
0.14.0 (2020-12-05)
-------------------
- Add ability to supply ``PACFile`` to ``pac_context_for_url()``. (#52) Thanks @alexrohvarger.
0.13.0 (2019-09-16)
-------------------
- Make it possible to configure the request for the PAC file. (#44) Thanks @SeyfSV.
- urlencode proxy username and password. (#46) Thanks @aslafy-z.
0.12.0 (2018-09-11)
-------------------
- Fix possible error when ``dnsResolve()`` fails. (#34) Thanks @maximinus.
0.11.0 (2018-09-08)
-------------------
- Require dukpy 0.2.2, to fix memory leak. (#32) Thanks @maximinus.
- Change Mac environment marker. (#30)
- Support Python 3.7.
0.10.1 (2018-08-26)
-------------------
- Require tld 0.9.x. (#29)
0.10.0 (2018-08-26)
-------------------
- Switch JavaScript interpreter to dukpy. (#24)
- Fix ``pac_context_for_url()`` erroring with ``DIRECT`` PAC setting. (#27)
- Fix warning about invalid escape sequence (#26). Thanks @BoboTiG.
0.9.0 (2018-06-02)
------------------
- Add macOS support for PAC in System Preferences (#23). Thanks @LKleinNux.
- The `from_registry` argument on `pypac.get_pac()` and `pypac.collect_pac_urls()`
is now deprecated and will be removed in 1.0.0. Use `from_os_settings` instead.
0.8.1 (2018-03-01)
------------------
- Defer Js2Py import until it's needed. It uses a lot of memory.
See #20 for details.
0.8.0 (2018-02-28)
------------------
- Add support for ``file://`` PAC URLs on Windows.
0.7.0 (2018-02-21)
------------------
- Drop support for Python 3.3.
- Add doc explaining how to use ``pac_context_for_url()``.
- Internal changes to dev and test processes.
0.6.0 (2018-01-28)
------------------
- Add ``pac_context_for_url()``, a context manager that adds basic PAC functionality
through proxy environment variables.
0.5.0 (2018-01-18)
------------------
- Accept PAC files served with no ``Content-Type`` header.
0.4.0 (2017-11-07)
------------------
- Add ``recursion_limit`` keyword argument to ``PACSession`` and ``PACFile``.
The default is an arbitrarily high value (10000), which should cover most applications.
- Exclude port numbers from ``host`` passed to ``FindProxyForURL(url, host)``.
0.3.1 (2017-06-23)
------------------
- Update GitHub username.
0.3.0 (2017-04-12)
------------------
- Windows: Get system auto-proxy config setting using ``winreg`` module.
- Windows: Accept local filesystem paths from system proxy auto-config setting.
- Raise ``PacComplexityError`` when recursion limit is hit while parsing PAC file.
- Support setting ``PACSession.proxy_auth`` and ``ProxyResolver.proxy_auth`` after constructing an instance.
- Narrative docs.
0.2.1 (2017-01-19)
------------------
- Require Js2Py >= 0.43 for Python 3.6 support, and to avoid needing to monkeypatch out ``pyimport``.
0.1.0 (2016-06-12)
------------------
- First release.
Raw data
{
"_id": null,
"home_page": "https://github.com/carsonyl/pypac",
"name": "PyPAC",
"maintainer": null,
"docs_url": null,
"requires_python": "!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*,!=3.4.*,>=2.7",
"maintainer_email": null,
"keywords": "pypac, pac, proxy, autoconfig, requests",
"author": "Carson Lam",
"author_email": "46059+carsonyl@users.noreply.github.com",
"download_url": null,
"platform": null,
"description": "PyPAC: Proxy auto-config for Python\n===================================\n\n.. image:: https://img.shields.io/pypi/v/pypac.svg?maxAge=2592000\n :target: https://pypi.python.org/pypi/pypac\n.. image:: https://img.shields.io/pypi/pyversions/pypac.svg\n :target: https://pypi.python.org/pypi/pypac\n.. image:: https://readthedocs.org/projects/pypac/badge/?version=latest\n :target: https://pypac.readthedocs.io/en/latest/?badge=latest\n.. image:: https://github.com/carsonyl/pypac/actions/workflows/tests.yml/badge.svg\n :target: https://github.com/carsonyl/pypac/actions/workflows/tests.yml\n\nPyPAC is a Python library for finding `proxy auto-config (PAC)`_ files and making HTTP requests\nthat respect them. PAC files are often used in organizations that need fine-grained and centralized control\nof proxy settings.\n\nPyPAC can find PAC files according to the DNS portion of the `Web Proxy Auto-Discovery (WPAD)`_ protocol.\nOn Windows, PyPAC will automatically get the PAC file URL from the Internet Options dialog.\nOn macOS, PyPAC will automatically get the PAC file URL from System Preferences.\n\n.. _proxy auto-config (PAC): https://en.wikipedia.org/wiki/Proxy_auto-config\n\nPyPAC provides a subclass of a `Requests <http://docs.python-requests.org/en/master/>`_ ``Session``,\nso you can start using it immediately, with any PAC file transparently discovered and honoured:\n\n.. code-block:: python\n\n >>> from pypac import PACSession\n >>> session = PACSession()\n >>> session.get('http://example.org')\n ...\n\nIf a PAC file isn't found, then ``PACSession`` behaves like a regular ``Session``.\n\n.. _Web Proxy Auto-Discovery (WPAD): https://en.wikipedia.org/wiki/Web_Proxy_Autodiscovery_Protocol\n\nIf you're looking to add *basic* PAC functionality to a library that you're using,\ntry the ``pac_context_for_url()`` context manager:\n\n.. code-block:: python\n\n from pypac import pac_context_for_url\n import boto3\n\n with pac_context_for_url('https://example.amazonaws.com'):\n client = boto3.client('sqs')\n client.list_queues()\n\nThis sets up proxy environment variables at the start of the scope, based on any auto-discovered PAC and the given URL.\n``pac_context_for_url()`` should work for any library\nthat honours proxy environment variables.\n\n\nFeatures\n--------\n\n* The same Requests API that you already know and love\n* Honour PAC setting from Windows Internet Options and macOS System Preferences\n* Follow DNS Web Proxy Auto-Discovery protocol\n* Proxy authentication pass-through\n* Proxy failover and load balancing\n* Generic components for adding PAC support to other code\n\nPyPAC supports Python 2.7 and 3.5+.\n\n\nInstallation\n------------\n\nInstall PyPAC using `pip <https://pip.pypa.io>`_::\n\n $ python -m pip install pypac\n\n\nDocumentation\n-------------\n\nPyPAC's documentation is available at http://pypac.readthedocs.io/.\n\n0.16.5 (2024-12-24)\n-------------------\n\n- Log warning for rejected PAC content-type. (#79) Thanks @jmkerloch.\n- Remove Python 2.7, 3.7 from CIB test matrix.\n\n0.16.4 (2023-04-24)\n-------------------\n\n- Release using `Trusted Publishing <https://blog.pypi.org/posts/2023-04-20-introducing-trusted-publishers/>`_.\n\n0.16.3 (2023-03-31)\n-------------------\n\n- ``isInNet()``: Return False immediately for invalid host arg. (#71)\n\n0.16.2 (2023-03-26)\n-------------------\n\n- Handle boolean args to ``isInNet()``. (#69)\n- Remove Python 3.5, 3.6 from CIB test matrix.\n- Windows Python 2.7 CIB: Pin to dukpy 0.2.3.\n\n\n0.16.1 (2022-11-08)\n-------------------\n\n- Disable ``tldextract`` caching. (#64) Thanks @mpkuth.\n\n\n0.16.0 (2022-01-01)\n-------------------\n\n- Change ``tld`` dependency to ``tldextract``. (#61)\n\n\n0.15.0 (2021-02-27)\n-------------------\n\n- Drop support for Python 3.4. (#48)\n- Support more proxy keywords: HTTP, HTTPS, SOCKS4, SOCKS5. (#41)\n- Absorb any exception from ``tld.get_tld()``, not just TldDomainNotFound. (#30) Thanks @santiavenda2.\n- Reimplement ``dnsDomainIs(host, domain)`` as case-insensitive 'host ends with domain'. (#42, #57)\n\n\n0.14.0 (2020-12-05)\n-------------------\n\n- Add ability to supply ``PACFile`` to ``pac_context_for_url()``. (#52) Thanks @alexrohvarger.\n\n\n0.13.0 (2019-09-16)\n-------------------\n\n- Make it possible to configure the request for the PAC file. (#44) Thanks @SeyfSV.\n- urlencode proxy username and password. (#46) Thanks @aslafy-z.\n\n\n0.12.0 (2018-09-11)\n-------------------\n\n- Fix possible error when ``dnsResolve()`` fails. (#34) Thanks @maximinus.\n\n\n0.11.0 (2018-09-08)\n-------------------\n\n- Require dukpy 0.2.2, to fix memory leak. (#32) Thanks @maximinus.\n- Change Mac environment marker. (#30)\n- Support Python 3.7.\n\n\n0.10.1 (2018-08-26)\n-------------------\n\n- Require tld 0.9.x. (#29)\n\n\n0.10.0 (2018-08-26)\n-------------------\n\n- Switch JavaScript interpreter to dukpy. (#24)\n- Fix ``pac_context_for_url()`` erroring with ``DIRECT`` PAC setting. (#27)\n- Fix warning about invalid escape sequence (#26). Thanks @BoboTiG.\n\n\n0.9.0 (2018-06-02)\n------------------\n\n- Add macOS support for PAC in System Preferences (#23). Thanks @LKleinNux.\n- The `from_registry` argument on `pypac.get_pac()` and `pypac.collect_pac_urls()`\n is now deprecated and will be removed in 1.0.0. Use `from_os_settings` instead.\n\n\n0.8.1 (2018-03-01)\n------------------\n\n- Defer Js2Py import until it's needed. It uses a lot of memory.\n See #20 for details.\n\n\n0.8.0 (2018-02-28)\n------------------\n\n- Add support for ``file://`` PAC URLs on Windows.\n\n\n0.7.0 (2018-02-21)\n------------------\n\n- Drop support for Python 3.3.\n- Add doc explaining how to use ``pac_context_for_url()``.\n- Internal changes to dev and test processes.\n\n\n0.6.0 (2018-01-28)\n------------------\n\n- Add ``pac_context_for_url()``, a context manager that adds basic PAC functionality\n through proxy environment variables.\n\n\n0.5.0 (2018-01-18)\n------------------\n\n- Accept PAC files served with no ``Content-Type`` header.\n\n\n0.4.0 (2017-11-07)\n------------------\n\n- Add ``recursion_limit`` keyword argument to ``PACSession`` and ``PACFile``.\n The default is an arbitrarily high value (10000), which should cover most applications.\n- Exclude port numbers from ``host`` passed to ``FindProxyForURL(url, host)``.\n\n\n0.3.1 (2017-06-23)\n------------------\n\n- Update GitHub username.\n\n\n0.3.0 (2017-04-12)\n------------------\n- Windows: Get system auto-proxy config setting using ``winreg`` module.\n- Windows: Accept local filesystem paths from system proxy auto-config setting.\n- Raise ``PacComplexityError`` when recursion limit is hit while parsing PAC file.\n- Support setting ``PACSession.proxy_auth`` and ``ProxyResolver.proxy_auth`` after constructing an instance.\n- Narrative docs.\n\n\n0.2.1 (2017-01-19)\n------------------\n\n- Require Js2Py >= 0.43 for Python 3.6 support, and to avoid needing to monkeypatch out ``pyimport``.\n\n\n0.1.0 (2016-06-12)\n------------------\n\n- First release.\n",
"bugtrack_url": null,
"license": "Apache-2.0",
"summary": "Proxy auto-config and auto-discovery for Python.",
"version": "0.16.5",
"project_urls": {
"Homepage": "https://github.com/carsonyl/pypac"
},
"split_keywords": [
"pypac",
" pac",
" proxy",
" autoconfig",
" requests"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "e28a34201b3162e7d0eb2c90313cb3055dd1ad6e19f1c28425569ae81d53be5f",
"md5": "d5f4da816e57344b8fcebb21ee061dac",
"sha256": "879c391d6784abc5d3b64b4bb132917ae4568cce97d75749e21a102548de7492"
},
"downloads": -1,
"filename": "PyPAC-0.16.5-py2.py3-none-any.whl",
"has_sig": false,
"md5_digest": "d5f4da816e57344b8fcebb21ee061dac",
"packagetype": "bdist_wheel",
"python_version": "py2.py3",
"requires_python": "!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*,!=3.4.*,>=2.7",
"size": 23234,
"upload_time": "2024-12-25T00:57:31",
"upload_time_iso_8601": "2024-12-25T00:57:31.728005Z",
"url": "https://files.pythonhosted.org/packages/e2/8a/34201b3162e7d0eb2c90313cb3055dd1ad6e19f1c28425569ae81d53be5f/PyPAC-0.16.5-py2.py3-none-any.whl",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-12-25 00:57:31",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "carsonyl",
"github_project": "pypac",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "pypac"
}