# 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, admin_password, key_pair, partitions, 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, admin_password=admin_password, key_pair=key_pair, partitions=partitions, 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') def manage_server(self, context, server, node_uuid): cctxt = self.client.prepare(topic=self.topic, server=CONF.host) return cctxt.call(context, 'manage_server', server=server, node_uuid=node_uuid)