469 lines
16 KiB
Python
469 lines
16 KiB
Python
# Copyright 2013 Rackspace Hosting.
|
|
#
|
|
# 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 django.conf import settings
|
|
from horizon.utils import functions as utils
|
|
from horizon.utils.memoized import memoized # noqa
|
|
from keystoneauth1 import session
|
|
from keystoneclient.auth import token_endpoint
|
|
from novaclient import client as nova_client
|
|
from openstack_auth import utils as auth_utils
|
|
from openstack_dashboard.api import base
|
|
from oslo_log import log as logging
|
|
from troveclient.v1 import client
|
|
|
|
# Supported compute versions
|
|
NOVA_VERSIONS = base.APIVersionManager("compute", preferred_version=2)
|
|
NOVA_VERSIONS.load_supported_version(1.1,
|
|
{"client": nova_client, "version": 1.1})
|
|
NOVA_VERSIONS.load_supported_version(2, {"client": nova_client, "version": 2})
|
|
NOVA_VERSION = NOVA_VERSIONS.get_active_version()['version']
|
|
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
|
|
@memoized
|
|
def troveclient(request):
|
|
insecure = getattr(settings, 'OPENSTACK_SSL_NO_VERIFY', False)
|
|
cacert = getattr(settings, 'OPENSTACK_SSL_CACERT', None)
|
|
endpoint_type = getattr(settings, 'OPENSTACK_ENDPOINT_TYPE', 'publicURL')
|
|
region = request.user.services_region
|
|
|
|
endpoint = base.url_for(request, 'database')
|
|
auth_url, _ = auth_utils.fix_auth_url_version_prefix(
|
|
settings.OPENSTACK_KEYSTONE_URL)
|
|
auth = token_endpoint.Token(auth_url, request.user.token.id)
|
|
verify = not insecure and (cacert or True)
|
|
|
|
t_client = client.Client(session=session.Session(auth=auth, verify=verify),
|
|
service_type='database',
|
|
endpoint_type=endpoint_type,
|
|
region_name=region,
|
|
endpoint_override=endpoint)
|
|
return t_client
|
|
|
|
|
|
def cluster_list(request, marker=None):
|
|
page_size = utils.get_page_size(request)
|
|
return troveclient(request).clusters.list(limit=page_size, marker=marker)
|
|
|
|
|
|
def cluster_get(request, cluster_id):
|
|
return troveclient(request).clusters.get(cluster_id)
|
|
|
|
|
|
def cluster_delete(request, cluster_id):
|
|
return troveclient(request).clusters.delete(cluster_id)
|
|
|
|
|
|
def cluster_create(request, name, volume, flavor, num_instances,
|
|
datastore, datastore_version,
|
|
nics=None, root_password=None, locality=None):
|
|
instances = []
|
|
for i in range(num_instances):
|
|
instance = {}
|
|
instance["flavorRef"] = flavor
|
|
if volume > 0:
|
|
instance["volume"] = {'size': volume}
|
|
if nics:
|
|
instance["nics"] = [{"network_id": nics}]
|
|
instances.append(instance)
|
|
|
|
# TODO(saurabhs): vertica needs root password on cluster create
|
|
return troveclient(request).clusters.create(
|
|
name,
|
|
datastore,
|
|
datastore_version,
|
|
instances=instances,
|
|
locality=locality)
|
|
|
|
|
|
def cluster_grow(request, cluster_id, new_instances):
|
|
instances = []
|
|
for new_instance in new_instances:
|
|
instance = {}
|
|
instance["flavorRef"] = new_instance.flavor_id
|
|
if new_instance.volume > 0:
|
|
instance["volume"] = {'size': new_instance.volume}
|
|
if new_instance.name:
|
|
instance["name"] = new_instance.name
|
|
if new_instance.type:
|
|
instance["type"] = new_instance.type
|
|
if new_instance.related_to:
|
|
instance["related_to"] = new_instance.related_to
|
|
if new_instance.nics:
|
|
instance["nics"] = [{'network_id': new_instance.nics}]
|
|
instances.append(instance)
|
|
return troveclient(request).clusters.grow(cluster_id, instances)
|
|
|
|
|
|
def cluster_shrink(request, cluster_id, instances):
|
|
return troveclient(request).clusters.shrink(cluster_id, instances)
|
|
|
|
|
|
def create_cluster_root(request, cluster_id, password):
|
|
# It appears the code below depends on this trove change
|
|
# https://review.opendev.org/#/c/166954/. Comment out when that
|
|
# change merges.
|
|
# return troveclient(request).cluster.reset_root_password(cluster_id)
|
|
troveclient(request).root.create_cluster_root(cluster_id, password)
|
|
|
|
|
|
def instance_list(request, marker=None):
|
|
page_size = utils.get_page_size(request)
|
|
return troveclient(request).instances.list(limit=page_size, marker=marker)
|
|
|
|
|
|
def instance_list_all(request):
|
|
instances = instance_list(request)
|
|
marker = instances.next
|
|
while marker:
|
|
temp_instances = instance_list(request, marker=marker)
|
|
marker = temp_instances.next
|
|
for instance in temp_instances:
|
|
instances.append(instance)
|
|
instances.links = temp_instances.links
|
|
instances.next = None
|
|
return instances
|
|
|
|
|
|
def instance_get(request, instance_id):
|
|
return troveclient(request).instances.get(instance_id)
|
|
|
|
|
|
def instance_delete(request, instance_id):
|
|
return troveclient(request).instances.delete(instance_id)
|
|
|
|
|
|
def instance_create(request, name, volume, flavor=None, databases=None,
|
|
users=None, restore_point=None, nics=None,
|
|
datastore=None, datastore_version=None,
|
|
replica_of=None, replica_count=None,
|
|
volume_type=None, configuration=None, locality=None,
|
|
availability_zone=None, access=None):
|
|
# TODO(dklyle): adding conditional to support trove without volume
|
|
# support for now until API supports checking for volume support
|
|
if volume > 0 and not replica_of:
|
|
volume_params = {'size': volume}
|
|
if volume_type:
|
|
volume_params['type'] = volume_type
|
|
else:
|
|
volume_params = None
|
|
|
|
if replica_of:
|
|
flavor = None
|
|
volume_params = None
|
|
datastore = None
|
|
datastore_version = None
|
|
|
|
return troveclient(request).instances.create(
|
|
name,
|
|
flavor,
|
|
volume=volume_params,
|
|
databases=databases,
|
|
users=users,
|
|
restorePoint=restore_point,
|
|
nics=nics,
|
|
datastore=datastore,
|
|
datastore_version=datastore_version,
|
|
replica_of=replica_of,
|
|
replica_count=replica_count,
|
|
configuration=configuration,
|
|
locality=locality,
|
|
availability_zone=availability_zone,
|
|
access=access)
|
|
|
|
|
|
def instance_resize_volume(request, instance_id, size):
|
|
return troveclient(request).instances.resize_volume(instance_id, size)
|
|
|
|
|
|
def instance_resize(request, instance_id, flavor_id):
|
|
return troveclient(request).instances.resize_instance(instance_id,
|
|
flavor_id)
|
|
|
|
|
|
def instance_backups(request, instance_id):
|
|
return troveclient(request).instances.backups(instance_id)
|
|
|
|
|
|
def instance_restart(request, instance_id):
|
|
return troveclient(request).instances.restart(instance_id)
|
|
|
|
|
|
def instance_update(request, instance_id, **kwargs):
|
|
return troveclient(request).instances.update(instance_id, **kwargs)
|
|
|
|
|
|
def instance_detach_replica(request, instance_id):
|
|
return troveclient(request).instances.update(instance_id,
|
|
detach_replica_source=True)
|
|
|
|
|
|
def promote_to_replica_source(request, instance_id):
|
|
return troveclient(request).instances.promote_to_replica_source(
|
|
instance_id)
|
|
|
|
|
|
def eject_replica_source(request, instance_id):
|
|
return troveclient(request).instances.eject_replica_source(instance_id)
|
|
|
|
|
|
def instance_attach_configuration(request, instance_id, configuration):
|
|
return troveclient(request).instances.update(instance_id,
|
|
configuration=configuration)
|
|
|
|
|
|
def instance_detach_configuration(request, instance_id):
|
|
return troveclient(request).instances.update(instance_id,
|
|
remove_configuration=True)
|
|
|
|
|
|
def database_list(request, instance_id):
|
|
return troveclient(request).databases.list(instance_id)
|
|
|
|
|
|
def database_create(request, instance_id, db_name, character_set=None,
|
|
collation=None):
|
|
database = {'name': db_name}
|
|
if collation:
|
|
database['collate'] = collation
|
|
if character_set:
|
|
database['character_set'] = character_set
|
|
return troveclient(request).databases.create(instance_id, [database])
|
|
|
|
|
|
def database_delete(request, instance_id, db_name):
|
|
return troveclient(request).databases.delete(instance_id, db_name)
|
|
|
|
|
|
def backup_list(request):
|
|
return troveclient(request).backups.list()
|
|
|
|
|
|
def backup_get(request, backup_id):
|
|
return troveclient(request).backups.get(backup_id)
|
|
|
|
|
|
def backup_delete(request, backup_id):
|
|
return troveclient(request).backups.delete(backup_id)
|
|
|
|
|
|
def backup_create(request, name, instance_id, description=None,
|
|
parent_id=None, swift_container=None):
|
|
return troveclient(request).backups.create(name, instance_id,
|
|
description=description,
|
|
parent_id=parent_id,
|
|
swift_container=swift_container)
|
|
|
|
|
|
def backup_strategy_create(request, instance_id=None, swift_container=None):
|
|
return troveclient(request).backup_strategies.create(
|
|
instance_id=instance_id, swift_container=swift_container)
|
|
|
|
|
|
def backup_strategy_list(request, instance_id=None, project_id=None):
|
|
return troveclient(request).backup_strategies.list(instance_id=instance_id,
|
|
project_id=project_id)
|
|
|
|
|
|
def backup_strategy_delete(request, instance_id=None, project_id=None):
|
|
return troveclient(request).backup_strategies.delete(
|
|
instance_id=instance_id, project_id=project_id)
|
|
|
|
|
|
def nova_client_client(request):
|
|
insecure = getattr(settings, 'OPENSTACK_SSL_NO_VERIFY', False)
|
|
cacert = getattr(settings, 'OPENSTACK_SSL_CACERT', None)
|
|
endpoint_type = getattr(settings, 'OPENSTACK_ENDPOINT_TYPE', 'publicURL')
|
|
region = request.user.services_region
|
|
|
|
endpoint = base.url_for(request, 'compute')
|
|
auth_url, _ = auth_utils.fix_auth_url_version_prefix(
|
|
settings.OPENSTACK_KEYSTONE_URL)
|
|
auth = token_endpoint.Token(auth_url, request.user.token.id)
|
|
verify = not insecure and (cacert or True)
|
|
|
|
nova = nova_client.Client(
|
|
NOVA_VERSION,
|
|
session=session.Session(auth=auth, verify=verify),
|
|
endpoint_type=endpoint_type,
|
|
service_type='compute',
|
|
region_name=region,
|
|
endpoint_override=endpoint)
|
|
|
|
return nova
|
|
|
|
|
|
def flavor_list(request):
|
|
return nova_client_client(request).flavors.list()
|
|
|
|
|
|
def datastore_flavors(request, datastore_name=None,
|
|
datastore_version=None):
|
|
return flavor_list(request)
|
|
|
|
|
|
def flavor_get(request, flavor_id):
|
|
return nova_client_client(request).flavors.get(flavor_id)
|
|
|
|
|
|
def root_enable(request, instance_ids):
|
|
username, password = troveclient(request).root.create(instance_ids[0])
|
|
return username, password
|
|
|
|
|
|
def root_show(request, instance_id):
|
|
return troveclient(request).root.is_root_enabled(instance_id)
|
|
|
|
|
|
def root_disable(request, instance_id):
|
|
return troveclient(request).root.delete(instance_id)
|
|
|
|
|
|
def users_list(request, instance_id):
|
|
return troveclient(request).users.list(instance_id)
|
|
|
|
|
|
def user_create(request, instance_id, username, password,
|
|
host=None, databases=[]):
|
|
user = {'name': username, 'password': password, 'databases': databases}
|
|
if host:
|
|
user['host'] = host
|
|
|
|
return troveclient(request).users.create(instance_id, [user])
|
|
|
|
|
|
def user_delete(request, instance_id, user, host=None):
|
|
return troveclient(request).users.delete(instance_id, user, hostname=host)
|
|
|
|
|
|
def user_update_attributes(request, instance_id, name, host=None,
|
|
new_name=None, new_password=None, new_host=None):
|
|
new_attributes = {}
|
|
if new_name:
|
|
new_attributes['name'] = new_name
|
|
if new_password:
|
|
new_attributes['password'] = new_password
|
|
if new_host:
|
|
new_attributes['host'] = new_host
|
|
return troveclient(request).users.update_attributes(
|
|
instance_id, name, newuserattr=new_attributes, hostname=host)
|
|
|
|
|
|
def user_list_access(request, instance_id, username, host=None):
|
|
return troveclient(request).users.list_access(
|
|
instance_id, username, hostname=host)
|
|
|
|
|
|
def user_grant_access(request, instance_id, username, databases, host=None):
|
|
return troveclient(request).users.grant(
|
|
instance_id, username, databases, hostname=host)
|
|
|
|
|
|
def user_revoke_access(request, instance_id, username, database, host=None):
|
|
return troveclient(request).users.revoke(
|
|
instance_id, username, database, hostname=host)
|
|
|
|
|
|
def user_show_access(request, instance_id, username, host=None):
|
|
return troveclient(request).users.list_access(
|
|
instance_id, username, hostname=host)
|
|
|
|
|
|
def datastore_list(request):
|
|
return troveclient(request).datastores.list()
|
|
|
|
|
|
def datastore_version_list(request, datastore):
|
|
return troveclient(request).datastore_versions.list(datastore)
|
|
|
|
|
|
def log_list(request, instance_id):
|
|
return troveclient(request).instances.log_list(instance_id)
|
|
|
|
|
|
def log_enable(request, instance_id, log_name):
|
|
return troveclient(request).instances.log_action(instance_id, log_name,
|
|
enable=True)
|
|
|
|
|
|
def log_disable(request, instance_id, log_name):
|
|
return troveclient(request).instances.log_action(instance_id, log_name,
|
|
disable=True)
|
|
|
|
|
|
def log_publish(request, instance_id, log_name):
|
|
return troveclient(request).instances.log_action(instance_id, log_name,
|
|
publish=True)
|
|
|
|
|
|
def log_discard(request, instance_id, log_name):
|
|
return troveclient(request).instances.log_action(instance_id, log_name,
|
|
discard=True)
|
|
|
|
|
|
def log_tail(request, instance_id, log_name, publish, lines, swift=None):
|
|
return troveclient(request).instances.log_generator(instance_id,
|
|
log_name,
|
|
publish=publish,
|
|
lines=lines,
|
|
swift=swift)
|
|
|
|
|
|
def configuration_list(request):
|
|
return troveclient(request).configurations.list()
|
|
|
|
|
|
def configuration_get(request, group_id):
|
|
return troveclient(request).configurations.get(group_id)
|
|
|
|
|
|
def configuration_parameters_list(request, datastore, datastore_version):
|
|
return troveclient(request).configuration_parameters.parameters(
|
|
datastore, datastore_version)
|
|
|
|
|
|
def configuration_create(request,
|
|
name,
|
|
values,
|
|
description=None,
|
|
datastore=None,
|
|
datastore_version=None):
|
|
return troveclient(request).configurations.create(name,
|
|
values,
|
|
description,
|
|
datastore,
|
|
datastore_version)
|
|
|
|
|
|
def configuration_delete(request, group_id):
|
|
return troveclient(request).configurations.delete(group_id)
|
|
|
|
|
|
def configuration_instances(request, group_id):
|
|
return troveclient(request).configurations.instances(group_id)
|
|
|
|
|
|
def configuration_update(request, group_id, values):
|
|
return troveclient(request).configurations.update(group_id, values)
|
|
|
|
|
|
def configuration_default(request, instance_id):
|
|
return troveclient(request).instances.configuration(instance_id)
|
|
|
|
|
|
def stop_database(request, instance_id):
|
|
return troveclient(request).mgmt_instances.stop(instance_id)
|