6f06bdfe4b
This is the follow up patch on Tim's patch to cleanup old dse code. Change-Id: Id4942d714c35e4eed70e72793fecbc08925e7811
155 lines
5.8 KiB
Python
155 lines
5.8 KiB
Python
# Copyright (c) 2014 VMware, Inc. All rights reserved.
|
|
#
|
|
# 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 __future__ import print_function
|
|
from __future__ import division
|
|
from __future__ import absolute_import
|
|
|
|
from oslo_log import log as logging
|
|
|
|
from congress.api import api_utils
|
|
from congress.api import base
|
|
from congress.api import webservice
|
|
from congress import exception
|
|
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
|
|
class TableModel(base.APIModel):
|
|
"""Model for handling API requests about Tables."""
|
|
|
|
# Note(thread-safety): blocking function
|
|
def get_item(self, id_, params, context=None):
|
|
"""Retrieve item with id id_ from model.
|
|
|
|
Args:
|
|
id_: The ID of the item to retrieve
|
|
params: A dict-like object containing parameters
|
|
from the request query string and body.
|
|
context: Key-values providing frame of reference of request
|
|
|
|
Returns:
|
|
The matching item or None if item with id_ does not exist.
|
|
"""
|
|
# Note(thread-safety): blocking call
|
|
caller, source_id = api_utils.get_id_from_context(context)
|
|
# FIXME(threod-safety): in DSE2, the returned caller can be a
|
|
# datasource name. But the datasource name may now refer to a new,
|
|
# unrelated datasource. Causing the rest of this code to operate on
|
|
# an unintended datasource.
|
|
# Fix: check UUID of datasource before operating. Abort if mismatch
|
|
|
|
args = {'source_id': source_id, 'table_id': id_}
|
|
try:
|
|
# Note(thread-safety): blocking call
|
|
tablename = self.invoke_rpc(caller, 'get_tablename', args)
|
|
except exception.CongressException as e:
|
|
LOG.exception("Exception occurred while retrieving table %s"
|
|
"from datasource %s", id_, source_id)
|
|
raise webservice.DataModelException.create(e)
|
|
|
|
if tablename:
|
|
return {'id': tablename}
|
|
|
|
LOG.info('table id %s is not found in datasource %s', id_, source_id)
|
|
|
|
# Note(thread-safety): blocking function
|
|
def get_items(self, params, context=None):
|
|
"""Get items in model.
|
|
|
|
Args:
|
|
params: A dict-like object containing parameters
|
|
from the request query string and body.
|
|
context: Key-values providing frame of reference of request
|
|
|
|
Returns: A dict containing at least a 'results' key whose value is
|
|
a list of items in the model. Additional keys set in the
|
|
dict will also be rendered for the user.
|
|
"""
|
|
LOG.info('get_items has context %s', context)
|
|
|
|
# Note(thread-safety): blocking call
|
|
caller, source_id = api_utils.get_id_from_context(context)
|
|
# FIXME(threod-safety): in DSE2, the returned caller can be a
|
|
# datasource name. But the datasource name may now refer to a new,
|
|
# unrelated datasource. Causing the rest of this code to operate on
|
|
# an unintended datasource.
|
|
# Fix: check UUID of datasource before operating. Abort if mismatch
|
|
|
|
try:
|
|
# Note(thread-safety): blocking call
|
|
tablenames = self.invoke_rpc(caller, 'get_tablenames',
|
|
{'source_id': source_id})
|
|
except exception.CongressException as e:
|
|
LOG.exception("Exception occurred while retrieving tables"
|
|
"from datasource %s", source_id)
|
|
raise webservice.DataModelException.create(e)
|
|
# when the source_id doesn't have any table, 'tablenames' is set([])
|
|
if isinstance(tablenames, set) or isinstance(tablenames, list):
|
|
return {'results': [{'id': x} for x in tablenames]}
|
|
|
|
# Tables can only be created/updated/deleted by writing policy
|
|
# or by adding new data sources. Once we have internal data sources
|
|
# we need to implement all of these.
|
|
|
|
# def add_item(self, item, id_=None, context=None):
|
|
# """Add item to model.
|
|
|
|
# Args:
|
|
# item: The item to add to the model
|
|
# id_: The ID of the item, or None if an ID should be generated
|
|
# context: Key-values providing frame of reference of request
|
|
|
|
# Returns:
|
|
# Tuple of (ID, newly_created_item)
|
|
|
|
# Raises:
|
|
# KeyError: ID already exists.
|
|
# """
|
|
|
|
# def update_item(self, id_, item, context=None):
|
|
# """Update item with id_ with new data.
|
|
|
|
# Args:
|
|
# id_: The ID of the item to be updated
|
|
# item: The new item
|
|
# context: Key-values providing frame of reference of request
|
|
|
|
# Returns:
|
|
# The updated item.
|
|
|
|
# Raises:
|
|
# KeyError: Item with specified id_ not present.
|
|
# """
|
|
# # currently a noop since the owner_id cannot be changed
|
|
# if id_ not in self.items:
|
|
# raise KeyError("Cannot update item with ID '%s': "
|
|
# "ID does not exist")
|
|
# return item
|
|
|
|
# def delete_item(self, id_, context=None):
|
|
# """Remove item from model.
|
|
|
|
# Args:
|
|
# id_: The ID of the item to be removed
|
|
# context: Key-values providing frame of reference of request
|
|
|
|
# Returns:
|
|
# The removed item.
|
|
|
|
# Raises:
|
|
# KeyError: Item with specified id_ not present.
|
|
# """
|