Skip to main content

A simple, flexible Python HTTP client and API modeling toolkit built on httpx and pydantic.

Project description

PyPI version Python Development Status Maintenance PyPI License


pyrest-model-client

A simple, flexible Python HTTP client and API modeling toolkit built on top of httpx and pydantic. Easily integrate robust API requests and resource models into your Python projects.


🚀 Features

  • Model-driven: Define and interact with API resources as Python classes using BaseAPIModel.
  • Easy HTTP Requests: Simple RestApiClient for GET, POST, PUT, DELETE with automatic header and base URL management.
  • Async Support: Full async/await support with AsyncRestApiClient for high-performance concurrent requests.
  • Automatic Endpoint Normalization: Configurable endpoint path normalization (trailing slash handling).
  • Resource Path Integration: Models can use their resource_path to generate endpoints and URLs automatically.
  • Flexible Authentication: Support for Token and Bearer authentication via build_header() helper.
  • Response to Model Conversion: get_model_fields() helper converts API responses to typed model instances.
  • Configurable Client: Customizable timeout, connection pool limits, and redirect handling.
  • Type Safety: All models use Pydantic for automatic validation and serialization.
  • Error Handling: Automatic HTTP status error handling with raise_for_status().
  • Extensible: Easily create new models for any RESTful resource by extending BaseAPIModel.

📦 Installation

uv add pyrest-model-client

🔧 Usage

1. Define Your Models

from pyrest_model_client.base import BaseAPIModel


class User(BaseAPIModel):
    name: str
    email: str
    resource_path: str = "user"


class Environment(BaseAPIModel):
    name: str
    resource_path: str = "environment"

2. Initialize the Client and Make Requests

import os

from dotenv import load_dotenv

from pyrest_model_client import RestApiClient, build_header, get_model_fields
from pyrest_model_client.base import BaseAPIModel

load_dotenv()

TOKEN = os.getenv("TOKEN")
BASE_URL = f'{os.getenv("BASE_URL")}:{os.getenv("PORT")}'


class FirstApp(BaseAPIModel):
    """
    Model representing the FirstApp API resource. The fields should match the API response structure.
    The app resource path is defined as "first_app" in the API.
    """
    name: str
    description: str | None = None
    resource_path: str = "first_app"


# Initialize the client with default settings
header = build_header(token=TOKEN)
client = RestApiClient(base_url=BASE_URL, header=header)

# Or configure the client with custom settings
import httpx
client = RestApiClient(
    base_url=BASE_URL,
    header=header,
    timeout=httpx.Timeout(60.0, connect=10.0),  # 60s read, 10s connect
    add_trailing_slash=True,  # Automatically add trailing slashes
    limits=httpx.Limits(max_keepalive_connections=5, max_connections=10)
)

# Example: Use resource_path from model
app = FirstApp(name="My App", description="Test")
endpoint = app.get_endpoint()  # Returns "first_app"
full_url = app.get_resource_url(client)  # Returns full URL

# Example: Get all items from the API (paginated) and convert them to model instances
item_list = []
params = None
while res := client.get("first_app", params=params):
    item_list.extend(get_model_fields(res["results"], model=FirstApp))

    if not res["next"]:
        break
    params = {"page": res["next"].split("/?page=")[-1]}

# Example: Create a new item
new_item = client.post("first_app", data={"name": "My App", "description": "A new app"})

# Example: Update an item
updated_item = client.put("first_app/1", data={"name": "Updated App"})

# Example: Delete an item
client.delete("first_app/1")

3. Using Async Client

import os
import asyncio

from dotenv import load_dotenv
from pyrest_model_client import AsyncRestApiClient, build_header
from pyrest_model_client.base import BaseAPIModel

load_dotenv()

TOKEN = os.getenv("TOKEN")
BASE_URL = f'{os.getenv("BASE_URL")}:{os.getenv("PORT")}'

async def main():
    header = build_header(token=TOKEN)

    # Use async client as context manager
    async with AsyncRestApiClient(base_url=BASE_URL, header=header) as client:
        # Make async requests
        response = await client.get("first_app")
        new_item = await client.post("first_app", data={"name": "Async App"})
        updated = await client.put("first_app/1", data={"name": "Updated"})
        await client.delete("first_app/1")

asyncio.run(main())

🤝 Contributing

Contributions are welcome! Please fork the repo, create a branch, and submit a pull request.


📄 License

MIT License — see LICENSE for details.

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

pyrest_model_client-1.1.0.tar.gz (10.7 kB view details)

Uploaded Source

Built Distribution

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

pyrest_model_client-1.1.0-py3-none-any.whl (7.8 kB view details)

Uploaded Python 3

File details

Details for the file pyrest_model_client-1.1.0.tar.gz.

File metadata

  • Download URL: pyrest_model_client-1.1.0.tar.gz
  • Upload date:
  • Size: 10.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pyrest_model_client-1.1.0.tar.gz
Algorithm Hash digest
SHA256 3bf2e580be13daf772de0fa6a82ddd250a6b54c4d39b2ab6373d54f7eb1bf6e5
MD5 10e5e77cfefee4f388057794801e2641
BLAKE2b-256 ba69b44f7b828ed306d3d44c7e684b96d87e0ed1714f30893c58760187a943a0

See more details on using hashes here.

File details

Details for the file pyrest_model_client-1.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for pyrest_model_client-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 17a0455cf66757e70ee24330fdc342ae7410c69087364a561e987632ce7bf149
MD5 60dda4d0b84d15c94a6d3f232dfa4b7f
BLAKE2b-256 c321aeb4e8b657ce887667607ddc3f416f6aa84a0498fa8c0c20bee9b91daffe

See more details on using hashes here.

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