Skip to main content

The Python framework that provides a quick way to build robust HTTP requests. Use type hints, to build requests, with little or no implementation

Project description

sensei

Logo Banner


Build robust HTTP Requests with minimal implementation

Python versions PyPi Version Coverage

The Python framework that provides a quick way to build robust HTTP requests. Use type hints, to build requests, with little or no implementation


Documentation: https://sensei.crocofactory.dev

Source code: https://github.com/CrocoFactory/sensei


There are key features provided by sensei:

  • Fast: Do not write any request-handling code, dedicate responsibility to the function's interface(signature)
  • Short: Avoid code duplication.
  • Sync/Async: Implement sync and async quickly, without headaches
  • Robust: Auto validation data before and after request

Quick Overview

API Wrapper should provide these features for users:

  • Provide sync and async code versions
  • Validate data before accessing the API.
  • Handle RPS (Requests per second) limits.
  • Return relevant response

And as a developer, you want to avoid code duplication and make routine things faster. To follow all these principles, you either violate DRY or have to maintain bad code architecture.

Sensei is a tool to avoid these issues.

First Request

Do you want to see the simplest and most robust HTTP Request? He's already here!

from typing import Annotated
from sensei import Router, Path, APIModel

router = Router('https://pokeapi.co/api/v2/')


class Pokemon(APIModel):
    name: str
    id: int
    height: int
    weight: int


@router.get('/pokemon/{name}')
def get_pokemon(name: Annotated[str, Path(max_length=300)]) -> Pokemon: 
    ...


pokemon = get_pokemon(name="pikachu")
print(pokemon)

Sensei abstracts away much of the manual work, letting developers focus on function signatures while the framework handles the API logic and data validation. This enables a declarative style for your apps.

The example of First Request demonstrates a simple and robust HTTP request using the Sensei framework. Here's the key breakdown of the process:

1. Importing Dependencies:

  • Router manages API endpoints and routing.
  • Path specifies and validates route parameters.
  • APIModel defines models for structuring API responses (similar to pydantic.BaseModel).

2. Creating the Router:

The Router is initialized with the base URL of the PokéAPI. All subsequent requests will use this as the base path.

3. Defining the Model:

The Pokemon class represents the data structure for a Pokémon, with fields like name, id, height, and weight. It inherits from APIModel, which provides validation and serialization.

4. Creating the Endpoint:

The get_pokemon function is a routed function decorated with @router.get, defining a GET request for /pokemon/{name}. This uses Annotated to ensure that name is a string and adheres to the validation rule (max length of 300).

5. Making the Request:

By calling get_pokemon(name="pikachu"), Sensei automatically handles validation, makes the HTTP request, and maps the API response into the Pokemon model. The code omits the function body since Sensei handles calls through the function's signature.

Installing sensei

To install sensei from PyPi, you can use that:

pip install sensei

To install sensei from GitHub, use that:

pip install git+https://github.com/CrocoFactory/sensei.git

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

sensei-0.1.1.tar.gz (75.0 kB view details)

Uploaded Source

Built Distribution

sensei-0.1.1-py3-none-any.whl (39.1 kB view details)

Uploaded Python 3

File details

Details for the file sensei-0.1.1.tar.gz.

File metadata

  • Download URL: sensei-0.1.1.tar.gz
  • Upload date:
  • Size: 75.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.6 Darwin/24.0.0

File hashes

Hashes for sensei-0.1.1.tar.gz
Algorithm Hash digest
SHA256 a2a947a1ec780064168a7f898f30684e705dc35951637cb5eed50cbf46f6dac7
MD5 357f0706642ba8fabbafb970b9474ede
BLAKE2b-256 7457e74eefbc1c2eee89579bab774ee020e081d8e6593ce5040ea2ea1ae0997a

See more details on using hashes here.

File details

Details for the file sensei-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: sensei-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 39.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.6 Darwin/24.0.0

File hashes

Hashes for sensei-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 4912d3c9ae43ad27d6efe8d75505c2fbad85065a90a34b6e5d424e416b411027
MD5 9bf244e51e2f63bf8bf82b5de4f0fc60
BLAKE2b-256 779237c7841b2d5f90de5aee788efdd1a9613c92cba7883efd281a72c24657ae

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