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
database_group = cfg.OptGroup(
name='database',
title='Deckhand Database Options'
)
barbican_group = cfg.OptGroup(
name='barbican',
title='Barbican Options',
help="""
Barbican options for allowing Deckhand to communicate with Barbican.
""")
database_opts = [
cfg.StrOpt(name='connection',
default='')
barbican_opts = [
cfg.StrOpt(
'api_endpoint',
sample_default='http://barbican.example.org:9311/',
help='URL override for the Barbican API endpoint.'),
]
keystone_auth_group = cfg.OptGroup(
name='keystone_authtoken',
title='Keystone Authentication Options'
@ -49,20 +51,6 @@ keystone_auth_opts = [
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(
name='logging',
title='Logging Options',
@ -79,9 +67,6 @@ def register_opts(conf):
conf.register_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_opts(keystone_auth_opts, group=keystone_auth_group)
@ -95,4 +80,24 @@ def list_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)

View File

@ -25,14 +25,17 @@ from deckhand.control import secrets
from deckhand.db.sqlalchemy import api as db_api
CONF = cfg.CONF
LOG = None
def __setup_logging():
global LOG
LOGGER_NAME = CONF.logging.global_logger_name
LOG = logging.getLogger(__name__, LOGGER_NAME)
logging.register_options(CONF)
config.parse_args()
current_path = os.path.dirname(os.path.realpath(__file__))
root_path = os.path.abspath(os.path.join(current_path, 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.
"""
config.register_opts(CONF)
__setup_logging()
# FOR TESTING -- REMOVE
engine = db_api.get_engine()
assert engine.engine.name == 'postgres'
assert engine.engine.name == 'sqlite'
control_api = falcon.API(request_type=api_base.DeckhandRequest)

View File

@ -58,7 +58,8 @@ def _create_facade_lazily():
if _FACADE is None:
with _LOCK:
if _FACADE is None:
_FACADE = session.EngineFacade.from_config(CONF)
_FACADE = session.EngineFacade.from_config(
CONF, sqlite_fk=True)
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