Skip to main content

Consume APIs and hold them to account.

Project description

Consume APIs and hold them to account.

Build Status Code Health Code Coverage Documentation Status Latest Version Supported Python versions

Not every API provider has an API as nice as Stripe and often their documentation is incorrect or (arguably better) non-existent.

Not every API provider can manage their release cycle, like inform customers, conform to semantic version numbers etc..

Chances are, if you’re reading this, you’re trying to talk to an API just like this.

You want to be sure, when you send them something, they give you the right thing back. That is, it contains the write shape of data and the correct data types and if you’re really persnickety, that it validates against defined rules.

Well, this Python library, with the help of schematics, will allow you to do just that.

Install

pip install eater

Usage

Not that this has ever happened to anyone, ever… but let’s say you are dealing with an API that you don’t necessarily trust. Perhaps the API is in flux because it’s alpha/beta or perhaps it’s not versioned and changes get made without notifying users. In any case, you want to be sure that what it says it does, it definitely does.

Using eater, first you define the API to be consumed, in part using schematics models.

import eater
from schematics import Model, IntegerType, StringType, BooleanType, ListType, ModelType

class Book(Model):
    title = StringType(required=True, min_length=3)


class Request(Model):
    """
    Represents, as a Python object, the JSON data required by the API.
    """
    in_print = BooleanType()


class Response(Model):
    """
    Represents, as a Python object, the JSON response returned by the API.
    """
    books = ListType(ModelType(Book))

class BooksAPI(eater.HTTPEater):
    url = 'https://example.com/books/'
    request_cls = Request
    response_cls = Response

You can then consume the API;

api = BooksAPI()
response = api(in_print=True)

for book in response.books:
    print(book.title)

See the full documentation at https://readthedocs.org/projects/eater

Author

Alex Hayes <alex@alution.com>

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

eater-0.1.0.tar.gz (901.9 kB view details)

Uploaded Source

Built Distribution

eater-0.1.0-py2.py3-none-any.whl (9.6 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file eater-0.1.0.tar.gz.

File metadata

  • Download URL: eater-0.1.0.tar.gz
  • Upload date:
  • Size: 901.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for eater-0.1.0.tar.gz
Algorithm Hash digest
SHA256 8f6119243d9fcadd4c3c81abf89b04d2b62cf788c26b009473088bc634ff2cbc
MD5 7c772b6392397b487e7a1b14b911591f
BLAKE2b-256 f00bb6d6ab014d60fa33e64825de6364b1fb6731843cdf49d839de76ae43d7bd

See more details on using hashes here.

File details

Details for the file eater-0.1.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for eater-0.1.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 e0cb80e9dd20b67ac182efcafb4a7e50778ce66e73f05b01d88165070a6f88b5
MD5 04c286a20cf1861d961a31f0c6a60df3
BLAKE2b-256 ec8c15c8fd704a39d10c33ca84c5a7b0a81e07b26b3b0273b65f90e0931c66ff

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