System Compatibility

Compatibility can be hard to maintain if you have many different systems with different firmware versions and system generations on each of them. gen_compat tries to help alleviate the headaches associated with this. It can automatically detect what type of system you are using and provide useful string values of key property keys, paths, types, and Booleans to check what the system type is.

A compatibility class is automatically created as part of an RmcApp class.

NOTE

While currently gen_compat only specifically supports HPE iLO systems, the Definevalstenplus class defines are mostly Redfish standard values. gen_compat can also easily be extended to provide strings for any system type.

Creating a Compatibility Class

To create a compatibility class we first need to import the relevant module and create an empty class.

Copy
Copied
>>> from redfish.ris.gen_compat import Typesandpathdefines
>>> COMPAT_OBJ = Typesandpathdefines()

Using a Compatibility Class

Now if you try to read any defines you will find the values are all empty. We need to point the compatibility class to a system in order to detect its API type, iLO version, and generation if necessary. This is done with the getgen function. If any other connection requirements are needed they can also be added now.

Copy
Copied
>>> COMPAT_OBJ.getgen(url=iLO_host, username=login_account, password=login_password)

After running the getgen function, if no connection errors occurred, you should be able to see information on the system as well as a list of string defines you can use in place of direct strings. That way you guarantee no matter the system you will have the correct key, type, or path value.

NOTE

The following example defines are from an iLO 5 system.

Copy
Copied
>>> COMPAT_OBJ.ilogen
5
>>> COMPAT_OBJ.defs.hrefstring
'@odata.id'
>>> COMPAT_OBJ.defs.collectionstring
'Members`
>>> COMPAT_OBJ.defs.biostype
'Bios.'

Here is the compatibility class in action on a RedfishClient. The following code would work the same for LegacyRest due to the use of the compatibility class instead of hard coding paths and keys.

Copy
Copied
>>> REST_OBJ = RestClient(base_url=iLO_host, username=login_account, password=login_password)
>>> resp = REST_OBJ.get(COMPAT_OBJ.defs.startpath)
>>> resp.path
'/redfish/v1/'
>>> resp.obj.Chassis[COMPAT_OBJ.defs.hrefstring]
u'/redfish/v1/Chassis/'

Updating a Compatibility Class

On some iLO 4 systems both Redfish and LegacyRest are available for use for backwards compatibility. The compatibility class will automatically assume LegacyRest in this instance. In order to use Redfish on these systems you will need to update the defines.

First create a new object with the redfish flag added.

Copy
Copied
>>> COMPAT_OBJ = Typesandpathdefines()
>>> COMPAT_OBJ.getgen(url=iLO_host, username=login_account, password=login_password, isredfish=True)

The initial isredfish flag will ensure we load redfish paths when performing the initial detection. We still need to call updatedefinesflag to update our defines to Redfish.

Copy
Copied
>>> COMPAT_OBJ.defs.startpath
'/rest/v1'
>>> COMPAT_OBJ.updatedefinesflag(redfishflag=True)
True
>>> COMPAT_OBJ.defs.startpath
'/redfish/v1/'
NOTE

This will not do anything on Redfish only systems, so it is safe to use in all cases to ensure Redfish is used if that is desired.