#http-proxy #port #https-proxy #no-proxy

proxyvars

Parser for the HTTP_PROXY, HTTPS_PROXY and NO_PROXY environment variables, with a Go-like matcher for the NO_PROXY variable

4 releases

0.2.0 May 3, 2024
0.1.3 Apr 21, 2023
0.1.1 Apr 21, 2023
0.1.0 Apr 21, 2023

#49 in #http-proxy

Download history 75/week @ 2024-11-28 62/week @ 2024-12-05 63/week @ 2024-12-12 33/week @ 2024-12-19 2/week @ 2024-12-26 18/week @ 2025-01-02 43/week @ 2025-01-09 27/week @ 2025-01-16 19/week @ 2025-01-23 57/week @ 2025-01-30 113/week @ 2025-02-06 32/week @ 2025-02-13 58/week @ 2025-02-20 20/week @ 2025-02-27 7/week @ 2025-03-06 7/week @ 2025-03-13

93 downloads per month

MIT license

19KB
341 lines

proxyvars

proxyvars is a parser for the HTTP_PROXY, HTTPS_PROXY and NO_PROXY environment variables, with NO_PROXY matcher based on Go's implementation.

This crate can:

  • Read HTTPS_PROXY and HTTP_PROXY and its lowercase variants
  • Read, parse and evaluate the NO_PROXY environment variables against a given URL
    • Supports CIDR
    • Supports IPv4/IPv6 address and optinal ports
    • Supports Hostnames and optinal ports
    • Supports Wildcard

Usage

if let Some(no_proxy) = proxyvars::no_proxy() {
    // This environment has NO_PROXY defined
    if no_proxy.matches("https://company.com") {
        // We should not use a proxy for this URL
    } else {
        // We should use a proxy for this URL, which are available at:
        let https_proxy = proxyvars::https_proxy();
        let http_proxy = proxyvars::http_proxy();
    }
}

Notes

  1. The implementation of the NO_PROXY matcher is heavily inspired by Go's implementation located at http/httpproxy/proxy.go.
  2. It's outside the scope of this crate to actually perform the proxying.

Dependencies

~770KB
~12K SLoC