128 lines
5.4 KiB
Python
128 lines
5.4 KiB
Python
# Copyright 2016 Huawei Technologies Co.,LTD.
|
|
# 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.
|
|
"""
|
|
Client side of the engine RPC API.
|
|
"""
|
|
from oslo_config import cfg
|
|
import oslo_messaging as messaging
|
|
|
|
from mogan.common import constants
|
|
from mogan.common import rpc
|
|
from mogan.objects import base as objects_base
|
|
|
|
CONF = cfg.CONF
|
|
|
|
|
|
class EngineAPI(object):
|
|
"""Client side of the engine RPC API.
|
|
|
|
API version history:
|
|
|
|
| 1.0 - Initial version.
|
|
|
|
"""
|
|
|
|
RPC_API_VERSION = '1.0'
|
|
|
|
def __init__(self, topic=None):
|
|
super(EngineAPI, self).__init__()
|
|
self.topic = topic
|
|
if self.topic is None:
|
|
self.topic = constants.ENGINE_TOPIC
|
|
|
|
target = messaging.Target(topic=self.topic,
|
|
version='1.0')
|
|
serializer = objects_base.MoganObjectSerializer()
|
|
self.client = rpc.get_client(target,
|
|
version_cap=self.RPC_API_VERSION,
|
|
serializer=serializer)
|
|
|
|
def schedule_and_create_servers(self, context, servers, requested_networks,
|
|
user_data, injected_files, key_pair,
|
|
request_spec, filter_properties):
|
|
"""Signal to engine service to perform a deployment."""
|
|
cctxt = self.client.prepare(topic=self.topic, server=CONF.host)
|
|
cctxt.cast(context, 'schedule_and_create_servers', servers=servers,
|
|
requested_networks=requested_networks,
|
|
user_data=user_data,
|
|
injected_files=injected_files,
|
|
key_pair=key_pair,
|
|
request_spec=request_spec,
|
|
filter_properties=filter_properties)
|
|
|
|
def delete_server(self, context, server):
|
|
"""Signal to engine service to delete a server."""
|
|
cctxt = self.client.prepare(topic=self.topic, server=CONF.host)
|
|
cctxt.cast(context, 'delete_server', server=server)
|
|
|
|
def set_power_state(self, context, server, state):
|
|
"""Signal to engine service to perform power action on server."""
|
|
cctxt = self.client.prepare(topic=self.topic, server=CONF.host)
|
|
return cctxt.cast(context, 'set_power_state',
|
|
server=server, state=state)
|
|
|
|
def rebuild_server(self, context, server, preserve_ephemeral):
|
|
"""Signal to engine service to rebuild a server."""
|
|
cctxt = self.client.prepare(topic=self.topic, server=CONF.host)
|
|
return cctxt.cast(context, 'rebuild_server', server=server,
|
|
preserve_ephemeral=preserve_ephemeral)
|
|
|
|
def get_serial_console(self, context, server, console_type):
|
|
cctxt = self.client.prepare(topic=self.topic, server=CONF.host)
|
|
return cctxt.call(context, 'get_serial_console',
|
|
server=server, console_type=console_type)
|
|
|
|
def attach_interface(self, context, server, net_id, port_id):
|
|
cctxt = self.client.prepare(topic=self.topic, server=CONF.host)
|
|
cctxt.call(context, 'attach_interface',
|
|
server=server, net_id=net_id, port_id=port_id)
|
|
|
|
def detach_interface(self, context, server, port_id):
|
|
cctxt = self.client.prepare(topic=self.topic, server=CONF.host)
|
|
cctxt.call(context, 'detach_interface', server=server,
|
|
port_id=port_id)
|
|
|
|
def list_compute_nodes(self, context):
|
|
cctxt = self.client.prepare(topic=self.topic, server=CONF.host)
|
|
return cctxt.call(context, 'list_compute_nodes')
|
|
|
|
def list_aggregate_nodes(self, context, aggregate_uuid):
|
|
cctxt = self.client.prepare(topic=self.topic, server=CONF.host)
|
|
return cctxt.call(context, 'list_aggregate_nodes',
|
|
aggregate_uuid=aggregate_uuid)
|
|
|
|
def add_aggregate_node(self, context, aggregate_uuid, node):
|
|
cctxt = self.client.prepare(topic=self.topic, server=CONF.host)
|
|
return cctxt.call(context, 'add_aggregate_node',
|
|
aggregate_uuid=aggregate_uuid, node=node)
|
|
|
|
def remove_aggregate_node(self, context, aggregate_uuid, node):
|
|
cctxt = self.client.prepare(topic=self.topic, server=CONF.host)
|
|
return cctxt.call(context, 'remove_aggregate_node',
|
|
aggregate_uuid=aggregate_uuid, node=node)
|
|
|
|
def remove_aggregate(self, context, aggregate_uuid):
|
|
cctxt = self.client.prepare(topic=self.topic, server=CONF.host)
|
|
return cctxt.call(context, 'remove_aggregate',
|
|
aggregate_uuid=aggregate_uuid)
|
|
|
|
def list_node_aggregates(self, context, node):
|
|
cctxt = self.client.prepare(topic=self.topic, server=CONF.host)
|
|
return cctxt.call(context, 'list_node_aggregates', node=node)
|
|
|
|
def get_manageable_servers(self, context):
|
|
cctxt = self.client.prepare(topic=self.topic, server=CONF.host)
|
|
return cctxt.call(context, 'get_manageable_servers')
|