![melanie witt](/assets/img/avatar_default.png)
The os-hosts API uses different attribute names depending on whether the host was returned as part of a list or not. A host returned from 'show host' has the attribute "host" whereas a host returned from 'list hosts' has the attribute "host_name". This adds a host_name property to the Host class that will set the "host" attribute if necessary. Although this doesn't exactly mirror the responses coming back from nova api, it will make it easier for users to use the objects interchangeably for hosts.list() operations and hosts.update() operations, for example. Co-Authored-By: Chung Chih, Hung <lyan.h@inwinstack.com> Closes-Bug: #1434167 Change-Id: I5c339bdd1ab867d972759ade9a10b86bfda1e70a
83 lines
2.5 KiB
Python
83 lines
2.5 KiB
Python
# Copyright 2011 OpenStack Foundation
|
|
# 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.
|
|
|
|
"""
|
|
host interface (1.1 extension).
|
|
"""
|
|
from novaclient import base
|
|
|
|
|
|
class Host(base.Resource):
|
|
def __repr__(self):
|
|
return "<Host: %s>" % self.host
|
|
|
|
def _add_details(self, info):
|
|
dico = 'resource' in info and info['resource'] or info
|
|
for (k, v) in dico.items():
|
|
setattr(self, k, v)
|
|
|
|
def update(self, values):
|
|
return self.manager.update(self.host, values)
|
|
|
|
def startup(self):
|
|
return self.manager.host_action(self.host, 'startup')
|
|
|
|
def shutdown(self):
|
|
return self.manager.host_action(self.host, 'shutdown')
|
|
|
|
def reboot(self):
|
|
return self.manager.host_action(self.host, 'reboot')
|
|
|
|
@property
|
|
def host_name(self):
|
|
return self.host
|
|
|
|
@host_name.setter
|
|
def host_name(self, value):
|
|
# A host from hosts.list() has the attribute "host_name" instead of
|
|
# "host." This sets "host" if that's the case. Even though it doesn't
|
|
# exactly mirror the response format, it enables users to work with
|
|
# host objects from list and non-list operations interchangeably.
|
|
self.host = value
|
|
|
|
|
|
class HostManager(base.ManagerWithFind):
|
|
resource_class = Host
|
|
|
|
def get(self, host):
|
|
"""
|
|
Describes cpu/memory/hdd info for host.
|
|
|
|
:param host: destination host name.
|
|
"""
|
|
return self._list("/os-hosts/%s" % host, "host")
|
|
|
|
def update(self, host, values):
|
|
"""Update status or maintenance mode for the host."""
|
|
return self._update("/os-hosts/%s" % host, values)
|
|
|
|
def host_action(self, host, action):
|
|
"""Perform an action on a host."""
|
|
url = '/os-hosts/{0}/{1}'.format(host, action)
|
|
return self.api.client.get(url)
|
|
|
|
def list(self, zone=None):
|
|
url = '/os-hosts'
|
|
if zone:
|
|
url = '/os-hosts?zone=%s' % zone
|
|
return self._list(url, "hosts")
|
|
|
|
list_all = list
|