Skip to main content

Python package which builds on pypac to add pac file support for httplib2 Http

Project description

pypac4http2

Python package which builds on pypac to add pac file support for httplib2 Http

This package adds proxy auto configure pac support to the httplib2 library Http classby sub-classing the class and adding a new constructor parameter for a resolver class.

Installation

pip install pypac4http2

Usage

HttpPac Class

The HttpPac class extends httplib2.Http and automatically resolves the proxy for each request using a PAC file.

from pypac4http2 import HttpPac

# Automatically discover PAC using OS settings or WPAD
http = HttpPac()
response, content = http.request("http://example.org")

# Specify a PAC URL
http = HttpPac(pac_url="http://internal.corp/proxy.pac")
response, content = http.request("http://example.org")

# Provide PAC as a JavaScript string
pac_js = "function FindProxyForURL(url, host) { return 'PROXY proxy:8080'; }"
http = HttpPac(pac_js=pac_js)
response, content = http.request("http://example.org")

# The library also supports the PAC_URL environment variable:
# export PAC_URL=http://internal.corp/proxy.pac

Usage with Google API Client

HttpPac is designed to be a drop-in replacement for httplib2.Http, making it ideal for use with the Google API Python Client.

In a typical enterprise environment, you may also need your authentication flow (which often uses google-auth and requests) to respect the same PAC settings. You can use pypac.PACSession alongside HttpPac.

import os
from googleapiclient.discovery import build
import google.auth
from google.auth.transport.requests import Request
from pypac import PACSession
from pypac4http2 import HttpPac

# 1. Use PACSession for authentication flows that use 'requests'
# pypac.PACSession doesn't natively check PAC_URL, so we pass it explicitly if set
pac_url = os.environ.get("PAC_URL")
auth_session = PACSession(url=pac_url) if pac_url else PACSession()
auth_request = Request(session=auth_session)

# 2. Get default credentials using the proxy-aware request
credentials, project = google.auth.default(request=auth_request)

# 3. Refresh credentials using the proxy-aware session
credentials.refresh(auth_request)

# 4. Use HttpPac for the Google API service calls (which use 'httplib2')
# Both will respect PAC settings (e.g. via PAC_URL environment variable)
http = HttpPac()
service = build('drive', 'v3', http=http, credentials=credentials)

# All API calls will now automatically resolve proxies via PAC
files = service.files().list().execute()

CLI Tool

The package includes a CLI tool pypac4http2 to resolve proxies for a given URL.

# Resolve proxy using OS auto-discovery (or PAC_URL env var if set)
pypac4http2 https://google.com

# Resolve proxy using a specific PAC URL
pypac4http2 --pac-url http://example.com/proxy.pac https://google.com

# Resolve proxy using a PAC JavaScript string
pypac4http2 --pac-js "function FindProxyForURL(url, host) { return 'DIRECT'; }" https://google.com

Output Example:

Proxy choice: PROXY proxy.example.com:8080
{
  "target_url": "https://google.com",
  "pac_result": "PROXY proxy.example.com:8080",
  "proxy_info": {
    "proxy_type": "HTTP",
    "proxy_host": "proxy.example.com",
    "proxy_port": 8080
  }
}

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pypac4http2-0.0.5.tar.gz (14.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pypac4http2-0.0.5-py3-none-any.whl (10.3 kB view details)

Uploaded Python 3

File details

Details for the file pypac4http2-0.0.5.tar.gz.

File metadata

  • Download URL: pypac4http2-0.0.5.tar.gz
  • Upload date:
  • Size: 14.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pypac4http2-0.0.5.tar.gz
Algorithm Hash digest
SHA256 a961de807012258c917cfc7a68db58f9dc1ed0662980f21944127e6d8167a9f8
MD5 748162ca8b8aa88b69651df50812309f
BLAKE2b-256 c083f9bf7f82b4807d7f5d1617500cc672978f2470463cc6cbd416ae536ecaf9

See more details on using hashes here.

Provenance

The following attestation bundles were made for pypac4http2-0.0.5.tar.gz:

Publisher: publish.yml on MikeMoore63/pypac4http2

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pypac4http2-0.0.5-py3-none-any.whl.

File metadata

  • Download URL: pypac4http2-0.0.5-py3-none-any.whl
  • Upload date:
  • Size: 10.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pypac4http2-0.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 9057a2c58bbdfae09301a1c5b2813892716e1fbaedf6ed74d88f567de776dec3
MD5 00ac75555ff2f8971e912aa23abaea0b
BLAKE2b-256 dc20aadc8aad14e59242b66ccfe9ceda128c2f4f8ac92e53dc0f8c7cf703f01e

See more details on using hashes here.

Provenance

The following attestation bundles were made for pypac4http2-0.0.5-py3-none-any.whl:

Publisher: publish.yml on MikeMoore63/pypac4http2

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page