Skip to main content

Minimal Request Finder is a analysis tool to determine the minimum valid API request data (including headers, query params, and payload) required to receive a valid response from an endpoint. It is designed to help in the process of reverse engineering complex third party API's and identifying the smallest, most efficient request that can be made.

Project description

Introduction

minimalrequest is a analysis tool to determine the minimum valid API request data (including headers, query params, and payload) required to receive a valid response from an endpoint. It is designed to help in the process of reverse engineering complex third party API's and identifying the smallest, most efficient request that can be made.

Installation

pip install minimalrequest

Methodology

minimalrequest works by applying a simple algorithm to pare down requests.

  1. An initial request is passed that might contain extra headers, query params, or JSON payload data that doesn't effect the value of the JSON response received. A request to that endpoint is made and the response is saved as the "reference" response.
  2. Each request element (this could be a header, query param, or JSON payload property) is removed and a test request is sent.
  3. If the test request suceeds, the test response is compared to the reference response using one of several equivalency modes.
  4. If the test response is deemed equivalent to the reference response, the request element is removed.

Usage

All functionality is exposed through the minimal_request_finder function.

from minimalrequest import minimal_request_finder

Initial requests can be passed as a curl command:

result = minimal_request_finder(
    curl="""
        curl -XPOST -H 'header-one: one' -H 'header-two: two' -H 'header-three: three' -H "Content-Type: application/json" -d '{
            "property1": {"subproperty1": "one", "subproperty2": "two"},
            "property2": [1, 2, 3, 4, 5]
        }' 'https://api.com/endpoint/v1/test?param1=1&param2=2&param3=3'
    """
)

or can be passed as individual arguments:

result = minimal_request_finder(
    http_method="post",
    url="https://api.com/endpoint/v1/test",
    query_params={"param1": "value", "param2": "value"},
    headers={"Content-Type": "application/json"},
    payload={"requestData": {"query": "test", "pages": 2}}
)

Results are returned as a MinimalRequestResult which contains the url and minimal query_params, headers, and payload.

Equivalency Modes

The minimal_request_finder function accepts an equivalency_mode argument to change the method used to check equivalency between the reference response and test responses.

Exact Equivalency

Setting the equivalency_mode to exact (it's default value) will only consider the test response and reference to be equivalent when their parsed Python object representations are exactly the same (==). This mode is intended for API's with a completely deterministic output based on each input.

Types Equivalency

The types equivalency mode compares each response object property or array element for data type equivalency rather than exact values. This mode can be useful any time an API response should have constant data structure, but some amount of variable or random content, such as a timestamp or hash value.

The types mode works with the types_check_exact_list_equivalency flag (defaults to True). If set to False, the equivalency check allows the number of elements in arrays throughout the response to vary in length between the test and reference response as long as any existing array elements pass the type check. This flag can be useful if your API response contains arrays of variable or random length, such as events over a given time period.

Size Equivalency

For highly variable API responses that might not work with other modes, the size equivalency mode can be used. This check converts the reference and test responses into JSON string representations and passes equivalency if the test response size in bytes is within some percent tolerance of the reference response size. The size_equivalency_tolerance argument (default value of 0.05) sets this tolerance value.

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

minimalrequest-2.0.2.tar.gz (14.1 kB view details)

Uploaded Source

Built Distribution

minimalrequest-2.0.2-py3-none-any.whl (12.7 kB view details)

Uploaded Python 3

File details

Details for the file minimalrequest-2.0.2.tar.gz.

File metadata

  • Download URL: minimalrequest-2.0.2.tar.gz
  • Upload date:
  • Size: 14.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for minimalrequest-2.0.2.tar.gz
Algorithm Hash digest
SHA256 fb0fc30d34eabec5a4f23c971b3d3de63aa54aff68d1b55824f2b9be918ec714
MD5 e1ceeac22b6648e5c37cc50044346ba4
BLAKE2b-256 e1a5398a34b7cba4dacbb56988561c283b5164d1a78363ecb372e7020e27093b

See more details on using hashes here.

Provenance

The following attestation bundles were made for minimalrequest-2.0.2.tar.gz:

Publisher: release.yml on ebier92/minimalrequest

Attestations:

File details

Details for the file minimalrequest-2.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for minimalrequest-2.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 9c8906e571ffdfceb1a3dafb9d246729c922f102882626edc7363b0562e3af23
MD5 e347b285305565242b20c821acf09b52
BLAKE2b-256 dac246d50acf6c296cd85a381de3199a1313acdec5e7d1cb24e8a12d22f1cafa

See more details on using hashes here.

Provenance

The following attestation bundles were made for minimalrequest-2.0.2-py3-none-any.whl:

Publisher: release.yml on ebier92/minimalrequest

Attestations:

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