Skip to content

/AWS1/CL_MHU=>PUTRESOURCEATTRIBUTES()

About PutResourceAttributes

Provides identifying details of the resource being migrated so that it can be associated in the Application Discovery Service repository. This association occurs asynchronously after PutResourceAttributes returns.

  • Keep in mind that subsequent calls to PutResourceAttributes will override previously stored attributes. For example, if it is first called with a MAC address, but later, it is desired to add an IP address, it will then be required to call it with both the IP and MAC addresses to prevent overriding the MAC address.

  • Note the instructions regarding the special use case of the ResourceAttributeList parameter when specifying any "VM" related value.

Because this is an asynchronous call, it will always return 200, whether an association occurs or not. To confirm if an association was found based on the provided details, call ListDiscoveredResources.

Method Signature

IMPORTING

Required arguments:

iv_progressupdatestream TYPE /AWS1/MHUPROGRESSUPDATESTREAM /AWS1/MHUPROGRESSUPDATESTREAM

The name of the ProgressUpdateStream.

iv_migrationtaskname TYPE /AWS1/MHUMIGRATIONTASKNAME /AWS1/MHUMIGRATIONTASKNAME

Unique identifier that references the migration task. Do not store personal data in this field.

it_resourceattributelist TYPE /AWS1/CL_MHURESOURCEATTRIBUTE=>TT_RESOURCEATTRIBUTELIST TT_RESOURCEATTRIBUTELIST

Information about the resource that is being migrated. This data will be used to map the task to a resource in the Application Discovery Service repository.

Takes the object array of ResourceAttribute where the Type field is reserved for the following values: IPV4_ADDRESS | IPV6_ADDRESS | MAC_ADDRESS | FQDN | VM_MANAGER_ID | VM_MANAGED_OBJECT_REFERENCE | VM_NAME | VM_PATH | BIOS_ID | MOTHERBOARD_SERIAL_NUMBER where the identifying value can be a string up to 256 characters.

  • If any "VM" related value is set for a ResourceAttribute object, it is required that VM_MANAGER_ID, as a minimum, is always set. If VM_MANAGER_ID is not set, then all "VM" fields will be discarded and "VM" fields will not be used for matching the migration task to a server in Application Discovery Service repository. See the Example section below for a use case of specifying "VM" related values.

  • If a server you are trying to match has multiple IP or MAC addresses, you should provide as many as you know in separate type/value pairs passed to the ResourceAttributeList parameter to maximize the chances of matching.

Optional arguments:

iv_dryrun TYPE /AWS1/MHUDRYRUN /AWS1/MHUDRYRUN

Optional boolean flag to indicate whether any effect should take place. Used to test if the caller has permission to make the call.

RETURNING

oo_output TYPE REF TO /aws1/cl_mhuputresrcattrsrslt /AWS1/CL_MHUPUTRESRCATTRSRSLT

Domain /AWS1/RT_ACCOUNT_ID
Primitive Type NUMC

Examples

Syntax Example

This is an example of the syntax for calling the method. It includes every possible argument and initializes every possible value. The data provided is not necessarily semantically accurate (for example the value "string" may be provided for something that is intended to be an instance ID, or in some cases two arguments may be mutually exclusive). The syntax shows the ABAP syntax for creating the various data structures.

DATA(lo_result) = lo_client->/aws1/if_mhu~putresourceattributes(
  it_resourceattributelist = VALUE /aws1/cl_mhuresourceattribute=>tt_resourceattributelist(
    (
      new /aws1/cl_mhuresourceattribute(
        iv_type = |string|
        iv_value = |string|
      )
    )
  )
  iv_dryrun = ABAP_TRUE
  iv_migrationtaskname = |string|
  iv_progressupdatestream = |string|
).

This is an example of reading all possible response values

lo_result = lo_result.
IF lo_result IS NOT INITIAL.
ENDIF.