You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
|
"""EasyEngine generic database creation module"""
|
|
|
|
from sqlalchemy import create_engine
|
|
|
|
from sqlalchemy.orm import scoped_session, sessionmaker
|
|
|
|
from sqlalchemy.ext.declarative import declarative_base
|
|
|
|
from ee.core.variables import EEVariables
|
|
|
|
|
|
|
|
# db_path = self.app.config.get('site', 'db_path')
|
|
|
|
engine = create_engine(EEVariables.ee_db_uri, convert_unicode=True)
|
|
|
|
db_session = scoped_session(sessionmaker(autocommit=False,
|
|
|
|
autoflush=False,
|
|
|
|
bind=engine))
|
|
|
|
Base = declarative_base()
|
|
|
|
Base.query = db_session.query_property()
|
|
|
|
|
|
|
|
|
|
|
|
def init_db():
|
|
|
|
"""
|
|
|
|
Initializes and creates all tables from models into the database
|
|
|
|
"""
|
|
|
|
# import all modules here that might define models so that
|
|
|
|
# they will be registered properly on the metadata. Otherwise
|
|
|
|
# you will have to import them first before calling init_db()
|
|
|
|
import ee.core.models
|
|
|
|
Base.metadata.create_all(bind=engine)
|