kite/kite/db/sqlalchemy/api.py

156 lines
4.8 KiB
Python

# 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 sqlalchemy.orm import exc
from kite.common import exception
from kite.db import connection
from kite.db.sqlalchemy import models
from kite.openstack.common.db import exception as db_exc
from kite.openstack.common.db.sqlalchemy import session as db_session
CONF = cfg.CONF
_facade = None
def get_facade():
global _facade
if not _facade:
_facade = db_session.EngineFacade.from_config(CONF.database.connection,
CONF)
return _facade
def get_engine():
return get_facade().get_engine()
def get_session():
return get_facade().get_session()
def reset():
global _facade
_facade = None
def get_backend():
return SqlalchemyDbImpl()
class SqlalchemyDbImpl(connection.Connection):
def set_key(self, name, key, signature, group, expiration=None):
session = get_session()
with session.begin():
q = session.query(models.Host)
q = q.filter(models.Host.name == name)
try:
host = q.one()
except exc.NoResultFound:
host = models.Host(name=name,
latest_generation=0,
group=group)
else:
if host.group != group:
raise exception.GroupStatusChanged(name=name)
host.latest_generation += 1
host.keys.append(models.Key(signature=signature,
enc_key=key,
generation=host.latest_generation,
expiration=expiration))
session.add(host)
return host.latest_generation
def _get_group_data(self, session, name):
"""Return data about a group.
In the case of getting a key where there is a Group defined but no key
has yet been defined we are supposed to return the group data without
a key. This is a difficult query to write as an all in one. This
function is called when we fail to find a key, to return group data
if the request host is a group.
"""
query = session.query(models.Host.name)
query = query.filter(models.Host.group == True)
query = query.filter(models.Host.name == name)
try:
result = query.one()
except exc.NoResultFound:
return None
else:
return {'name': result.name,
'group': True}
def get_key(self, name, generation=None, group=None):
session = get_session()
query = session.query(models.Host, models.Key)
query = query.filter(models.Host.id == models.Key.host_id)
query = query.filter(models.Host.name == name)
if group is not None:
query = query.filter(models.Host.group == group)
if generation is not None:
query = query.filter(models.Key.generation == generation)
else:
query = query.filter(models.Host.latest_generation ==
models.Key.generation)
try:
result = query.one()
except exc.NoResultFound:
if group is not False and generation is None:
return self._get_group_data(session, name)
else:
return None
return {'name': result.Host.name,
'group': result.Host.group,
'key': result.Key.enc_key,
'signature': result.Key.signature,
'generation': result.Key.generation,
'expiration': result.Key.expiration}
def create_group(self, name):
session = get_session()
try:
with session.begin():
group = models.Host(name=name, latest_generation=0, group=True)
session.add(group)
except db_exc.DBDuplicateEntry:
# an existing group of this name already exists.
return False
return True
def delete_host(self, name, group=None):
session = get_session()
with session.begin():
query = session.query(models.Host).filter(models.Host.name == name)
if group is not None:
query = query.filter(models.Host.group == group)
count = query.delete()
return count > 0