ironic.drivers.modules.agent_client module

class ironic.drivers.modules.agent_client.AgentClient[source]

Bases: object

Client for interacting with nodes via a REST API.

collect_system_logs(node)[source]

Collect and package diagnostic and support data from the ramdisk.

Parameters:

node – A Node object.

Raises:

IronicException when failed to issue the request or there was a malformed response from the agent.

Raises:

AgentAPIError when agent failed to execute specified command.

Raises:

AgentInProgress when the command fails to execute as the agent is presently executing the prior command.

Returns:

A dict containing command response from agent. See get_commands_status() for a command result sample.

execute_clean_step(step, node, ports)[source]

Execute specified clean step.

Parameters:
  • step – A clean step dictionary to execute.

  • node – A Node object.

  • ports – Ports associated with the node.

Raises:

IronicException when failed to issue the request or there was a malformed response from the agent.

Raises:

AgentAPIError when agent failed to execute specified command.

Raises:

AgentInProgress when the command fails to execute as the agent is presently executing the prior command.

Returns:

A dict containing command response from agent. See get_commands_status() for a command result sample. The value of key command_result is in the form of:

{
  'clean_result': <the result of execution, step specific>,
  'clean_step': <the clean step issued to agent>
}

execute_deploy_step(step, node, ports)[source]

Execute specified deploy step.

Parameters:
  • step – A deploy step dictionary to execute.

  • node – A Node object.

  • ports – Ports associated with the node.

Raises:

IronicException when failed to issue the request or there was a malformed response from the agent.

Raises:

AgentAPIError when agent failed to execute specified command.

Raises:

AgentInProgress when the command fails to execute as the agent is presently executing the prior command.

Returns:

A dict containing command response from agent. See get_commands_status() for a command result sample. The value of key command_result is in the form of:

{
  'deploy_result': <the result of execution, step specific>,
  'deploy_step': <the deploy step issued to agent>
}

execute_service_step(step, node, ports)[source]

Execute specified service step.

Parameters:
  • step – A service step dictionary to execute.

  • node – A Node object.

  • ports – Ports associated with the node.

Raises:

IronicException when failed to issue the request or there was a malformed response from the agent.

Raises:

AgentAPIError when agent failed to execute specified command.

Raises:

AgentInProgress when the command fails to execute as the agent is presently executing the prior command.

Returns:

A dict containing command response from agent. See get_commands_status() for a command result sample. The value of key command_result is in the form of:

{
  'service_result': <the result of execution, step specific>,
  'service_step': <the service step issued to agent>
}

finalize_rescue(node)[source]

Instruct the ramdisk to finalize entering of rescue mode.

Parameters:

node – A Node object.

Raises:

IronicException if rescue_password is missing, or when failed to issue the request, or there was a malformed response from the agent.

Raises:

AgentAPIError when agent failed to execute specified command.

Raises:

AgentInProgress when the command fails to execute as the agent is presently executing the prior command.

Raises:

InstanceRescueFailure when the agent ramdisk is too old to support transmission of the rescue password.

Returns:

A dict containing command response from agent. See get_commands_status() for a command result sample.

get_clean_steps(node, ports)[source]

Get clean steps from agent.

Parameters:
  • node – A node object.

  • ports – Ports associated with the node.

Raises:

IronicException when failed to issue the request or there was a malformed response from the agent.

Raises:

AgentAPIError when agent failed to execute specified command.

Raises:

AgentInProgress when the command fails to execute as the agent is presently executing the prior command.

Returns:

A dict containing command response from agent. See get_commands_status() for a command result sample. The value of key command_result is in the form of:

{
  'clean_steps': <a list of clean steps>,
  'hardware_manager_version': <manager version>
}

get_commands_status(node, retry_connection=True, expect_errors=False)[source]

Get command status from agent.

Parameters:
  • node – A Node object.

  • retry_connection – Whether to retry connection problems.

  • expect_errors – If True, do not log connection problems as errors.

Returns:

A list of command results, each result is related to a command been issued to agent. A typical result can be:

{
  'command_name': <command name related to the result>,
  'command_params': <params related with the command>,
  'command_status': <current command status,
                    e.g. 'RUNNING', 'SUCCEEDED', 'FAILED'>,
  'command_error': <error message if command execution
                   failed>,
  'command_result': <command result if command execution
                    succeeded, the value is command specific,
                    e.g.:
                    * a dictionary containing keys clean_result
                      and clean_step for the command
                      clean.execute_clean_step;
                    * a dictionary containing keys deploy_result
                      and deploy_step for the command
                      deploy.execute_deploy_step;
                    * a string representing result message for
                      the command standby.cache_image;
                    * None for the command standby.sync.>
}

