REST API calls made easier
Project description
RESTEasy
REST API calls made easier
Installation
pip install resteasy
Usage and examples
Import
from resteasy import RESTEasy, json
api = RESTEasy(base_url='https://api.example.com',
auth=('user', '****'),
verify=False, cert=None, timeout=None,
encoder=json.dumps, decoder=json.loads, debug=False)
# optional timeout
api.timeout = 60
Example 1: GitHub Jobs
api = RESTEasy(base_url='https://jobs.github.com')
positions = api.route('positions.json')
positions.get(description='python', full_time=1)
# or
positions.do('GET', {'description': 'python', 'full_time': 1})
# GET https://jobs.github.com/positions.json?description=python&full_time=1
Example 2: All methods: GET, POST, PUT, PATCH, DELETE
from resteasy import RESTEasy
api = RESTEasy(base_url='https://jsonplaceholder.typicode.com')
posts = api.route('posts')
### GET (fetch resources)
posts.get()
posts.get(userId=1)
posts.route(1).get()
### POST (create a resource)
posts.post(title='foo', body='bar', userId=1)
### PUT & PATCH (update a resource)
posts.route(1).put(id=1, title='foo', body='bar', userId=1)
posts.route(1).patch(title='foo')
### DELETE (delete a resource)
posts.route(1).delete()
Example 3: Chuck Norris jokes
from __future__ import print_function
from resteasy import RESTEasy
api = RESTEasy(base_url='https://api.chucknorris.io')
### Print a random joke
jokes = api.route('jokes')
random = jokes.route('random')
print(random.get())
# GET https://api.chucknorris.io/jokes/random
### Get all categories
categories = jokes.route('categories').get()
print(categories)
# GET https://api.chucknorris.io/jokes/categories
### Print a random joke from each category
for category in categories:
random_joke = random.get(category=category)
print(category, ':', random_joke['value'])
# GET https://api.chucknorris.io/jokes/random?category=<category>
Example 4: Using custom decoder: Parsing MyAnimeList HTML content
from resteasy import RESTEasy
from html.parser import HTMLParser
class MyHTMLParser(HTMLParser):
'''Custom HTML parser'''
def handle_starttag(self, tag, attrs):
'''Overriding abstract method'''
if tag == 'title' and not self.found:
self.found = True
def handle_data(self, data):
'''Overriding abstract method'''
if self.found and self.anime is None:
self.anime = data
def parse(self, content):
'''Parse content and return object'''
self.found = False
self.anime = None
self.feed(content)
title = self.anime.strip().replace(' - MyAnimeList.net', '') if self.found else None
return dict(title=title)
parser = MyHTMLParser()
api = RESTEasy(base_url='https://myanimelist.net', decoder=parser.parse)
### One way
api.route('anime/1').get()
### Another way
api.route('anime', 1).get()
### Yet another way
api.route('anime').route(1).get()
### This is the last way I swear
api.route('anime').route(1).do('GET')
# GET https://myanimelist.net/anime/1
Debugging
To enable debugging just pass or set debug=True
api.debug = True
Once debugging is set to 'True', Every HTTP call will return debug information instead of doing the actual request
>>> posts.debug = True
>>> posts.get(userId=1)
{'endpoint': 'https://jsonplaceholder.typicode.com/posts',
'kwargs': {'userId': 1},
'method': 'GET',
'session': <requests.sessions.Session at 0x7f1e8c8bfeb8>}
Exceptions
-
As this package uses requests module to perform HTTP calls, most exceptions will be raised by requests module itself.
-
In case API server returns HTTP status code outside the range of 200-299, It will raise resteasy.HTTPError
-
In case the returned content by API server is not parsable, It will raise resteasy.InvalidResponseError
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 RESTEasy-1.0.4.tar.gz
.
File metadata
- Download URL: RESTEasy-1.0.4.tar.gz
- Upload date:
- Size: 5.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.0 setuptools/40.4.3 requests-toolbelt/0.8.0 tqdm/4.27.0 CPython/3.5.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a4578df346cc03a4543bb11eb9cd9f51bddfba8a8a90bd3bfe022c23ee224a3a |
|
MD5 | 133af6e520c7f742395cff29cd0099df |
|
BLAKE2b-256 | dd90aa0f8a254e6eaa2f987bc2cc95b1bebe25d3de1304ad5dab44e4d6ddccf3 |
File details
Details for the file RESTEasy-1.0.4-py3-none-any.whl
.
File metadata
- Download URL: RESTEasy-1.0.4-py3-none-any.whl
- Upload date:
- Size: 5.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.0 setuptools/40.4.3 requests-toolbelt/0.8.0 tqdm/4.27.0 CPython/3.5.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b1ec0b2fa6bd04b11f93a2bffb2d785132b290235b267e5f0f118bbf2209361b |
|
MD5 | 1e3031eb84622a3861cc369101d1d2c6 |
|
BLAKE2b-256 | 775fffe3a8afbcf8d1ed382ce622bb1deb14bd138de654d21b486deb1d35ddfa |