Skip to main content

RESTful (micro)server that can build an API in minutes.

Project description

Pypi Build Status Coverage Code Climate

Efesto is a RESTful (micro)server that can be used for building an API in minutes. It takes care of authentication, permissions and kickstarts you by providing a simple way to build a data structure and the means to expose it.

Efesto follows the UNIX principle of doing one thing and well, leaving you the freedom of choice about other components (e.g. caching, rate-limiting, load balancer).

When do I use this?

  • You need a full-fledged ReST API

  • You are fine using Siren as hypermedia specification

  • You need authentication and permissions but want the work already done

  • You are fine with using PostgreSQL

  • You want to be able to create models without writing code (Python or SQL)

  • You need to easily import and export the models you created

  • You have Python3.4+ on your production server :)

Installing

You will need to install and configure PostgreSQL, and a server like uwsgi or gunicorn:

pip3 install efesto

Configure Efesto, editing the configuration file. At the very minimum you will need to provide the database details:

vim efesto.cfg

Use efesto-quickstart to have tables and admin created:

efesto-quickstart

Done! Now you can run your server and launch Efesto:

gunicorn efesto.App:app

The first request

Efesto only allows authenticated users to make requests, so first authenticate yourself using the /auth endpoint. You will receive an access token that should be sent in the Auth header:

POST http://myhost.com/auth
username=myuser&password=mypasswd

{'token':'someverylongtoken'}

Now that you have a token, you can make requests! For example, to get a list of users:

GET http://myhost.com/users
Authorization: Basic anystring:someverylongtoken

# [ ... list of users ]

More

Read the documentation at http://efesto.readthedocs.io for extra internet points!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

efesto-0.7.2-py3-none-any.whl (22.7 kB view hashes)

Uploaded Python 3

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