A modern object-oriented HTTP REST client.
Project description
Presto! Requests
An object-oriented REST API client & requests extesion library.
As of version 1.0.0, this library can be considered stable, and significant changes to the interface or new features are unlikely to be introduced.
Note: This library requires Python 3.11.0rc1 or later.
Installation
pip install presto-requests
poetry add presto-requests
With async support using httpx:
pip install presto-requests[async]
poetry add presto-requests --extras async
Concept:
Presto! Requests is a library that extends the functionality of the requests library. It provides a simple way to create a REST API client that is object-oriented and easy to use.
Example:
from presto import Presto
import pprint
presto = Presto("https://api.github.com")
user = presto.users.sitbon() # == presto.users["sitbon"]()
print(f"User {user.attr.login} has {user.attr.public_repos} public repositories.")
pprint.pprint(user.json())
User sitbon has 15 public repositories.
{'avatar_url': 'https://avatars.githubusercontent.com/u/1381063?v=4',
'bio': None,
'blog': '',
'company': None,
'created_at': '2012-01-26T04:25:21Z',
'email': None,
'events_url': 'https://api.github.com/users/sitbon/events{/privacy}',
'followers': 7,
'followers_url': 'https://api.github.com/users/sitbon/followers',
'following': 13,
'following_url': 'https://api.github.com/users/sitbon/following{/other_user}',
'gists_url': 'https://api.github.com/users/sitbon/gists{/gist_id}',
'gravatar_id': '',
'hireable': None,
'html_url': 'https://github.com/sitbon',
'id': 1381063,
'location': 'Portland, OR, USA',
'login': 'sitbon',
'name': 'Phillip Sitbon',
'node_id': 'MDQ6VXNlcjEzODEwNjM=',
'organizations_url': 'https://api.github.com/users/sitbon/orgs',
'public_gists': 4,
'public_repos': 15,
'received_events_url': 'https://api.github.com/users/sitbon/received_events',
'repos_url': 'https://api.github.com/users/sitbon/repos',
'site_admin': False,
'starred_url': 'https://api.github.com/users/sitbon/starred{/owner}{/repo}',
'subscriptions_url': 'https://api.github.com/users/sitbon/subscriptions',
'twitter_username': None,
'type': 'User',
'updated_at': '2022-11-22T00:41:18Z',
'url': 'https://api.github.com/users/sitbon'}
Usage:
Each dot in the path of the request is a new request object.
Calling the object without any arguments will execute the request and return the response object.
Indexing the object like a list is a convient way to extend the path to a new object for things
like id paths, e.g. presto("http://<base>").note[1]
maps to a request for http://<base>/note/1
and calling that object executes the request.
Specifying keyword arguments will add them to the request as keyword arguments to requests.request(), and then return the current object for further chaining.
There are a few special top-level attributes that can be used to modify the request:
get
, post
, put
, patch
, delete
, head
, options
, and finally request
which is
an empty path component that can be used to indirectly modify existing top-level auto created request objects.
All of these top-level attributes are able to clone existing request attributes, to modify the path and parent parameters while using the same component path and parameters.
For example:
from presto import Presto
presto = Presto(url="http://127.0.0.1:8000", APPEND_SLASH=True)
print("presto:", presto)
api = presto.api
print("api:", api)
note = api(headers={"X-User": "Testing"}).note
print("api.note:", api.note, "equal:", api.note == note)
resp = api.note[4]()
print("headers:", resp.request.headers)
print("response:", resp)
print("note:", resp.attr)
presto: Presto(url='http://127.0.0.1:8000/', params=adict(method='GET', headers={'Accept': 'application/json'}))
api: Request(url='http://127.0.0.1:8000/api/', params=adict(method='GET', headers={'Accept': 'application/json'}))
api.note: Request(url='http://127.0.0.1:8000/api/note/', params=adict(method='GET', headers={'Accept': 'application/json', 'X-User': 'Testing'})) equal: True
headers: {'User-Agent': 'python-requests/2.28.1', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/json', 'Connection': 'keep-alive', 'X-User': 'Testing'}
response: <Response [200]>
note: adict(user='', id=4, url='http://127.0.0.1:8000/api/note/4/', time='2022-12-02T19:26:09-0800', note='Hello from the API!!', collection={'id': 3, 'url': 'http://127.0.0.1:8000/api/note/coll/3/', 'name': 'Public', 'public': True, 'notes': 1})
response.attr
is an adict
instance, which is a dictionary that can be accessed as attributes.
It contains the JSON-decoded content of a response, if any.
APPEND_SLASH
is meant to be client implementation-specific, e.g. for a Django Rest Framework client, one would
typically set Presto.APPEND_SLASH = True
or inherit from Presto
in a pre-defined API client class.
Async Support
Version 1.0.0 adds support for async requests using the httpx
library.
The usage is the same as the synchronous version except when it comes to executing requests, so calls to request objects without parameters need to be awaited. See the example below.
import asyncio
from presto.asynco import AsyncPresto as Presto
async def main():
presto = Presto(url="http://127.0.0.1:8000", APPEND_SLASH=True)
print("presto:", presto)
api = presto.api
print("api:", api)
note = api(headers={"X-User": "Testing"}).note
print("api.note:", api.note, "equal:", api.note == note)
resp = await api.note[4]()
print("headers:", resp.request.headers)
print("response:", resp)
print("note:", resp.attr)
if __name__ == "__main__":
asyncio.run(main())
presto: AsyncPresto(url='http://127.0.0.1:8000/', params=adict(method='GET', headers={'Accept': 'application/json'}))
api: Request(url='http://127.0.0.1:8000/api/', params=adict(method='GET', headers={'Accept': 'application/json'}))
api.note: Request(url='http://127.0.0.1:8000/api/note/', params=adict(method='GET', headers={'Accept': 'application/json', 'X-User': 'Testing'})) equal: True
headers: Headers({'host': '127.0.0.1:8000', 'accept-encoding': 'gzip, deflate', 'connection': 'keep-alive', 'user-agent': 'python-httpx/0.23.1', 'accept': 'application/json', 'x-user': 'Testing'})
response: <Response [200 OK]>
note: adict(user='', id=4, url='http://127.0.0.1:8000/api/note/4/', time='2022-12-02T19:26:09-0800', note='Hello from the API!!', collection={'id': 3, 'url': 'http://127.0.0.1:8000/api/note/coll/3/', 'name': 'Public', 'public': True, 'notes': 1})
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
Built Distribution
File details
Details for the file presto_requests-1.3.4.tar.gz
.
File metadata
- Download URL: presto_requests-1.3.4.tar.gz
- Upload date:
- Size: 10.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.2.2 CPython/3.10.6 Linux/5.15.0-53-generic
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4751c46edfdb1c58212f31696ddac77e4edf49dffb09c0c102971c282a982e5a |
|
MD5 | 9cc0cb20ac5e403dd457af0ef4a98fa4 |
|
BLAKE2b-256 | f0bce33fb39ae465a8aaaafee127913f19a8de5c4aa63d7788dc7782cfd32a28 |
File details
Details for the file presto_requests-1.3.4-py3-none-any.whl
.
File metadata
- Download URL: presto_requests-1.3.4-py3-none-any.whl
- Upload date:
- Size: 8.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.2.2 CPython/3.10.6 Linux/5.15.0-53-generic
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1fbf2898065624fd671ce0a088013173fb4f8b600312ecbea808b735a20bf8b8 |
|
MD5 | 3631008a00dc49d495b4c47efdebd59f |
|
BLAKE2b-256 | 9d590a9030b0ee98745bc4b3329ecc8d0ca668b9a9e505abbe0e9da11867c921 |