dellemc.openmanage.idrac_redfish_storage_controller – Configures the storage controller settings

Note

This plugin is part of the dellemc.openmanage collection (version 3.6.0).

You might already have this collection installed if you are using the ansible package. It is not included in ansible-core. To check whether it is installed, run ansible-galaxy collection list.

To install it, use: ansible-galaxy collection install dellemc.openmanage.

To use it in a playbook, specify: dellemc.openmanage.idrac_redfish_storage_controller.

New in version 2.1.0: of dellemc.openmanage

Synopsis

  • This module configures the settings of the storage controller using Redfish.

Requirements

The below requirements are needed on the host that executes this module.

  • python >= 2.7.5

Parameters

Parameter

Comments

baseuri

string / required

IP address of the target out-of-band controller. For example- <ipaddress>:<port>.

command

string

These actions may require a system reset, depending on the controller’s capabilities.

ResetConfig - Deletes all the virtual disks and unassigns all hot spares on physical disks.

AssignSpare - Assigns a physical disk as a dedicated or global hot spare for a virtual disk.

SetControllerKey - Sets the key on controllers, which is used to encrypt the drives in Local key Management(LKM).

RemoveControllerKey - Erases the encryption key on the controller.

ReKey - Resets the key on the controller.

Choices:

  • ResetConfig

  • AssignSpare ← (default)

  • SetControllerKey

  • RemoveControllerKey

  • ReKey

controller_id

string

FQDD of the storage controller. For example- ‘RAID.Slot.1-1’.

This option is mandatory when command is ResetConfig, SetControllerKey, RemoveControllerKey and ReKey.

key

string

A new security key passphrase that the encryption-capable controller uses to create the encryption key. The controller uses the encryption key to lock or unlock access to the Self Encryption Disk(SED). Only one encryption key can be created for each controller.

This is mandatory when command is SetControllerKey or ReKey, and when mode is LKM.

key_id

string

This is a user supplied text label associated with the passphrase.

This is mandatory when command is SetControllerKey or ReKey, and when mode is LKM.

mode

string

Encryption mode of the encryption-capable controller: 1 - Local Key Management (LKM), 2 - Security Enterprise Key Manager(SEKM).

This option is applicable only when command is ReKey.

SEKM requires secure enterprise key manager license on the iDRAC.

Choices:

  • LKM ← (default)

  • SEKM

old_key

string

Security key passphrase used by the encryption-capable controller..

This option is mandatory when command is ReKey and mode is LKM.

password

string / required

Password of the target out-of-band controller.

target

string

Fully Qualified Device Descriptor (FQDD) of the target physical drive that is assigned as a spare.

This is mandatory when command is AssignSpare.

If volume_id is not specified or empty, this physical drive will be assigned as a global hot spare.

username

string / required

Username of the target out-of-band controller.

volume_id

list / elements=string

FQDD of the volumes to which a hot spare is assigned.

Applicable if command is AssignSpare.

To know the number of volumes to which a hot spare can be assigned, refer iDRAC Redfish API guide.

Notes

Note

  • Run this module from a system that has direct access to DellEMC iDRAC.

  • This module does not support check_mode.

Examples

---
- name: Assign dedicated hot spare
  dellemc.openmanage.idrac_redfish_storage_controller:
    baseuri: "192.168.0.1:443"
    username: "user_name"
    password: "user_password"
    volume_id:
      - "Disk.Virtual.0:RAID.Slot.1-1"
    target: "Disk.Bay.0:Enclosure.Internal.0-1:RAID.Slot.1-1"
  tags:
    - assign_dedicated_hot_spare

- name: Assign global hot spare
  dellemc.openmanage.idrac_redfish_storage_controller:
    baseuri: "192.168.0.1:443"
    username: "user_name"
    password: "user_password"
    target: "Disk.Bay.0:Enclosure.Internal.0-1:RAID.Slot.1-1"
  tags:
    - assign_global_hot_spare

- name: Set controller encryption key
  dellemc.openmanage.idrac_redfish_storage_controller:
    baseuri: "192.168.0.1:443"
    username: "user_name"
    password: "user_password"
    command: "SetControllerKey"
    controller_id: "RAID.Slot.1-1"
    key: "PassPhrase@123"
    key_id: "mykeyid123"
  tags:
    - set_controller_key

- name: Rekey in LKM mode
  dellemc.openmanage.idrac_redfish_storage_controller:
    baseuri: "192.168.0.1:443"
    username: "user_name"
    password: "user_password"
    command: "ReKey"
    controller_id: "RAID.Slot.1-1"
    key: "NewPassPhrase@123"
    key_id: "newkeyid123"
    old_key: "OldPassPhrase@123"
  tags:
    - rekey_lkm

- name: Rekey in SEKM mode
  dellemc.openmanage.idrac_redfish_storage_controller:
    baseuri: "192.168.0.1:443"
    username: "user_name"
    password: "user_password"
    command: "ReKey"
    controller_id: "RAID.Slot.1-1"
    mode: "SEKM"
  tags:
    - rekey_sekm

- name: Remove controller key
  dellemc.openmanage.idrac_redfish_storage_controller:
    baseuri: "192.168.0.1:443"
    username: "user_name"
    password: "user_password"
    command: "RemoveControllerKey"
    controller_id: "RAID.Slot.1-1"
  tags:
    - remove_controller_key

- name: Reset controller configuration
  dellemc.openmanage.idrac_redfish_storage_controller:
    baseuri: "192.168.0.1:443"
    username: "user_name"
    password: "user_password"
    command: "ResetConfig"
    controller_id: "RAID.Slot.1-1"
  tags:
    - reset_config

Return Values

Common return values are documented here, the following are the fields unique to this module:

Key

Description

error_info

dictionary

Details of a http error.

Returned: on http error

Sample: {“error”: {“@Message.ExtendedInfo”: [{“Message”: “Unable to run the method because the requested HTTP method is not allowed.”, “MessageArgs”: [], “MessageArgs@odata.count”: 0, “MessageId”: “iDRAC.1.6.SYS402”, “RelatedProperties”: [], “RelatedProperties@odata.count”: 0, “Resolution”: “Enter a valid HTTP method and retry the operation. For information about valid methods, see the Redfish Users Guide available on the support site.”, “Severity”: “Informational”}], “code”: “Base.1.0.GeneralError”, “message”: “A general error has occurred. See ExtendedInfo for more information”}}

msg

string

Overall status of the storage controller configuration operation.

Returned: always

Sample: “Successfully submitted the job that performs the AssignSpare operation”

task

dictionary

ID and URI resource of the job created.

Returned: success

Sample: {“id”: “JID_XXXXXXXXXXXXX”, “uri”: “/redfish/v1/Managers/iDRAC.Embedded.1/Jobs/JID_XXXXXXXXXXXXX”}

Authors

  • Jagadeesh N V (@jagadeeshnv)