Skip to main content

No project description provided

Project description

PyHTTPIntercept

Provides a HTTP Server which can be used to intercept and modify API requests/responses for local clients.

This is useful for client testing where generating different response types from the API is not always ideal.

The HTTP server provides the following functionality:

  • Hosting of sites
  • Redirecting requests with the following methods:
    • HTTP 3xx statuses
    • transparently to the client
  • Intercepting and modifying of requests. Man-in-the-middle, useful for client testing against a production API.
  • Proxying of requests

When a request comes in methods are checked & executed in the following order:

  1. Redirect
  2. Hosting
  3. Intercept - Intercept will only be reached if request is not picked up by hosting.
  4. Proxy - Proxy configuration will only be reached if request is not picked up by Hosting or Intercept.

Hosting requests

Sites can be hosted as with any webserver. The server supports static sites/resources only.

Hosting configuration

An example configuration file:

{
  "/": {
    "doc_root": "default_sites/",
    "active": true,
    "description": "Root Site"
  },
  "/example": {
    "doc_root": "default_sites/example/",
    "active": true,
    "description": "Example Site"
  }
}

A configured site configurations key will be set to the expected url path.

Site configuration parameters:

  • Object key: String - Path where site will be hosted.
  • doc_root: String - The full path to the configured site. A relative path can also be configured and is explained below.
  • active: Boolean - True if the site is to be served.
  • description: String - [optional] A description for your site.

Relative paths

TODO


Redirecting requests

Sending HTTP 3xx statuses

These are your standard redirects.

Transparently to the client

These are useful for clients that do not support redirects.

An example use would be redirecting a client with hard coded endpoints to a lab environemnt for testing without having to generate & install specific builds for the lab.

Redirect configuration

Parameters:

  • Object key: String - Domain to redirect.
  • host: String - [optional] The full domain to redirect to.
  • paths: Object - [optional] An object containing the paths being redirected for this domain.
  • active: Boolean - True to enable redirect.
  • description: String - [optional] A description for your redirect.

Note: at least one of host or paths must be specified!

Path object:

  • Object key: String - Path to redirect.
  • host: String - [optional] The full domain to redirect to.
  • path: String - [optional] The full path to redirect to. If omitted then the path will be set to domain root.
  • status: Number - [optional] The HTTP 3xx status to send. Specifying this parameter tells the server to use a HTTP 3xx redirect rather than redirecting transparently.
  • active: Boolean - True to enable redirect.
  • description: String - [optional] A description for your redirect.

Note: at least one of path or host (from either site/path config) must be specified!

If a host is specifed in the key it will only by honoured when intercepting or proxying, for anything else the keys will be ignored.

Redirecting paths within the same site:

{
  "example.com": {
    "paths": {
      "/example_redirect": {
        "path": "/temp_path",
        "active": true,
      }
    },
    "active": true,
  }
}

Redirecting paths within the same site using a HTTP 3xx redirect:

{
  "example.com": {
    "paths": {
      "/example_redirect": {
        "path": "/temp_path",
        "status": 301,
        "active": true,
      }
    },
    "active": true,
  }
}

Redirecting paths from one site to another:

{
  "example.com": {
    "host": "example2.com",
    "paths": {
      "/example_redirect": {
        "path": "/",
        "active": true,
      }
    },
    "active": true,
  }
}

This can also be done on a path by path basis:

{
  "example.com": {
    "paths": {
      "host": "example2.com",
      "/example_redirect": {
        "path": "/",
        "active": true,
      },
      "/example_redirect2": {
        "host": "example3.com",
        "path": "/",
        "active": true,
      }
    },
    "active": true,
  }
}

If a host is configured for a path it takes precedence over the site redirect host.

Redirecting one domain to another:

{
  "example.com": {
    "host": "example2.com",
    "active": true,
  }
}

This applies to all paths for the domain.


Intercepting requests

Intercept configuration

Parameters:

  • Object key: String - Domain to Intercept.
  • active: Boolean - True to enable proxy.
  • description: String - [optional] A description for your proxy.

An example configuration file:

{
  "example.com": {
    "active": true,
    "description": "Intercept & modify"
  }
}

Proxying requests

Parameters:

  • Object key: String - Domain to proxy.
  • active: Boolean - True to enable proxy.
  • description: String - [optional] A description for your proxy.

Proxy can be configured to either proxy all requests:

{
  "*": {
    "active": true,
    "description": "Proxy All"
  }
}

or specific domains only:

{
  "example.com": {
    "active": true,
    "description": "Proxy example.com"
  }
}

Wildcards

The '*' character can be used as a wildcard.

Domain wildcards

*.example.com will handle requests for all subdomains, but not example.com. *example.com will handle requests for all subdomains, including example.com.

In the following example the first configuration example.com will only proxy requests for example.com. While the second configuration \*.example.com will proxy all subdomains but not example.com.

{
  "example.com": {
    "active": true,
    "description": "Proxy example.com"
  },
  "*.example.com": {
    "active": true,
    "description": "Proxy subdomains of example.com"
  }
}

This snippet can be simplified to:

{
  "*example.com": {
    "active": true,
    "description": "Proxy example.com and all subdomains"
  }
}

Path wildcards (Only available for redirects)

/testing/* will redirect all requests for path /testing including sub paths i.e /testing/path_a

In the following example example.com/example_redirect and all sub paths will be redirected to example.com/temp_path.

{
  "example.com": {
    "paths": {
      "/example_redirect/*": {
        "path": "/temp_path",
        "active": true,
      }
    },
    "active": true,
  }
}

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

pyhttpintercept-0.34.1.tar.gz (903.7 kB view details)

Uploaded Source

Built Distribution

pyhttpintercept-0.34.1-py2.py3-none-any.whl (961.1 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file pyhttpintercept-0.34.1.tar.gz.

File metadata

  • Download URL: pyhttpintercept-0.34.1.tar.gz
  • Upload date:
  • Size: 903.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.9.6 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.10.1 urllib3/1.26.14 tqdm/4.64.1 importlib-metadata/4.8.3 keyring/23.4.1 rfc3986/1.5.0 colorama/0.4.5 CPython/3.6.15

File hashes

Hashes for pyhttpintercept-0.34.1.tar.gz
Algorithm Hash digest
SHA256 307e09de9f8f52208ccd70248155ae97f1a3cb7be15c2708a11442b1cc79a025
MD5 619042e29c5033d0203d78b61a8e2ed3
BLAKE2b-256 68332abfd9d34e3797df6ba51aaaba0a30e6eb95144b90340511e27d9b6e5c10

See more details on using hashes here.

File details

Details for the file pyhttpintercept-0.34.1-py2.py3-none-any.whl.

File metadata

  • Download URL: pyhttpintercept-0.34.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 961.1 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.9.6 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.10.1 urllib3/1.26.14 tqdm/4.64.1 importlib-metadata/4.8.3 keyring/23.4.1 rfc3986/1.5.0 colorama/0.4.5 CPython/3.6.15

File hashes

Hashes for pyhttpintercept-0.34.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 f0d1c7059a3eca7f5b4ab1eeb1dae9ca3069e3f6dd52a4e39017fbf2a7f0991e
MD5 3f664c62f06f0ddb234b5eb429344aa0
BLAKE2b-256 8a2201d7fc7e0d30ff86207eed7f01bd44529ee09826dd5f1ae0e92ffdee3896

See more details on using hashes here.

Supported by

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