Commit DB changes on API startup

During API startup we initialize secret stores, which should be
populating secret_stores table.

Story: 2002137
Task: 19827
Change-Id: I4272c00b64714347bdf048124e0bfaadbb3b7237
This commit is contained in:
Vladyslav Drok 2018-06-01 14:07:22 +03:00
parent 8d8e0d652c
commit 44b2f5e704

View File

@ -74,21 +74,28 @@ def main_app(func):
# Configure oslo logging and configuration services. # Configure oslo logging and configuration services.
log.setup(CONF, 'barbican') log.setup(CONF, 'barbican')
LOG = log.getLogger(__name__)
config.setup_remote_pydev_debug() config.setup_remote_pydev_debug()
# Initializing the database engine and session factory before the app # Initializing the database engine and session factory before the app
# starts ensures we don't lose requests due to lazy initialization of # starts ensures we don't lose requests due to lazy initialization of
# db connections. # db connections.
try:
repositories.setup_database_engine_and_factory( repositories.setup_database_engine_and_factory(
initialize_secret_stores=True initialize_secret_stores=True
) )
repositories.commit()
except Exception:
LOG.exception('Failed to sync secret_stores table.')
repositories.rollback()
raise
wsgi_app = func(global_config, **local_conf) wsgi_app = func(global_config, **local_conf)
if newrelic_loaded: if newrelic_loaded:
wsgi_app = newrelic.agent.WSGIApplicationWrapper(wsgi_app) wsgi_app = newrelic.agent.WSGIApplicationWrapper(wsgi_app)
LOG = log.getLogger(__name__)
LOG.info('Barbican app created and initialized') LOG.info('Barbican app created and initialized')
return wsgi_app return wsgi_app
return _wrapper return _wrapper