Skip to main content

Automated REST APIs for existing database-driven systems

Project description

sandman “makes things REST”. Have an existing database you’d like to expose via a REST API? Normally, you’d have to write a ton of boilerplate code for the ORM you’re using.

We’re programmers. We don’t write boilerplate.

Simple Setup

from sandman import app, db

app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///chinook'

from sandman.model import register, Model

class Artist(Model):
    __tablename__ = 'Artist'

class Album(Model):
    __tablename__ = 'Album'

class Playlist(Model):
    __tablename__ = 'Playlist'

register((Artist, Album, Playlist))

app.run()

Let’s start our new API server and make a request.

$ python runserver.py &
* Running on http://127.0.0.1:5000/

$ curl GET http://localhost:5000/artists

Here is the JSON returned:

{
    "ArtistId": 273,
    "Name": "C. Monteverdi, Nigel Rogers - Chiaroscuro; London Baroque; London Cornett & Sackbu",
    "links": [
    {
        "rel": "self",
        "uri": "/artists/ArtistId"
    }
    ]
},
{
    "ArtistId": 274,
    "Name": "Nash Ensemble",
    "links": [
    {
        "rel": "self",
        "uri": "/artists/ArtistId"
    }
    ]
},
{
    "ArtistId": 275,
    "Name": "Philip Glass Ensemble",
    "links": [
    {
        "rel": "self",
        "uri": "/artists/ArtistId"
    }
    ]
}
]

Batteries Included

With sandman, (almost) zero boilerplate code is required. Your existing database structure and schema is introspected and your database tables magically get a RESTful API. For each table, Sandman creates:

  • proper endpoints

  • support for a configurable set of HTTP verbs

    • GET

    • POST

    • PATCH

    • DELETE

  • responses with appropriate rel links automatically

  • essentially a HATEOAS-based service sitting in front of your database

Warning: Sandman is still very much a work in progress. It is not suitable for use anywhere. Don’t use it for anything important. It’s also often changing in backwards incompatible ways.

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

sandman-0.2.3.1.tar.gz (8.7 kB view details)

Uploaded Source

File details

Details for the file sandman-0.2.3.1.tar.gz.

File metadata

  • Download URL: sandman-0.2.3.1.tar.gz
  • Upload date:
  • Size: 8.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for sandman-0.2.3.1.tar.gz
Algorithm Hash digest
SHA256 700d6962d47656a4160ea8216a125df2e96b5f2336963082852c838b44b76584
MD5 b11b18842b27238f8635c16176f2953e
BLAKE2b-256 c8bdeacacbe71d22ebae89237dd5b8d4524498e97add4e323eea3d068f66ded3

See more details on using hashes here.

Provenance

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