Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/shawalli/flask-sqlalchemy-pgevents
Flask extension for psycopg2-pgevents, via SQLAlchemy.
https://github.com/shawalli/flask-sqlalchemy-pgevents
Last synced: 14 days ago
JSON representation
Flask extension for psycopg2-pgevents, via SQLAlchemy.
- Host: GitHub
- URL: https://github.com/shawalli/flask-sqlalchemy-pgevents
- Owner: shawalli
- License: mit
- Created: 2018-09-05T01:00:27.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2020-07-31T23:35:51.000Z (over 4 years ago)
- Last Synced: 2024-03-15T02:14:24.130Z (8 months ago)
- Language: Python
- Size: 44.9 KB
- Stars: 7
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.rst
- License: LICENSE.txt
Awesome Lists containing this project
- jimsghstars - shawalli/flask-sqlalchemy-pgevents - Flask extension for psycopg2-pgevents, via SQLAlchemy. (Python)
README
#########################
flask-sqlalchemy-pgevents
#########################.. image:: https://badge.fury.io/py/flask-sqlalchemy-pgevents.svg
:target: https://badge.fury.io/py/flask-sqlalchemy-pgevents
.. image:: https://coveralls.io/repos/github/shawalli/flask-sqlalchemy-pgevents/badge.svg?branch=master
:target: https://coveralls.io/github/shawalli/flask-sqlalchemy-pgevents?branch=master
.. image:: https://img.shields.io/badge/License-MIT-yellow.svg
:target: https://opensource.org/licenses/MITflask-sqlalchemy-pgevents provides PostGreSQL eventing for Flask. It handles
setting up the underlying database, registering triggers, and polling for
events.**************
Why Do I Care?
***************I have SQLAlchemy, which supports event listeners. Why do I care about this
extension?*SQLAlchemy's event listening framework is great for listening to database
changes made through SQLAlchemy. However, in the real world, not every data
event that affects a database takes place through SQLAlchemy; an application
may be created from any number of packages, libraries, and modules written
in different languages and with different frameworks. If any of these
non-SQLAlchemy items modify a database, SQLAlchemy will not know, and will
therefore not notify event listeners of these changes.With this extension, an application may be notified of events at the
*database layer*. This means that any changes made to a table are caught by
this extension and registered event listeners (for the affected table) are
called.*******************
Why Use SQLAlchemy?
********************You just said that SQLAlchemy has nothing to do with the eventing aspect
of this extension...So why are you using SQLAlchemy?*Great question! SQLAlchemy is primarily used as a convenience mechanism for
creating a consistent connection to the database.Additionally, many Flask applications use SQLAlchemy as their ORM. As such,
this extension will integrate seamlessly with any Flask applications that
use `Flask-SQLAlchemy `_. To
provide a consistent SQLAlchemy experience, this extension's event listener
decorator is designed to closely resemble SQLAlchemy event listener decorators.Note
While this extension may appear to integrate with SQLAlchemy's event
listeners, it actually sits alongside that eventing structure. Registering
a PGEvents event listener does not register the event listener with
SQLAlchemy's ``event`` registrar.********
Examples
********See the ``examples`` directory for example use cases for this package.
************
Future Plans
************* With a little bit of work, it should be possible to completely integrate this
extension's event listeners into ``SQLAlchemy.event``, so that event listeners
are functionally identical to SQLAlchemy's event listeners.* Currently, the only supported events are after-insert and after-update.
The ``psycopg2-pgevent`` package could be updated in coordination with this
extension to support other `SQLAlchemy mapper events
`_.**********
References
*********** `psycopg2-pgevents `_
* `SQLAlchemy `_
* `Flask-SQLAlchemy `_
**********************
Authorship and License
**********************Written by Shawn Wallis and distributed under the MIT license.