Base HTTP service client
Project description
A base HTTP service client.
By default it “demands” successful responses from API endpoints, otherwise it raises an exception.
Demands accepts all the same parameters as requests.request and extends the requests.Session class, documentation for both: Requests Developer Interface.
Written and used by the folks at Yola to support our free website builder.
HTTPServiceClient Overview
base class for creating service clients
provides flexible way of http error handling for descendants
HTTPServiceError raised on unexpected service response
Supports pre-send and post-send hooks
Usage
from demands import HTTPServiceClient
class MyService(HTTPServiceClient):
def get_user(self, user_id):
return self.get('/users/%s/' % user_id).json()
def safe_get_user(self, user_id, default_user):
response = self.get(
'/users/%s/' % user_id,
expected_response_codes=[404])
return response.json() if response.is_ok else default_user
service = MyService(url='http://localhost/')
user = service.get_user(1234)
Any parameters passed to the constructor will also be used for each and every request:
service = MyService(
url='http://localhost/',
headers={'h1':'value'},
auth=('username','pass'),
)
# sent with auth and both headers
user = service.get('/some-path', headers={'h2': 'kittens'})
Testing
Install development requirements:
pip install -r requirements.txt
Run the tests with:
nosetests
API documentation
To generate the documentation:
cd docs && PYTHONPATH=.. make singlehtml
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
File details
Details for the file demands-3.0.0.tar.gz
.
File metadata
- Download URL: demands-3.0.0.tar.gz
- Upload date:
- Size: 12.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 796bad2385ce1f26b21abafa49c8e66738c37417d4229a5e89506a6f19355163 |
|
MD5 | e88e97164343d8abdd9e8cdaf6c692d9 |
|
BLAKE2b-256 | 27c2897a2c9d6ff860270fd360309d67253f34788f273df187c00c46f458597e |