Skip to main content

A modern Python HTTP client library with built-in authentication and response handling

Project description

make-api-request

A modern Python HTTP client library with built-in authentication and response handling.

Features

  • 🚀 Modern async/sync support - Built on httpx with full async/await support
  • 🔐 Built-in authentication - Support for API keys, Basic auth, Bearer tokens, and OAuth2
  • 📦 Type-safe - Full type hints with Pydantic models
  • 🔄 Flexible responses - Handle JSON, binary, and streaming responses
  • 🛡️ Error handling - Comprehensive API error handling with detailed context
  • Performance - Efficient request building and response parsing

Installation

pip install make-api-request

Or with Poetry:

poetry add make-api-request

Quick Start

Basic Usage

import asyncio
from make_api_request import AsyncBaseClient

async def main():
    client = AsyncBaseClient("https://api.example.com")
    
    # Simple GET request
    response = await client.get("/users")
    print(response)

asyncio.run(main())

With Authentication

from make_api_request import AsyncBaseClient, AuthBearer

async def main():
    # Bearer token authentication
    auth = AuthBearer("your-token-here")
    client = AsyncBaseClient(
        "https://api.example.com",
        auths={"bearer": auth}
    )
    
    response = await client.get("/protected-endpoint")
    print(response)

asyncio.run(main())

Synchronous Usage

from make_api_request import SyncBaseClient, AuthKey

# API key authentication
auth = AuthKey("x-api-key", "your-api-key")
client = SyncBaseClient(
    "https://api.example.com",
    auths={"api_key": auth}
)

response = client.get("/users")
print(response)

Authentication Types

API Key Authentication

from make_api_request import AuthKey

# Header-based API key
auth = AuthKey("x-api-key", "your-api-key")

# Query parameter API key  
auth = AuthKey("api_key", "your-api-key", location="query")

Bearer Token

from make_api_request import AuthBearer

auth = AuthBearer("your-jwt-token")

Basic Authentication

from make_api_request import AuthBasic

auth = AuthBasic("username", "password")

OAuth2

from make_api_request import OAuth2ClientCredentials

auth = OAuth2ClientCredentials(
    token_url="https://auth.example.com/token",
    client_id="your-client-id",
    client_secret="your-client-secret"
)

Advanced Usage

Custom Request Options

from make_api_request import RequestOptions

options = RequestOptions(
    timeout=30.0,
    headers={"Custom-Header": "value"},
    max_retries=3
)

response = await client.get("/endpoint", options=options)

Binary Responses

# Download a file
binary_response = await client.get("/download/file.pdf")
if isinstance(binary_response, BinaryResponse):
    with open("file.pdf", "wb") as f:
        f.write(binary_response.content)

Streaming Responses

async with client.stream("GET", "/large-dataset") as response:
    async for chunk in response.iter_content():
        process_chunk(chunk)

Error Handling

from make_api_request import ApiError

try:
    response = await client.get("/might-fail")
except ApiError as e:
    print(f"API Error: {e.status_code}")
    print(f"Response body: {e.body}")
    print(f"Full response: {e.response}")

API Reference

Client Classes

  • AsyncBaseClient - Asynchronous HTTP client
  • SyncBaseClient - Synchronous HTTP client
  • BaseClient - Base class for client implementations

Authentication

  • AuthKey - API key authentication (header or query parameter)
  • AuthBasic - HTTP Basic authentication
  • AuthBearer - Bearer token authentication
  • OAuth2 - Base OAuth2 authentication
  • OAuth2ClientCredentials - OAuth2 client credentials flow
  • OAuth2Password - OAuth2 resource owner password flow

Response Types

  • BinaryResponse - Binary content responses
  • StreamResponse - Streaming response handling
  • AsyncStreamResponse - Async streaming responses

Utilities

  • RequestOptions - Configure individual requests
  • QueryParams - Type-safe query parameter handling
  • ApiError - Comprehensive API error information

Development

Setup

git clone <repository-url>
cd make-api-request-py
poetry install

Run Tests

poetry run pytest

Code Quality

# Format code
poetry run black .

# Lint
poetry run ruff check .

# Type checking
poetry run mypy make_api_request/

License

MIT License - see LICENSE file for details.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

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

make_api_request-0.2.0.tar.gz (18.0 kB view details)

Uploaded Source

Built Distribution

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

make_api_request-0.2.0-py3-none-any.whl (20.0 kB view details)

Uploaded Python 3

File details

Details for the file make_api_request-0.2.0.tar.gz.

File metadata

  • Download URL: make_api_request-0.2.0.tar.gz
  • Upload date:
  • Size: 18.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for make_api_request-0.2.0.tar.gz
Algorithm Hash digest
SHA256 b806c0e32184f56a96f5eb42c17465f4a355e3032e1ff2b81d6107caca15ab97
MD5 ef140e6fb6ae526a41bf7b6a0dc9b54d
BLAKE2b-256 ce43f4abee0f2af8d4b066f79e07d662f7714c1d37210000c8f9394f0640c826

See more details on using hashes here.

Provenance

The following attestation bundles were made for make_api_request-0.2.0.tar.gz:

Publisher: release.yml on Sideko-Inc/make-request-py

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

File details

Details for the file make_api_request-0.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for make_api_request-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e06efc8433f0a7fabc78fe120f18ee04b87c4ad364782148039fc704cafc2f46
MD5 6023785c9b3ae9f32e7c7e939d78f360
BLAKE2b-256 27d5f06b370d1bb56f5433373334a3f54bdeaaafd2d97da3b1b250f9a5203eb9

See more details on using hashes here.

Provenance

The following attestation bundles were made for make_api_request-0.2.0-py3-none-any.whl:

Publisher: release.yml on Sideko-Inc/make-request-py

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