ironic.dhcp.base module

Abstract base class for dhcp providers.

class ironic.dhcp.base.BaseDHCP[source]

Bases: object

Base class for DHCP provider APIs.

clean_dhcp_opts(task)[source]

Clean up the DHCP BOOT options for all ports in task.

Parameters:

task – A TaskManager instance.

Raises:

FailedToCleanDHCPOpts

get_ip_addresses(task)[source]

Get IP addresses for all ports/portgroups in task.

Parameters:

task – A TaskManager instance.

Returns:

List of IP addresses associated with task’s ports and portgroups.

supports_ipxe_tag()[source]

Whether the provider will correctly apply the ‘ipxe’ tag.

When iPXE makes a DHCP request, does this provider support adding the tag ipxe or ipxe6 (for IPv6). When the provider returns True, options can be added which filter on these tags.

Returns:

True when the driver supports tagging iPXE DHCP requests

abstract update_dhcp_opts(task, options, vifs=None)[source]

Send or update the DHCP BOOT options for this node.

Parameters:
  • task – A TaskManager instance.

  • options

    this will be a list of dicts, e.g.

    [{'opt_name': '67',
      'opt_value': 'pxelinux.0',
      'ip_version': 4},
     {'opt_name': '66',
      'opt_value': '123.123.123.456',
      'ip_version': 4}]
    

  • vifs

    A dict with keys ‘ports’ and ‘portgroups’ and dicts as values. Each dict has key/value pairs of the form <ironic UUID>:<neutron port UUID>. e.g.

    {'ports': {'port.uuid': vif.id},
     'portgroups': {'portgroup.uuid': vif.id}}
    

    If the value is None, will get the list of ports/portgroups from the Ironic port/portgroup objects.

Raises:

FailedToUpdateDHCPOptOnPort

abstract update_port_dhcp_opts(port_id, dhcp_options, token=None, context=None)[source]

Update one or more DHCP options on the specified port.

Parameters:
  • port_id – designate which port these attributes will be applied to.

  • dhcp_options

    this will be a list of dicts, e.g.

    [{'opt_name': '67',
      'opt_value': 'pxelinux.0',
      'ip_version': 4},
     {'opt_name': '66',
      'opt_value': '123.123.123.456',
      'ip_version': 4}]
    

  • token – An optional authentication token. Deprecated, use context

  • context (ironic.common.context.RequestContext) – request context

Raises:

FailedToUpdateDHCPOptOnPort