Skip to main content

Bottle-wrapper to make python objects accessible via HTTP API

Project description

Nimrodel

A simple Bottle.py-wrapper to provide HTTP API access to any python object.

Requirements

  • Python 3.5 or higher

Quick Start

Install with

pip install nimrodel

Create your API with

from nimrodel import API

myapi = API()

You may optionally pass a port number with port=42, a path with path="api" and whether you want to serve on IPv4 (IPv6=False). You can also give the API object an existing bottle server (server=bottleobject), in which case your API will be served on the existing server. It is heavily recommended to also pass a path variable to separate API from regular routing of your server. You may also pass a custom function with parsedoc=yourfunction that takes your method as input and returns a dictionary with the values desc for the function description, params for a dictionary of parameter names mapped to a dictionary and returns for a dictionary of the return value. Both return and param dictionaries can have the keys type and desc for data type and description respectively. By default nimrodel will attempt to parse your docstring according to the reST standard (Sphinx).

Then make any class accessible with a decorator.

@myapi.apiclass("group")
class Group:

	def __init__(self,name,apipath,songs):
		# some stuff
		self.__apiname__ = apipath

Any instance of that class is now accessible via the combination of class path and its individual path. Now just decorate the methods. All its arguments can be passed via URI query arguments.

	@myapi.get("songs")
	def get_songs(self,member):
		return {"songs":[s["title"] for s in self.songs if member in s["performers"]]}

Now create an object and make sure it has an __apiname__ attribute:

e = Group("Exid","exid",exidsongs)

Then you can access its methods with simple HTTP calls like /group/exid/songs?member=Junghwa.

There is also an integrated graphical API explorer under /api_explorer.

Nimrodel also allows you to create a simple function-based API with the class EAPI.

For more in-depth exploration of the possibilities, refer to the file example.py included in the repository.

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

nimrodel-0.8.0.tar.gz (23.4 kB view details)

Uploaded Source

Built Distribution

nimrodel-0.8.0-py3-none-any.whl (29.8 kB view details)

Uploaded Python 3

File details

Details for the file nimrodel-0.8.0.tar.gz.

File metadata

  • Download URL: nimrodel-0.8.0.tar.gz
  • Upload date:
  • Size: 23.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/33.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.63.0 importlib-metadata/4.11.2 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.10

File hashes

Hashes for nimrodel-0.8.0.tar.gz
Algorithm Hash digest
SHA256 7fd5d5baf31730082a943c83b194c5ec07eaba3f4bff453fe3156c37e560b56d
MD5 1bd58c0f66015eafc7685f13fca1fac1
BLAKE2b-256 090ebb8ce1a078dbab7665452c03c99b38b56561c16ae22033cddd1b2571fe5c

See more details on using hashes here.

File details

Details for the file nimrodel-0.8.0-py3-none-any.whl.

File metadata

  • Download URL: nimrodel-0.8.0-py3-none-any.whl
  • Upload date:
  • Size: 29.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/33.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.63.0 importlib-metadata/4.11.2 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.10

File hashes

Hashes for nimrodel-0.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 08df134ac532e24189c037c61a2e4e7a817b198d604bcfc72f6eea5ef0e1a49d
MD5 116ad5e56576b43df474a3d42447ebde
BLAKE2b-256 1174387a543d6495f3d4c84cd67519d31157acb62fe4b9bf33bff456d1cbd384

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