RESTful != HTTP.
Work in progress.
This is a framework for bringing RESTful Resources to your Python applications. It can be used in a few ways:
- To add a RESTful interface to your existing codebase.
- To power the backbone of your entire application.
- Simple API — makes no assumptions
- Event/Signaling System
- 'hyperlink' support (Resource references)
- Custom Verb Support (HTTP verbs out of the box)
- Content Negotiation
Potentially:
from resources import Interface, Resource api = Interface() @api.map('bookmarks') class Bookmarks(Resource): """Haystack's Bookmarks Resource.""" __bookmarks = {} def element_get(self, ri): return self.__bookmarks.get(ri) ... # json content, element/collection put, &c
Now we have an API w/ a single resource: bookmarks
. We can access it
like so:
>>> api.bookmarks <resource 'bookmarks'> >>> api.bookmarks['00001'] <element <bookmarks:00001> >>> api.bookmarks['00001'].get() <bookmark 000001> >>> api.bookmarks['00001'].content('json').get() '{"bookmark": {"id": "00001"}}'
- Build a set of web framework plugins for serving Resources via HTTP (e.g. flask-resources, django-resources).
- Build a Resources-Client module for consuming RESTful web APIs (powered by Requests).
ISC.