get_deploy_steps(node, ports)[source]

Get deploy steps from agent.

Parameters:
  • node – A node object.

  • ports – Ports associated with the node.

Raises:

IronicException when failed to issue the request or there was a malformed response from the agent.

Raises:

AgentAPIError when agent failed to execute specified command.

Returns:

A dict containing command response from agent. See get_commands_status() for a command result sample. The value of key command_result is in the form of:

{
  'deploy_steps': <a list of deploy steps>,
  'hardware_manager_version': <manager version>
}

get_last_command_status(node, method)[source]

Get the last status for the given command.

Parameters:
  • node – A Node object.

  • method – Command name.

Returns:

A dict containing command status from agent or None if the command was not found.

get_partition_uuids(node)[source]

Get deploy steps from agent.

Parameters:

node – A node object.

Raises:

IronicException when failed to issue the request or there was a malformed response from the agent.

Raises:

AgentAPIError when agent failed to execute specified command.

Raises:

AgentInProgress when the command fails to execute as the agent is presently executing the prior command.

Returns:

A dict containing command response from agent.

get_service_steps(node, ports)[source]

Get service steps from agent.

Parameters:
  • node – A node object.

  • ports – Ports associated with the node.

Raises:

IronicException when failed to issue the request or there was a malformed response from the agent.

Raises:

AgentAPIError when agent failed to execute specified command.

Raises:

AgentInProgress when the command fails to execute as the agent is presently executing the prior command.

Returns:

A dict containing command response from agent. See get_commands_status() for a command result sample. The value of key command_result is in the form of:

{
  'service_steps': <a list of service steps>,
  'hardware_manager_version': <manager version>
}

install_bootloader(node, root_uuid, target_boot_mode, efi_system_part_uuid=None, prep_boot_part_uuid=None, software_raid=False)[source]

Install a boot loader on the image.

Parameters:
  • node – A node object.

  • root_uuid – The UUID of the root partition.

  • target_boot_mode – The target deployment boot mode.

  • efi_system_part_uuid – The UUID of the efi system partition where the bootloader will be installed to, only used for uefi boot mode.

  • prep_boot_part_uuid – The UUID of the PReP Boot partition where the bootloader will be installed to when local booting a partition image on a ppc64* system.

Raises:

IronicException when failed to issue the request or there was a malformed response from the agent.

Raises:

AgentAPIError when agent failed to execute specified command.

Raises:

AgentInProgress when the command fails to execute as the agent is presently executing the prior command.

Returns:

A dict containing command response from agent. See get_commands_status() for a command result sample.

lockdown(node, fail_if_unavailable=True)[source]

Lock down the agent so that it’s not usable any more.

Parameters:
  • node – A Node object.

  • fail_if_unavailable – Whether to fail this call if the agent is already unavailable.

Raises:

IronicException when failed to issue the request or there was a malformed response from the agent.

Raises:

AgentAPIError when agent failed to execute specified command.

Raises:

AgentInProgress when the command fails to execute as the agent is presently executing the prior command.

power_off(node)[source]

Soft powers off the bare metal node by shutting down ramdisk OS.

Parameters:

node – A Node object.

Raises:

IronicException when failed to issue the request or there was a malformed response from the agent.

Raises:

AgentAPIError when agent failed to execute specified command.

Raises:

AgentInProgress when the command fails to execute as the agent is presently executing the prior command.

Returns:

A dict containing command response from agent. See get_commands_status() for a command result sample.

reboot(node)[source]

Soft reboots the bare metal node by shutting down ramdisk OS.

Parameters:

node – A Node object.

Raises:

IronicException when failed to issue the request or there was a malformed response from the agent.

Raises:

AgentAPIError when agent failed to execute specified command.

Raises:

AgentInProgress when the command fails to execute as the agent is presently executing the prior command.

Returns:

A dict containing command response from agent. See get_commands_status() for a command result sample.

sync(node)[source]

Flush file system buffers forcing changed blocks to disk.

Parameters:

node – A Node object.

Raises:

IronicException when failed to issue the request or there was a malformed response from the agent.

Raises:

AgentAPIError when agent failed to execute specified command.

Raises:

AgentInProgress when the command fails to execute as the agent is presently executing the prior command.

Returns:

A dict containing command response from agent. See get_commands_status() for a command result sample.

ironic.drivers.modules.agent_client.get_client(task)[source]

Get client for this node.

ironic.drivers.modules.agent_client.get_command_error(command)[source]

Extract an error string from the command result.

Parameters:

command – Command information from the agent.

Returns:

Error string.