Add support to oslo.db to be used as a DB driver. The DB driver will be
used with API v2. When it's completely implemented, API V1 will be
deprecated and removed by the end of the cycle. Freezer-api will keep
supporting V2 with Elasticsearch, Sqlalchemy drivers.
This patch implements the follow:
* Abstract Base DB driver to be implemented by each driver
* Base driver; will return only access to the db engine, session
* SqlAlchemy driver;
* ElasticSearch driver;
* Implement both drivers in freezer-manage
Partially-Implements: blueprint oslo-db
Depends-On: I81e417155da48f46dd2113e5745fb3c21c96499f
Depends-On: I2e5724b1f1a75121952e2beb3844d2c489e4df68
Depends-On: Idb4ac050652d1d0107bf3fcd447d7cbedd811809
Depends-On: I81d46c89859752c0cbc21ef02de90db7f19f942c
Change-Id: I93ed1b909f538728a1a9bd5c8b07baf7aeddb705
46 lines
1.5 KiB
Python
46 lines
1.5 KiB
Python
"""
|
|
(C) Copyright 2016-2018 Hewlett Packard Enterprise Development Company LP
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
"""
|
|
|
|
from oslo_config import cfg
|
|
from oslo_log import log
|
|
from oslo_utils import importutils
|
|
|
|
CONF = cfg.CONF
|
|
LOG = log.getLogger(__name__)
|
|
|
|
# storage backend options to be registered
|
|
_OPTS = [
|
|
cfg.StrOpt("backend",
|
|
help="Database backend section name. This section "
|
|
"will be loaded by the proper driver to connect to "
|
|
"the database."
|
|
),
|
|
cfg.StrOpt('driver',
|
|
default='freezer_api.storage.elastic.ElasticSearchEngine',
|
|
help="Database driver to be used."
|
|
)
|
|
]
|
|
|
|
|
|
def get_db(driver=None):
|
|
"""Automatically loads the database driver to be used."""
|
|
storage = CONF.get('storage')
|
|
if not driver:
|
|
driver = storage['driver']
|
|
driver_instance = importutils.import_object(
|
|
driver,
|
|
backend=storage['backend']
|
|
)
|
|
|
|
return driver_instance
|