Source code for ironicclient.v1.driver

# Copyright 2013 Red Hat, Inc.
# 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.

from ironicclient.common import base
from ironicclient.common.i18n import _
from ironicclient import exc


[docs]class Driver(base.Resource): def __repr__(self): return "<Driver %s>" % self._info
[docs]class DriverManager(base.Manager): resource_class = Driver _resource_name = 'drivers'
[docs] def list(self): return self._list('/v1/drivers', self._resource_name)
[docs] def get(self, driver_name): return self._get(resource_id=driver_name)
[docs] def update(self, driver_name, patch, http_method='PATCH'): return self._update(resource_id=driver_name, patch=patch, method=http_method)
[docs] def delete(self, driver_name): return self._delete(resource_id=driver_name)
[docs] def properties(self, driver_name): return self._get_as_dict('%s/properties' % driver_name)
[docs] def raid_logical_disk_properties(self, driver_name): """Returns the RAID logical disk properties for the driver. :param driver_name: Name of the driver. :returns: A dictionary containing the properties that can be mentioned for RAID logical disks and a textual description for them. It returns an empty dictionary on error. """ info = None try: info = self._list( '/v1/drivers/%s/raid/logical_disk_properties' % driver_name)[0] except IndexError: pass if info: return info.to_dict() return {}
[docs] def vendor_passthru(self, driver_name, method, args=None, http_method=None): """Issue requests for vendor-specific actions on a given driver. :param driver_name: The name of the driver. :param method: Name of the vendor method. :param args: Optional. The arguments to be passed to the method. :param http_method: The HTTP method to use on the request. Defaults to POST. """ if args is None: args = {} if http_method is None: http_method = 'POST' http_method = http_method.upper() path = "%s/vendor_passthru/%s" % (driver_name, method) if http_method in ('POST', 'PUT', 'PATCH'): return self.update(path, args, http_method=http_method) elif http_method == 'DELETE': return self.delete(path) elif http_method == 'GET': return self.get(path) else: raise exc.InvalidAttribute( _('Unknown HTTP method: %s') % http_method)
[docs] def get_vendor_passthru_methods(self, driver_name): return self._get_as_dict("%s/vendor_passthru/methods" % driver_name)