Added logic for establishing DB connection.

This commit is contained in:
Felipe Monteiro 2017-07-19 22:06:39 +01:00
parent 5e66317cd9
commit 31eb6b2b29
4 changed files with 39 additions and 77 deletions

View File

@ -17,18 +17,20 @@ from oslo_config import cfg
CONF = cfg.CONF CONF = cfg.CONF
database_group = cfg.OptGroup( barbican_group = cfg.OptGroup(
name='database', name='barbican',
title='Deckhand Database Options' title='Barbican Options',
) help="""
Barbican options for allowing Deckhand to communicate with Barbican.
""")
barbican_opts = [
database_opts = [ cfg.StrOpt(
cfg.StrOpt(name='connection', 'api_endpoint',
default='') sample_default='http://barbican.example.org:9311/',
help='URL override for the Barbican API endpoint.'),
] ]
keystone_auth_group = cfg.OptGroup( keystone_auth_group = cfg.OptGroup(
name='keystone_authtoken', name='keystone_authtoken',
title='Keystone Authentication Options' title='Keystone Authentication Options'
@ -49,20 +51,6 @@ keystone_auth_opts = [
default='http://127.0.0.1/identity/v3') default='http://127.0.0.1/identity/v3')
] ]
barbican_group = cfg.OptGroup(
name='barbican',
title='Barbican Options',
help="""
Barbican options for allowing Deckhand to communicate with Barbican.
""")
barbican_opts = [
cfg.StrOpt(
'api_endpoint',
sample_default='http://barbican.example.org:9311/',
help='URL override for the Barbican API endpoint.'),
]
logging_group = cfg.OptGroup( logging_group = cfg.OptGroup(
name='logging', name='logging',
title='Logging Options', title='Logging Options',
@ -79,9 +67,6 @@ def register_opts(conf):
conf.register_group(barbican_group) conf.register_group(barbican_group)
conf.register_opts(barbican_opts, group=barbican_group) conf.register_opts(barbican_opts, group=barbican_group)
conf.register_group(database_group)
conf.register_opts(database_opts, group=database_group)
conf.register_group(keystone_auth_group) conf.register_group(keystone_auth_group)
conf.register_opts(keystone_auth_opts, group=keystone_auth_group) conf.register_opts(keystone_auth_opts, group=keystone_auth_group)
@ -95,4 +80,24 @@ def list_opts():
logging_group: logging_opts} logging_group: logging_opts}
def parse_args(args=None, usage=None, default_config_files=None):
CONF(args=args,
project='deckhand',
usage=usage,
default_config_files=default_config_files)
def parse_cache_args(args=None):
# Look for Deckhand config files in the following directories::
#
# ~/.${project}/
# ~/
# /etc/${project}/
# /etc/
# ${SNAP}/etc/${project}
# ${SNAP_COMMON}/etc/${project}
config_files = cfg.find_config_files(project='deckhand')
parse_args(args=args, default_config_files=config_files)
register_opts(CONF) register_opts(CONF)

View File

@ -25,14 +25,17 @@ from deckhand.control import secrets
from deckhand.db.sqlalchemy import api as db_api from deckhand.db.sqlalchemy import api as db_api
CONF = cfg.CONF CONF = cfg.CONF
LOG = None
def __setup_logging(): def __setup_logging():
global LOG
LOGGER_NAME = CONF.logging.global_logger_name LOGGER_NAME = CONF.logging.global_logger_name
LOG = logging.getLogger(__name__, LOGGER_NAME) LOG = logging.getLogger(__name__, LOGGER_NAME)
logging.register_options(CONF) logging.register_options(CONF)
config.parse_args()
current_path = os.path.dirname(os.path.realpath(__file__)) current_path = os.path.dirname(os.path.realpath(__file__))
root_path = os.path.abspath(os.path.join(current_path, os.pardir, root_path = os.path.abspath(os.path.join(current_path, os.pardir,
os.pardir)) os.pardir))
@ -54,10 +57,10 @@ def start_api(state_manager=None):
Create routes for the v1.0 API and sets up logging. Create routes for the v1.0 API and sets up logging.
""" """
config.register_opts(CONF)
__setup_logging() __setup_logging()
# FOR TESTING -- REMOVE
engine = db_api.get_engine() engine = db_api.get_engine()
assert engine.engine.name == 'postgres' assert engine.engine.name == 'sqlite'
control_api = falcon.API(request_type=api_base.DeckhandRequest) control_api = falcon.API(request_type=api_base.DeckhandRequest)

View File

@ -58,7 +58,8 @@ def _create_facade_lazily():
if _FACADE is None: if _FACADE is None:
with _LOCK: with _LOCK:
if _FACADE is None: if _FACADE is None:
_FACADE = session.EngineFacade.from_config(CONF) _FACADE = session.EngineFacade.from_config(
CONF, sqlite_fk=True)
return _FACADE return _FACADE

View File

@ -1,47 +0,0 @@
[DEFAULT]
[barbican]
#
# Barbican options for allowing Deckhand to communicate with Barbican.
#
# From deckhand.conf
#
# URL override for the Barbican API endpoint. (string value)
#api_endpoint = http://barbican.example.org:9311/
[keystone_authtoken]
#
# From deckhand.conf
#
# (string value)
#signing_dir = <None>
# (string value)
#cafile = <None>
# (string value)
#project_domain_name = Default
# (string value)
#project_name = admin
# (string value)
#user_domain_name = Default
# (string value)
#password = devstack
# (string value)
#username = admin
# (string value)
#auth_url = http://127.0.0.1/identity
# (string value)
#auth_type = password