75 lines
2.3 KiB
Python
75 lines
2.3 KiB
Python
# Copyright (c) 2013 Mirantis Inc.
|
|
#
|
|
# 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_utils import netutils
|
|
from six.moves.urllib import parse as urlparse
|
|
|
|
from sahara.i18n import _
|
|
from sahara.plugins import exceptions as ex
|
|
|
|
|
|
def get_node_groups(cluster, node_process=None):
|
|
return [ng for ng in cluster.node_groups
|
|
if (node_process is None or
|
|
node_process in ng.node_processes)]
|
|
|
|
|
|
def get_instances_count(cluster, node_process=None):
|
|
return sum([ng.count for ng in get_node_groups(cluster, node_process)])
|
|
|
|
|
|
def get_instances(cluster, node_process=None):
|
|
nodes = get_node_groups(cluster, node_process)
|
|
return reduce(lambda a, b: a + b.instances, nodes, [])
|
|
|
|
|
|
def get_instance(cluster, node_process):
|
|
instances = get_instances(cluster, node_process)
|
|
if len(instances) > 1:
|
|
raise ex.InvalidComponentCountException(
|
|
node_process, _('0 or 1'), len(instances))
|
|
return instances[0] if instances else None
|
|
|
|
|
|
def generate_host_names(nodes):
|
|
return "\n".join([n.hostname() for n in nodes])
|
|
|
|
|
|
def generate_fqdn_host_names(nodes):
|
|
return "\n".join([n.fqdn() for n in nodes])
|
|
|
|
|
|
def get_port_from_address(address):
|
|
parse_result = urlparse.urlparse(address)
|
|
# urlparse do not parse values like 0.0.0.0:8000,
|
|
# netutils do not parse values like http://localhost:8000,
|
|
# so combine approach is using
|
|
if parse_result.port:
|
|
return parse_result.port
|
|
else:
|
|
return netutils.parse_host_port(address)[1]
|
|
|
|
|
|
def instances_with_services(instances, node_processes):
|
|
node_processes = set(node_processes)
|
|
return filter(
|
|
lambda x: node_processes.intersection(
|
|
x.node_group.node_processes), instances)
|
|
|
|
|
|
def start_process_event_message(process):
|
|
return _("Start the following process(es): {process}").format(
|
|
process=process)
|