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
|
2020-11-20 20:44:56 +13:00
|
|
|
|
2017-01-17 15:26:08 -06:00
|
|
|
from osc_lib.command import command
|
|
|
|
from osc_lib import utils as osc_utils
|
2020-11-20 20:44:56 +13:00
|
|
|
from oslo_utils import uuidutils
|
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-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',
|
2020-11-20 20:44:56 +13:00
|
|
|
'Datastore Version Name', 'Datastore Version Number']
|
2017-01-17 15:26:08 -06:00
|
|
|
|
|
|
|
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)
|
2020-10-12 19:30:57 +08:00
|
|
|
return zip(*sorted(configuration.items()))
|
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>',
|
2020-11-20 20:44:56 +13:00
|
|
|
help=_('Datastore version name or ID assigned to the '
|
|
|
|
'configuration group. ID is preferred if more than one '
|
|
|
|
'datastore versions have the same name.')
|
2017-12-08 11:01:26 +08:00
|
|
|
)
|
|
|
|
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
|
2020-11-20 20:44:56 +13:00
|
|
|
|
|
|
|
if uuidutils.is_uuid_like(parsed_args.datastore_version):
|
|
|
|
params = db_configuration_parameters.parameters_by_version(
|
|
|
|
parsed_args.datastore_version)
|
|
|
|
elif parsed_args.datastore:
|
|
|
|
params = db_configuration_parameters.parameters(
|
|
|
|
parsed_args.datastore,
|
|
|
|
parsed_args.datastore_version)
|
2017-12-08 11:01:26 +08:00
|
|
|
else:
|
2020-11-20 20:44:56 +13:00
|
|
|
raise exceptions.NoUniqueMatch(_('Either datastore version ID or '
|
|
|
|
'datastore name needs to be '
|
|
|
|
'specified.'))
|
|
|
|
|
2017-12-08 11:01:26 +08:00
|
|
|
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>',
|
2020-11-20 20:44:56 +13:00
|
|
|
help=_('Datastore version name or ID assigned to the '
|
|
|
|
'configuration group. ID is preferred if more than one '
|
|
|
|
'datastore versions have the same name.')
|
2017-12-09 14:19:17 +08:00
|
|
|
)
|
|
|
|
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):
|
2020-11-20 20:44:56 +13:00
|
|
|
db_configuration_parameters = self.app.client_manager.database. \
|
2017-12-09 14:19:17 +08:00
|
|
|
configuration_parameters
|
2020-11-20 20:44:56 +13:00
|
|
|
|
|
|
|
if uuidutils.is_uuid_like(parsed_args.datastore_version):
|
|
|
|
param = db_configuration_parameters.get_parameter_by_version(
|
2017-12-09 14:19:17 +08:00
|
|
|
parsed_args.datastore_version,
|
|
|
|
parsed_args.parameter)
|
2020-11-20 20:44:56 +13:00
|
|
|
elif parsed_args.datastore:
|
|
|
|
param = db_configuration_parameters.get_parameter(
|
|
|
|
parsed_args.datastore,
|
2017-12-09 14:19:17 +08:00
|
|
|
parsed_args.datastore_version,
|
|
|
|
parsed_args.parameter)
|
|
|
|
else:
|
2020-11-20 20:44:56 +13:00
|
|
|
raise exceptions.NoUniqueMatch(_('Either datastore version ID or '
|
|
|
|
'datastore name needs to be '
|
|
|
|
'specified.'))
|
|
|
|
|
2020-10-12 19:30:57 +08:00
|
|
|
return zip(*sorted(param._info.items()))
|
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(
|
2020-11-20 20:44:56 +13:00
|
|
|
'--datastore-version',
|
2017-12-22 22:57:34 -05:00
|
|
|
metavar='<datastore_version>',
|
|
|
|
default=None,
|
|
|
|
help=_('Datastore version ID assigned to the '
|
|
|
|
'configuration group.'),
|
|
|
|
)
|
2020-11-20 20:44:56 +13:00
|
|
|
parser.add_argument(
|
|
|
|
'--datastore-version-number',
|
|
|
|
default=None,
|
|
|
|
help=_('The version number for the database. The version number '
|
|
|
|
'is needed for the datastore versions with the same name.'),
|
|
|
|
)
|
2017-12-22 22:57:34 -05:00
|
|
|
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,
|
2020-11-20 20:44:56 +13:00
|
|
|
datastore_version=parsed_args.datastore_version,
|
|
|
|
datastore_version_number=parsed_args.datastore_version_number)
|
2017-12-22 22:57:34 -05:00
|
|
|
config_grp = set_attributes_for_print_detail(config_grp)
|
2020-10-12 19:30:57 +08:00
|
|
|
return zip(*sorted(config_grp.items()))
|
2017-12-26 02:45:15 -05:00
|
|
|
|
|
|
|
|
|
|
|
class AttachDatabaseConfiguration(command.Command):
|
|
|
|
_description = _("Attaches a configuration group to an instance.")
|
|
|
|
|
|
|
|
def get_parser(self, prog_name):
|
|
|
|
parser = super(AttachDatabaseConfiguration, self).get_parser(prog_name)
|
|
|
|
parser.add_argument(
|
|
|
|
'instance',
|
|
|
|
metavar='<instance>',
|
|
|
|
type=str,
|
|
|
|
help=_('ID or name of the instance'),
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
'configuration',
|
|
|
|
metavar='<configuration>',
|
|
|
|
type=str,
|
|
|
|
help=_('ID or name of the configuration group to attach to the '
|
|
|
|
'instance.'),
|
|
|
|
)
|
|
|
|
return parser
|
|
|
|
|
|
|
|
def take_action(self, parsed_args):
|
|
|
|
manager = self.app.client_manager.database
|
|
|
|
db_instances = manager.instances
|
|
|
|
db_configurations = manager.configurations
|
2021-07-09 20:31:43 +12:00
|
|
|
|
|
|
|
instance_id = parsed_args.instance
|
|
|
|
config_id = parsed_args.configuration
|
|
|
|
|
|
|
|
if not uuidutils.is_uuid_like(instance_id):
|
|
|
|
instance_id = osc_utils.find_resource(db_instances, instance_id)
|
|
|
|
if not uuidutils.is_uuid_like(config_id):
|
|
|
|
config_id = osc_utils.find_resource(db_configurations, config_id)
|
|
|
|
|
|
|
|
db_instances.update(instance_id, configuration=config_id)
|
2017-12-26 02:45:15 -05:00
|
|
|
|
|
|
|
|
|
|
|
class DetachDatabaseConfiguration(command.Command):
|
|
|
|
|
|
|
|
_description = _("Detaches a configuration group from an instance.")
|
|
|
|
|
|
|
|
def get_parser(self, prog_name):
|
|
|
|
parser = super(DetachDatabaseConfiguration, self).get_parser(prog_name)
|
|
|
|
parser.add_argument(
|
|
|
|
'instance',
|
|
|
|
metavar='<instance>',
|
|
|
|
type=str,
|
|
|
|
help=_('ID or name of the instance.'),
|
|
|
|
)
|
|
|
|
return parser
|
|
|
|
|
|
|
|
def take_action(self, parsed_args):
|
|
|
|
db_instances = self.app.client_manager.database.instances
|
2021-07-09 20:31:43 +12:00
|
|
|
instance_id = parsed_args.instance
|
|
|
|
|
|
|
|
if not uuidutils.is_uuid_like(instance_id):
|
|
|
|
instance_id = osc_utils.find_resource(db_instances, instance_id)
|
|
|
|
|
|
|
|
db_instances.update(instance_id, remove_configuration=True)
|
2018-07-12 14:53:28 +08:00
|
|
|
|
|
|
|
|
|
|
|
class ListDatabaseConfigurationInstances(command.Lister):
|
|
|
|
|
|
|
|
_description = _("Lists all instances associated "
|
|
|
|
"with a configuration group.")
|
|
|
|
columns = ['ID', 'Name']
|
|
|
|
|
|
|
|
def get_parser(self, prog_name):
|
|
|
|
parser = super(ListDatabaseConfigurationInstances, self).\
|
|
|
|
get_parser(prog_name)
|
|
|
|
parser.add_argument(
|
|
|
|
'configuration_group',
|
|
|
|
metavar='<configuration_group>',
|
|
|
|
help=_('ID or name of the configuration group.')
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
'--limit',
|
|
|
|
metavar='<limit>',
|
|
|
|
default=None,
|
|
|
|
type=int,
|
|
|
|
help=_('Limit the number of results displayed.')
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
'--marker',
|
|
|
|
metavar='<ID>',
|
|
|
|
default=None,
|
|
|
|
type=str,
|
|
|
|
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
|
|
|
|
configuration = osc_utils.find_resource(
|
|
|
|
db_configurations, parsed_args.configuration_group)
|
|
|
|
params = db_configurations.instances(configuration,
|
|
|
|
limit=parsed_args.limit,
|
|
|
|
marker=parsed_args.marker)
|
|
|
|
instance = [osc_utils.get_item_properties(p, self.columns)
|
|
|
|
for p in params]
|
|
|
|
return self.columns, instance
|
2018-07-11 20:29:03 +08:00
|
|
|
|
|
|
|
|
|
|
|
class DefaultDatabaseConfiguration(command.ShowOne):
|
|
|
|
_description = _("Shows the default configuration of an instance.")
|
|
|
|
|
|
|
|
def get_parser(self, prog_name):
|
|
|
|
parser = super(DefaultDatabaseConfiguration, self).get_parser(
|
|
|
|
prog_name)
|
|
|
|
parser.add_argument(
|
|
|
|
'instance',
|
|
|
|
metavar='<instance>',
|
|
|
|
type=str,
|
|
|
|
help=_('ID or name of the instance.'),
|
|
|
|
)
|
|
|
|
return parser
|
|
|
|
|
|
|
|
def take_action(self, parsed_args):
|
|
|
|
db_instances = self.app.client_manager.database.instances
|
|
|
|
instance = osc_utils.find_resource(db_instances,
|
|
|
|
parsed_args.instance)
|
|
|
|
configs = db_instances.configuration(instance)
|
2020-10-12 19:30:57 +08:00
|
|
|
return zip(*sorted(configs._info['configuration'].items()))
|
2020-05-08 11:35:54 +12:00
|
|
|
|
|
|
|
|
|
|
|
class SetDatabaseConfiguration(command.Command):
|
|
|
|
_description = _("Change parameters for a configuration group.")
|
|
|
|
|
|
|
|
def get_parser(self, prog_name):
|
|
|
|
parser = super(SetDatabaseConfiguration, self).get_parser(prog_name)
|
|
|
|
parser.add_argument(
|
|
|
|
'configuration_group_id',
|
|
|
|
help=_('Configuration group ID.'),
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
'values',
|
|
|
|
metavar='<values>',
|
|
|
|
help=_('Dictionary of the new values to set.'),
|
|
|
|
)
|
|
|
|
return parser
|
|
|
|
|
|
|
|
def take_action(self, parsed_args):
|
|
|
|
db_configurations = self.app.client_manager.database.configurations
|
|
|
|
|
|
|
|
db_configurations.edit(
|
|
|
|
parsed_args.configuration_group_id,
|
|
|
|
parsed_args.values
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
class UpdateDatabaseConfiguration(command.Command):
|
|
|
|
_description = _("Update a configuration group.")
|
|
|
|
|
|
|
|
def get_parser(self, prog_name):
|
|
|
|
parser = super(UpdateDatabaseConfiguration, self).get_parser(prog_name)
|
|
|
|
parser.add_argument(
|
|
|
|
'configuration_group_id',
|
|
|
|
help=_('Configuration group ID.'),
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
'values',
|
|
|
|
metavar='<values>',
|
|
|
|
help=_('Dictionary of the values to set.'),
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
'--name',
|
|
|
|
metavar='<name>',
|
|
|
|
help=_('New name of 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
|
|
|
|
|
|
|
|
db_configurations.update(
|
|
|
|
parsed_args.configuration_group_id,
|
|
|
|
parsed_args.values,
|
|
|
|
name=parsed_args.name,
|
|
|
|
description=parsed_args.description
|
|
|
|
)
|