c21b7d7038
Redfish hardware usually will support better methods -- e.g. redfish-https or redfish-virtual-media, however we've had some user requests for the http boot interfaces on Redfish. Since we can generally expect the generic boot interfaces to work on redfish, this enables all of them. Related-Bug: #2032380 Change-Id: I9c36072f6165baaa985862113b283f34bed7bee4
76 lines
2.9 KiB
Python
76 lines
2.9 KiB
Python
# Copyright 2017 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 ironic.drivers import generic
|
|
from ironic.drivers.modules import agent
|
|
from ironic.drivers.modules import noop
|
|
from ironic.drivers.modules import noop_mgmt
|
|
from ironic.drivers.modules.redfish import bios as redfish_bios
|
|
from ironic.drivers.modules.redfish import boot as redfish_boot
|
|
from ironic.drivers.modules.redfish import firmware as redfish_firmware
|
|
from ironic.drivers.modules.redfish import inspect as redfish_inspect
|
|
from ironic.drivers.modules.redfish import management as redfish_mgmt
|
|
from ironic.drivers.modules.redfish import power as redfish_power
|
|
from ironic.drivers.modules.redfish import raid as redfish_raid
|
|
from ironic.drivers.modules.redfish import vendor as redfish_vendor
|
|
|
|
|
|
class RedfishHardware(generic.GenericHardware):
|
|
"""Redfish hardware type."""
|
|
|
|
@property
|
|
def supported_bios_interfaces(self):
|
|
"""List of supported bios interfaces."""
|
|
return [redfish_bios.RedfishBIOS, noop.NoBIOS]
|
|
|
|
@property
|
|
def supported_management_interfaces(self):
|
|
"""List of supported management interfaces."""
|
|
return [redfish_mgmt.RedfishManagement, noop_mgmt.NoopManagement]
|
|
|
|
@property
|
|
def supported_power_interfaces(self):
|
|
"""List of supported power interfaces."""
|
|
return [redfish_power.RedfishPower]
|
|
|
|
@property
|
|
def supported_inspect_interfaces(self):
|
|
"""List of supported power interfaces."""
|
|
return ([redfish_inspect.RedfishInspect]
|
|
+ super().supported_inspect_interfaces)
|
|
|
|
@property
|
|
def supported_boot_interfaces(self):
|
|
"""List of supported boot interfaces."""
|
|
# NOTE(dtantsur): virtual media goes last because of limited hardware
|
|
# vendors support.
|
|
return (super().supported_boot_interfaces
|
|
+ [redfish_boot.RedfishVirtualMediaBoot,
|
|
redfish_boot.RedfishHttpsBoot])
|
|
|
|
@property
|
|
def supported_vendor_interfaces(self):
|
|
"""List of supported vendor interfaces."""
|
|
return [redfish_vendor.RedfishVendorPassthru, noop.NoVendor]
|
|
|
|
@property
|
|
def supported_raid_interfaces(self):
|
|
"""List of supported raid interfaces."""
|
|
return [redfish_raid.RedfishRAID, noop.NoRAID, agent.AgentRAID]
|
|
|
|
@property
|
|
def supported_firmware_interfaces(self):
|
|
return [redfish_firmware.RedfishFirmware, noop.NoFirmware]
|