Skip to main content

SQLAlchemy integration for API Star.

Project description

API Star SQLAlchemy
===================
|build-status| |coverage| |version|

:Version: 0.3.2
:Status: Production/Stable
:Author: José Antonio Perdiguero López

SQLAlchemy integration for API Star.

Features
--------
This library provides **components** for injecting SQLAlchemy ORM sessions into your views and **event_hooks** to
handle commit/rollback behavior based on exceptions in your views.

Quick start
-----------
Install API Star SQLAlchemy:

.. code:: bash

pip install apistar-sqlalchemy

Create an API Star application adding components and event hooks:

.. code:: python

from apistar_sqlalchemy.components import SQLAlchemySessionComponent
from apistar_sqlalchemy.event_hooks import SQLAlchemyTransactionHook

routes = []

components = [
SQLAlchemySessionComponent(url='sqlite://'),
]

event_hooks = [
SQLAlchemyTransactionHook(),
]

app = App(routes=routes, components=components, event_hooks=event_hooks)

Now you can inject SQLAlchemy Session into your views:

.. code:: python

from sqlalchemy.orm import Session

def sqlalchemy_view(session: Session):
# do something
return {'message': 'something done'}

Forget about **commit** and **rollback** because there is an event hook that will handle it for you.

Full example
------------

.. code:: python

from typing import List

from apistar import App, Route, http, types, validators
from sqlalchemy import Column, Integer, String
from sqlalchemy.orm import Session

from apistar_sqlalchemy.components import SQLAlchemySessionComponent
from apistar_sqlalchemy.event_hooks import SQLAlchemyTransactionHook
from apistar_sqlalchemy import database


class PuppyModel(database.Base):
__tablename__ = "Puppy"
id = Column(Integer, primary_key=True, autoincrement=True)
name = Column(String)


class PuppyType(types.Type):
id = validators.Integer(allow_null=True, default=None)
name = validators.String()


def list_puppies(session: Session) -> List[PuppyType]:
return [PuppyType(puppy) for puppy in session.query(PuppyModel).all()]


def create_puppy(session: Session, puppy: PuppyType) -> http.JSONResponse:
model = PuppyModel(**puppy)
session.add(model)
session.flush()
return http.JSONResponse(PuppyType(model), status_code=201)


routes = [
Route('/puppy/', 'POST', create_puppy),
Route('/puppy/', 'GET', list_puppies),
]

components = [
SQLAlchemySessionComponent(url='sqlite://'),
]

event_hooks = [
SQLAlchemyTransactionHook(),
]

app = App(routes=routes, components=components, event_hooks=event_hooks)


.. |build-status| image:: https://travis-ci.org/PeRDy/apistar-sqlalchemy.svg?branch=master
:alt: build status
:scale: 100%
:target: https://travis-ci.org/PeRDy/apistar-sqlalchemy
.. |coverage| image:: https://codecov.io/gh/PeRDy/apistar-sqlalchemy/branch/master/graph/badge.svg
:alt: coverage
:scale: 100%
:target: https://codecov.io/gh/PeRDy/apistar-sqlalchemy/branch/master/graph/badge.svg
.. |version| image:: https://badge.fury.io/py/apistar-sqlalchemy.svg
:alt: version
:scale: 100%
:target: https://badge.fury.io/py/apistar-sqlalchemy


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

apistar-sqlalchemy-0.3.2.tar.gz (16.7 kB view details)

Uploaded Source

Built Distribution

apistar_sqlalchemy-0.3.2-py3-none-any.whl (16.5 kB view details)

Uploaded Python 3

File details

Details for the file apistar-sqlalchemy-0.3.2.tar.gz.

File metadata

File hashes

Hashes for apistar-sqlalchemy-0.3.2.tar.gz
Algorithm Hash digest
SHA256 9ae07aa0e63b23590ec25797e74d98b878f634b49ac4ca2690fd370477169f21
MD5 fffb80f38996b4b3e29cce31f8452c24
BLAKE2b-256 e15abfe2319f837de7352856f04e06afeae99f941006db4377431afd20023d3b

See more details on using hashes here.

File details

Details for the file apistar_sqlalchemy-0.3.2-py3-none-any.whl.

File metadata

File hashes

Hashes for apistar_sqlalchemy-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 861d3a44ad355640881c375ec476c676fa5e5f5539f3d731c32b0bf99ffd105c
MD5 0ed7914db4e8342afb7d327ac3908aae
BLAKE2b-256 26e04b107b976fd9d1b6066ba7115f4dde8ab459660b2e11f8488cfa9bba9bef

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