2018-10-26 18:14:27 +02:00
|
|
|
from .config import DATABASE_NAME
|
|
|
|
from .config import DATABASE_USER
|
|
|
|
from .config import DATABASE_PASS
|
|
|
|
from .config import DATABASE_HOST
|
2018-11-03 22:40:45 +02:00
|
|
|
from .config import DATABASE_PORT
|
2018-11-10 23:58:58 +02:00
|
|
|
import falcon
|
2018-11-03 23:55:23 +02:00
|
|
|
import psycopg2
|
|
|
|
import psycopg2.extras
|
|
|
|
|
2018-09-25 00:49:47 +03:00
|
|
|
|
2018-11-07 17:41:21 +02:00
|
|
|
class DatabaseManager():
|
|
|
|
'''Manage database connection.'''
|
2018-09-24 00:00:05 +03:00
|
|
|
|
2018-11-07 17:41:21 +02:00
|
|
|
def __init__(self):
|
|
|
|
self._connection_uri = 'dbname={} user={} password={} host={} port={}'.format(DATABASE_NAME, DATABASE_USER, DATABASE_PASS, DATABASE_HOST, DATABASE_PORT)
|
|
|
|
|
|
|
|
def __enter__(self):
|
2018-11-10 23:58:58 +02:00
|
|
|
try:
|
|
|
|
self._connection = psycopg2.connect(self._connection_uri, cursor_factory=psycopg2.extras.DictCursor)
|
|
|
|
except psycopg2.OperationalError:
|
|
|
|
title = '500 Internal Server Error'
|
|
|
|
description = 'Could not connect to database'
|
|
|
|
raise falcon.HTTPInternalServerError(title, description)
|
|
|
|
|
2018-11-07 17:41:21 +02:00
|
|
|
return self._connection
|
|
|
|
|
|
|
|
def __exit__(self, exc_type, exc_value, exc_traceback):
|
|
|
|
self._connection.close()
|
2018-09-24 00:00:05 +03:00
|
|
|
|
2018-09-23 16:47:00 +03:00
|
|
|
# vim: set sw=4 ts=4 expandtab:
|