2017-01-17 15:26:08 -06:00
|
|
|
# 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.
|
|
|
|
|
|
|
|
"""Database v1 Configurations action implementations"""
|
|
|
|
|
2017-11-30 21:16:18 +08:00
|
|
|
import json
|
2017-01-17 15:26:08 -06:00
|
|
|
from osc_lib.command import command
|
|
|
|
from osc_lib import utils as osc_utils
|
2017-11-30 21:16:18 +08:00
|
|
|
import six
|
2017-01-17 15:26:08 -06:00
|
|
|
|
2017-12-08 11:01:26 +08:00
|
|
|
from troveclient import exceptions
|
2017-01-17 15:26:08 -06:00
|
|
|
from troveclient.i18n import _
|
2017-12-08 11:01:26 +08:00
|
|
|
from troveclient import utils
|
2017-01-17 15:26:08 -06:00
|
|
|
|
|
|
|
|
2017-11-30 21:16:18 +08:00
|
|
|
def set_attributes_for_print_detail(configuration):
|
|
|
|
info = configuration._info.copy()
|
|
|
|
info['values'] = json.dumps(configuration.values)
|
|
|
|
del info['datastore_version_id']
|
|
|
|
return info
|
|
|
|
|
|
|
|
|
2017-01-17 15:26:08 -06:00
|
|
|
class ListDatabaseConfigurations(command.Lister):
|
|
|
|
|
|
|
|
_description = _("List database configurations")
|
|
|
|
columns = ['ID', 'Name', 'Description', 'Datastore Name',
|
|
|
|
'Datastore Version Name']
|
|
|
|
|
|
|
|
def get_parser(self, prog_name):
|
|
|
|
parser = super(ListDatabaseConfigurations, self).get_parser(prog_name)
|
|
|
|
parser.add_argument(
|
|
|
|
'--limit',
|
|
|
|
dest='limit',
|
|
|
|
metavar='<limit>',
|
|
|
|
type=int,
|
|
|
|
default=None,
|
|
|
|
help=_('Limit the number of results displayed.')
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
'--marker',
|
|
|
|
dest='marker',
|
|
|
|
metavar='<ID>',
|
|
|
|
help=_('Begin displaying the results for IDs greater than the '
|
|
|
|
'specified marker. When used with --limit, set this to '
|
|
|
|
'the last ID displayed in the previous run.')
|
|
|
|
)
|
|
|
|
return parser
|
|
|
|
|
|
|
|
def take_action(self, parsed_args):
|
|
|
|
db_configurations = self.app.client_manager.database.configurations
|
|
|
|
config = db_configurations.list(limit=parsed_args.limit,
|
|
|
|
marker=parsed_args.marker)
|
|
|
|
config = [osc_utils.get_item_properties(c, self.columns)
|
|
|
|
for c in config]
|
|
|
|
return self.columns, config
|
2017-11-30 21:16:18 +08:00
|
|
|
|
|
|
|
|
|
|
|
class ShowDatabaseConfiguration(command.ShowOne):
|
|
|
|
_description = _("Shows details of a database configuration group.")
|
|
|
|
|
|
|
|
def get_parser(self, prog_name):
|
|
|
|
parser = super(ShowDatabaseConfiguration, self).get_parser(prog_name)
|
|
|
|
parser.add_argument(
|
|
|
|
'configuration_group',
|
|
|
|
metavar='<configuration_group>',
|
|
|
|
help=_('ID or name of the configuration group'),
|
|
|
|
)
|
|
|
|
return parser
|
|
|
|
|
|
|
|
def take_action(self, parsed_args):
|
|
|
|
db_configurations = self.app.client_manager.database.configurations
|
|
|
|
configuration = osc_utils.find_resource(
|
|
|
|
db_configurations, parsed_args.configuration_group)
|
|
|
|
configuration = set_attributes_for_print_detail(configuration)
|
|
|
|
return zip(*sorted(six.iteritems(configuration)))
|
2017-12-08 11:01:26 +08:00
|
|
|
|
|
|
|
|
|
|
|
class ListDatabaseConfigurationParameters(command.Lister):
|
|
|
|
|
|
|
|
_description = _("Lists available parameters for a configuration group.")
|
|
|
|
columns = ['Name', 'Type', 'Min Size', 'Max Size', 'Restart Required']
|
|
|
|
|
|
|
|
def get_parser(self, prog_name):
|
|
|
|
parser = super(ListDatabaseConfigurationParameters, self).\
|
|
|
|
get_parser(prog_name)
|
|
|
|
parser.add_argument(
|
|
|
|
'datastore_version',
|
|
|
|
metavar='<datastore_version>',
|
|
|
|
help=_('Datastore version name or ID assigned'
|
|
|
|
'to the configuration group.')
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
'--datastore',
|
|
|
|
metavar='<datastore>',
|
|
|
|
default=None,
|
|
|
|
help=_('ID or name of the datastore to list configuration'
|
|
|
|
'parameters for. Optional if the ID of the'
|
|
|
|
'datastore_version is provided.')
|
|
|
|
)
|
|
|
|
return parser
|
|
|
|
|
|
|
|
def take_action(self, parsed_args):
|
|
|
|
db_configuration_parameters = self.app.client_manager.\
|
|
|
|
database.configuration_parameters
|
|
|
|
if parsed_args.datastore:
|
|
|
|
params = db_configuration_parameters.\
|
|
|
|
parameters(parsed_args.datastore,
|
|
|
|
parsed_args.datastore_version)
|
|
|
|
elif utils.is_uuid_like(parsed_args.datastore_version):
|
|
|
|
params = db_configuration_parameters.\
|
|
|
|
parameters_by_version(parsed_args.datastore_version)
|
|
|
|
else:
|
|
|
|
raise exceptions.NoUniqueMatch(_('The datastore name or id is'
|
|
|
|
' required to retrieve the'
|
|
|
|
' parameters for the'
|
|
|
|
' configuration group'
|
|
|
|
' by name.'))
|
|
|
|
for param in params:
|
|
|
|
setattr(param, 'min_size', getattr(param, 'min', '-'))
|
|
|
|
setattr(param, 'max_size', getattr(param, 'max', '-'))
|
|
|
|
params = [osc_utils.get_item_properties(p, self.columns)
|
|
|
|
for p in params]
|
|
|
|
return self.columns, params
|
2017-12-09 14:19:17 +08:00
|
|
|
|
|
|
|
|
|
|
|
class ShowDatabaseConfigurationParameter(command.ShowOne):
|
|
|
|
_description = _("Shows details of a database configuration parameter.")
|
|
|
|
|
|
|
|
def get_parser(self, prog_name):
|
|
|
|
parser = super(ShowDatabaseConfigurationParameter, self).\
|
|
|
|
get_parser(prog_name)
|
|
|
|
parser.add_argument(
|
|
|
|
'datastore_version',
|
|
|
|
metavar='<datastore_version>',
|
|
|
|
help=_('Datastore version name or ID assigned to the'
|
|
|
|
' configuration group.'),
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
'parameter',
|
|
|
|
metavar='<parameter>',
|
|
|
|
help=_('Name of the configuration parameter.'),
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
'--datastore',
|
|
|
|
metavar='<datastore>',
|
|
|
|
default=None,
|
|
|
|
help=_('ID or name of the datastore to list configuration'
|
|
|
|
' parameters for. Optional if the ID of the'
|
|
|
|
' datastore_version is provided.'),
|
|
|
|
)
|
|
|
|
return parser
|
|
|
|
|
|
|
|
def take_action(self, parsed_args):
|
|
|
|
db_configuration_parameters = self.app.client_manager.database.\
|
|
|
|
configuration_parameters
|
|
|
|
if parsed_args.datastore:
|
|
|
|
param = db_configuration_parameters.get_parameter(
|
|
|
|
parsed_args.datastore,
|
|
|
|
parsed_args.datastore_version,
|
|
|
|
parsed_args.parameter)
|
|
|
|
elif utils.is_uuid_like(parsed_args.datastore_version):
|
|
|
|
param = db_configuration_parameters.get_parameter_by_version(
|
|
|
|
parsed_args.datastore_version,
|
|
|
|
parsed_args.parameter)
|
|
|
|
else:
|
|
|
|
raise exceptions.NoUniqueMatch(_('The datastore name or id is'
|
|
|
|
' required to retrieve the'
|
|
|
|
' parameter for the'
|
|
|
|
' configuration group'
|
|
|
|
' by name.'))
|
|
|
|
return zip(*sorted(six.iteritems(param._info)))
|
2017-12-21 00:23:55 -05:00
|
|
|
|
|
|
|
|
|
|
|
class DeleteDatabaseConfiguration(command.Command):
|
|
|
|
|
|
|
|
_description = _("Deletes a configuration group.")
|
|
|
|
|
|
|
|
def get_parser(self, prog_name):
|
|
|
|
parser = super(DeleteDatabaseConfiguration, self).get_parser(prog_name)
|
|
|
|
parser.add_argument(
|
|
|
|
'configuration_group',
|
|
|
|
metavar='<configuration_group>',
|
|
|
|
help=_('ID or name of the configuration group'),
|
|
|
|
)
|
|
|
|
return parser
|
|
|
|
|
|
|
|
def take_action(self, parsed_args):
|
|
|
|
db_configurations = self.app.client_manager.database.configurations
|
|
|
|
try:
|
|
|
|
configuration = osc_utils.find_resource(
|
|
|
|
db_configurations, parsed_args.configuration_group)
|
|
|
|
db_configurations.delete(configuration)
|
|
|
|
except Exception as e:
|
|
|
|
msg = (_("Failed to delete configuration %(c_group)s: %(e)s")
|
|
|
|
% {'c_group': parsed_args.configuration_group, 'e': e})
|
|
|
|
raise exceptions.CommandError(msg)
|
2017-12-22 22:57:34 -05:00
|
|
|
|
|
|
|
|
|
|
|
class CreateDatabaseConfiguration(command.ShowOne):
|
|
|
|
|
|
|
|
_description = _("Creates a configuration group.")
|
|
|
|
|
|
|
|
def get_parser(self, prog_name):
|
|
|
|
parser = super(CreateDatabaseConfiguration, self).get_parser(prog_name)
|
|
|
|
parser.add_argument(
|
|
|
|
'name',
|
|
|
|
metavar='<name>',
|
|
|
|
help=_('Name of the configuration group.'),
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
'values',
|
|
|
|
metavar='<values>',
|
|
|
|
help=_('Dictionary of the values to set.'),
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
'--datastore',
|
|
|
|
metavar='<datastore>',
|
|
|
|
default=None,
|
|
|
|
help=_('Datastore assigned to the configuration group. Required '
|
|
|
|
'if default datastore is not configured.'),
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
'--datastore_version',
|
|
|
|
metavar='<datastore_version>',
|
|
|
|
default=None,
|
|
|
|
help=_('Datastore version ID assigned to the '
|
|
|
|
'configuration group.'),
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
'--description',
|
|
|
|
metavar='<description>',
|
|
|
|
default=None,
|
|
|
|
help=_('An optional description for the configuration group.'),
|
|
|
|
)
|
|
|
|
return parser
|
|
|
|
|
|
|
|
def take_action(self, parsed_args):
|
|
|
|
db_configurations = self.app.client_manager.database.configurations
|
|
|
|
config_grp = db_configurations.create(
|
|
|
|
parsed_args.name,
|
|
|
|
parsed_args.values,
|
|
|
|
description=parsed_args.description,
|
|
|
|
datastore=parsed_args.datastore,
|
|
|
|
datastore_version=parsed_args.datastore_version)
|
|
|
|
config_grp = set_attributes_for_print_detail(config_grp)
|
|
|
|
return zip(*sorted(six.iteritems(config_grp)))
|