Skip to content

/AWS1/IF_WAD=>UPDATEWORKLOAD()

About UpdateWorkload

Update an existing workload.

Method Signature

METHODS /AWS1/IF_WAD~UPDATEWORKLOAD
  IMPORTING
    !IV_WORKLOADID TYPE /AWS1/WADWORKLOADID OPTIONAL
    !IV_WORKLOADNAME TYPE /AWS1/WADWORKLOADNAME OPTIONAL
    !IV_DESCRIPTION TYPE /AWS1/WADWORKLOADDESCRIPTION OPTIONAL
    !IV_ENVIRONMENT TYPE /AWS1/WADWORKLOADENVIRONMENT OPTIONAL
    !IT_ACCOUNTIDS TYPE /AWS1/CL_WADWORKLOADACCTIDS_W=>TT_WORKLOADACCOUNTIDS OPTIONAL
    !IT_AWSREGIONS TYPE /AWS1/CL_WADWORKLOADAWSREGIO00=>TT_WORKLOADAWSREGIONS OPTIONAL
    !IT_NONAWSREGIONS TYPE /AWS1/CL_WADWORKLOADNONAWSRE00=>TT_WORKLOADNONAWSREGIONS OPTIONAL
    !IT_PILLARPRIORITIES TYPE /AWS1/CL_WADWORKLOADPILLARPR00=>TT_WORKLOADPILLARPRIORITIES OPTIONAL
    !IV_ARCHITECTURALDESIGN TYPE /AWS1/WADWORKLOADARCHITECTUR00 OPTIONAL
    !IV_REVIEWOWNER TYPE /AWS1/WADWORKLOADREVIEWOWNER OPTIONAL
    !IV_ISREVIEWOWNERUPDACKNOWL00 TYPE /AWS1/WADISREVIEWOWNERUPACKN00 OPTIONAL
    !IV_INDUSTRYTYPE TYPE /AWS1/WADWORKLOADINDUSTRYTYPE OPTIONAL
    !IV_INDUSTRY TYPE /AWS1/WADWORKLOADINDUSTRY OPTIONAL
    !IV_NOTES TYPE /AWS1/WADNOTES OPTIONAL
    !IV_IMPROVEMENTSTATUS TYPE /AWS1/WADWORKLOADIMPROVEMENT00 OPTIONAL
    !IO_DISCOVERYCONFIG TYPE REF TO /AWS1/CL_WADWORKLOADDISCOVER00 OPTIONAL
    !IT_APPLICATIONS TYPE /AWS1/CL_WADWORKLOADAPPLICAT00=>TT_WORKLOADAPPLICATIONS OPTIONAL
    !IO_JIRACONFIGURATION TYPE REF TO /AWS1/CL_WADWORKLOADJIRACONF00 OPTIONAL
  RETURNING
    VALUE(OO_OUTPUT) TYPE REF TO /aws1/cl_wadupdworkloadoutput
  RAISING
    /AWS1/CX_WADACCESSDENIEDEX
    /AWS1/CX_WADCONFLICTEXCEPTION
    /AWS1/CX_WADINTERNALSERVEREX
    /AWS1/CX_WADRESOURCENOTFOUNDEX
    /AWS1/CX_WADTHROTTLINGEX
    /AWS1/CX_WADVALIDATIONEX
    /AWS1/CX_WADCLIENTEXC
    /AWS1/CX_WADSERVEREXC
    /AWS1/CX_RT_TECHNICAL_GENERIC
    /AWS1/CX_RT_SERVICE_GENERIC.

IMPORTING

Required arguments:

iv_workloadid TYPE /AWS1/WADWORKLOADID /AWS1/WADWORKLOADID

The ID assigned to the workload. This ID is unique within an Amazon Web Services Region.

Optional arguments:

iv_workloadname TYPE /AWS1/WADWORKLOADNAME /AWS1/WADWORKLOADNAME

The name of the workload.

The name must be unique within an account within an Amazon Web Services Region. Spaces and capitalization are ignored when checking for uniqueness.

iv_description TYPE /AWS1/WADWORKLOADDESCRIPTION /AWS1/WADWORKLOADDESCRIPTION

The description for the workload.

iv_environment TYPE /AWS1/WADWORKLOADENVIRONMENT /AWS1/WADWORKLOADENVIRONMENT

The environment for the workload.

it_accountids TYPE /AWS1/CL_WADWORKLOADACCTIDS_W=>TT_WORKLOADACCOUNTIDS TT_WORKLOADACCOUNTIDS

The list of Amazon Web Services account IDs associated with the workload.

it_awsregions TYPE /AWS1/CL_WADWORKLOADAWSREGIO00=>TT_WORKLOADAWSREGIONS TT_WORKLOADAWSREGIONS

The list of Amazon Web Services Regions associated with the workload, for example, us-east-2, or ca-central-1.

it_nonawsregions TYPE /AWS1/CL_WADWORKLOADNONAWSRE00=>TT_WORKLOADNONAWSREGIONS TT_WORKLOADNONAWSREGIONS

The list of non-Amazon Web Services Regions associated with the workload.

it_pillarpriorities TYPE /AWS1/CL_WADWORKLOADPILLARPR00=>TT_WORKLOADPILLARPRIORITIES TT_WORKLOADPILLARPRIORITIES

The priorities of the pillars, which are used to order items in the improvement plan. Each pillar is represented by its PillarReviewSummary$PillarId.

iv_architecturaldesign TYPE /AWS1/WADWORKLOADARCHITECTUR00 /AWS1/WADWORKLOADARCHITECTUR00

The URL of the architectural design for the workload.

iv_reviewowner TYPE /AWS1/WADWORKLOADREVIEWOWNER /AWS1/WADWORKLOADREVIEWOWNER

The review owner of the workload. The name, email address, or identifier for the primary group or individual that owns the workload review process.

iv_isreviewownerupdacknowl00 TYPE /AWS1/WADISREVIEWOWNERUPACKN00 /AWS1/WADISREVIEWOWNERUPACKN00

Flag indicating whether the workload owner has acknowledged that the Review owner field is required.

If a Review owner is not added to the workload within 60 days of acknowledgement, access to the workload is restricted until an owner is added.

iv_industrytype TYPE /AWS1/WADWORKLOADINDUSTRYTYPE /AWS1/WADWORKLOADINDUSTRYTYPE

The industry type for the workload.

If specified, must be one of the following:

  • Agriculture

  • Automobile

  • Defense

  • Design and Engineering

  • Digital Advertising

  • Education

  • Environmental Protection

  • Financial Services

  • Gaming

  • General Public Services

  • Healthcare

  • Hospitality

  • InfoTech

  • Justice and Public Safety

  • Life Sciences

  • Manufacturing

  • Media & Entertainment

  • Mining & Resources

  • Oil & Gas

  • Power & Utilities

  • Professional Services

  • Real Estate & Construction

  • Retail & Wholesale

  • Social Protection

  • Telecommunications

  • Travel, Transportation & Logistics

  • Other

iv_industry TYPE /AWS1/WADWORKLOADINDUSTRY /AWS1/WADWORKLOADINDUSTRY

The industry for the workload.

iv_notes TYPE /AWS1/WADNOTES /AWS1/WADNOTES

The notes associated with the workload.

For a review template, these are the notes that will be associated with the workload when the template is applied.

iv_improvementstatus TYPE /AWS1/WADWORKLOADIMPROVEMENT00 /AWS1/WADWORKLOADIMPROVEMENT00

The improvement status for a workload.

io_discoveryconfig TYPE REF TO /AWS1/CL_WADWORKLOADDISCOVER00 /AWS1/CL_WADWORKLOADDISCOVER00

Well-Architected discovery configuration settings to associate to the workload.

it_applications TYPE /AWS1/CL_WADWORKLOADAPPLICAT00=>TT_WORKLOADAPPLICATIONS TT_WORKLOADAPPLICATIONS

List of AppRegistry application ARNs to associate to the workload.

io_jiraconfiguration TYPE REF TO /AWS1/CL_WADWORKLOADJIRACONF00 /AWS1/CL_WADWORKLOADJIRACONF00

Configuration of the Jira integration.

RETURNING

oo_output TYPE REF TO /aws1/cl_wadupdworkloadoutput /AWS1/CL_WADUPDWORKLOADOUTPUT

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->updateworkload(
  io_discoveryconfig = new /aws1/cl_wadworkloaddiscover00(
    it_workloadresourcedefn = VALUE /aws1/cl_wadworkloadresrcdef_w=>tt_workloadresourcedefinition(
      ( new /aws1/cl_wadworkloadresrcdef_w( |string| ) )
    )
    iv_trustedadvisorintegrati00 = |string|
  )
  io_jiraconfiguration = new /aws1/cl_wadworkloadjiraconf00(
    iv_issuemanagementstatus = |string|
    iv_issuemanagementtype = |string|
    iv_jiraprojectkey = |string|
  )
  it_accountids = VALUE /aws1/cl_wadworkloadacctids_w=>tt_workloadaccountids(
    ( new /aws1/cl_wadworkloadacctids_w( |string| ) )
  )
  it_applications = VALUE /aws1/cl_wadworkloadapplicat00=>tt_workloadapplications(
    ( new /aws1/cl_wadworkloadapplicat00( |string| ) )
  )
  it_awsregions = VALUE /aws1/cl_wadworkloadawsregio00=>tt_workloadawsregions(
    ( new /aws1/cl_wadworkloadawsregio00( |string| ) )
  )
  it_nonawsregions = VALUE /aws1/cl_wadworkloadnonawsre00=>tt_workloadnonawsregions(
    ( new /aws1/cl_wadworkloadnonawsre00( |string| ) )
  )
  it_pillarpriorities = VALUE /aws1/cl_wadworkloadpillarpr00=>tt_workloadpillarpriorities(
    ( new /aws1/cl_wadworkloadpillarpr00( |string| ) )
  )
  iv_architecturaldesign = |string|
  iv_description = |string|
  iv_environment = |string|
  iv_improvementstatus = |string|
  iv_industry = |string|
  iv_industrytype = |string|
  iv_isreviewownerupdacknowl00 = ABAP_TRUE
  iv_notes = |string|
  iv_reviewowner = |string|
  iv_workloadid = |string|
  iv_workloadname = |string|
).

This is an example of reading all possible response values

lo_result = lo_result.
IF lo_result IS NOT INITIAL.
  lo_workload = lo_result->get_workload( ).
  IF lo_workload IS NOT INITIAL.
    lv_workloadid = lo_workload->get_workloadid( ).
    lv_workloadarn = lo_workload->get_workloadarn( ).
    lv_workloadname = lo_workload->get_workloadname( ).
    lv_workloaddescription = lo_workload->get_description( ).
    lv_workloadenvironment = lo_workload->get_environment( ).
    lv_timestamp = lo_workload->get_updatedat( ).
    LOOP AT lo_workload->get_accountids( ) into lo_row.
      lo_row_1 = lo_row.
      IF lo_row_1 IS NOT INITIAL.
        lv_awsaccountid = lo_row_1->get_value( ).
      ENDIF.
    ENDLOOP.
    LOOP AT lo_workload->get_awsregions( ) into lo_row_2.
      lo_row_3 = lo_row_2.
      IF lo_row_3 IS NOT INITIAL.
        lv_awsregion = lo_row_3->get_value( ).
      ENDIF.
    ENDLOOP.
    LOOP AT lo_workload->get_nonawsregions( ) into lo_row_4.
      lo_row_5 = lo_row_4.
      IF lo_row_5 IS NOT INITIAL.
        lv_workloadnonawsregion = lo_row_5->get_value( ).
      ENDIF.
    ENDLOOP.
    lv_workloadarchitecturalde = lo_workload->get_architecturaldesign( ).
    lv_workloadreviewowner = lo_workload->get_reviewowner( ).
    lv_timestamp = lo_workload->get_reviewrestrictiondate( ).
    lv_isreviewownerupdateackn = lo_workload->get_isreviewownerupdacknow00( ).
    lv_workloadindustrytype = lo_workload->get_industrytype( ).
    lv_workloadindustry = lo_workload->get_industry( ).
    lv_notes = lo_workload->get_notes( ).
    lv_workloadimprovementstat = lo_workload->get_improvementstatus( ).
    LOOP AT lo_workload->get_riskcounts( ) into ls_row_6.
      lv_key = ls_row_6-key.
      lo_value = ls_row_6-value.
      IF lo_value IS NOT INITIAL.
        lv_count = lo_value->get_value( ).
      ENDIF.
    ENDLOOP.
    LOOP AT lo_workload->get_pillarpriorities( ) into lo_row_7.
      lo_row_8 = lo_row_7.
      IF lo_row_8 IS NOT INITIAL.
        lv_pillarid = lo_row_8->get_value( ).
      ENDIF.
    ENDLOOP.
    LOOP AT lo_workload->get_lenses( ) into lo_row_9.
      lo_row_10 = lo_row_9.
      IF lo_row_10 IS NOT INITIAL.
        lv_lensalias = lo_row_10->get_value( ).
      ENDIF.
    ENDLOOP.
    lv_awsaccountid = lo_workload->get_owner( ).
    lv_shareinvitationid = lo_workload->get_shareinvitationid( ).
    LOOP AT lo_workload->get_tags( ) into ls_row_11.
      lv_key_1 = ls_row_11-key.
      lo_value_1 = ls_row_11-value.
      IF lo_value_1 IS NOT INITIAL.
        lv_tagvalue = lo_value_1->get_value( ).
      ENDIF.
    ENDLOOP.
    lo_workloaddiscoveryconfig = lo_workload->get_discoveryconfig( ).
    IF lo_workloaddiscoveryconfig IS NOT INITIAL.
      lv_trustedadvisorintegrati = lo_workloaddiscoveryconfig->get_trustedadvisorintegrat00( ).
      LOOP AT lo_workloaddiscoveryconfig->get_workloadresourcedefn( ) into lo_row_12.
        lo_row_13 = lo_row_12.
        IF lo_row_13 IS NOT INITIAL.
          lv_definitiontype = lo_row_13->get_value( ).
        ENDIF.
      ENDLOOP.
    ENDIF.
    LOOP AT lo_workload->get_applications( ) into lo_row_14.
      lo_row_15 = lo_row_14.
      IF lo_row_15 IS NOT INITIAL.
        lv_applicationarn = lo_row_15->get_value( ).
      ENDIF.
    ENDLOOP.
    LOOP AT lo_workload->get_profiles( ) into lo_row_16.
      lo_row_17 = lo_row_16.
      IF lo_row_17 IS NOT INITIAL.
        lv_profilearn = lo_row_17->get_profilearn( ).
        lv_profileversion = lo_row_17->get_profileversion( ).
      ENDIF.
    ENDLOOP.
    LOOP AT lo_workload->get_prioritizedriskcounts( ) into ls_row_6.
      lv_key = ls_row_6-key.
      lo_value = ls_row_6-value.
      IF lo_value IS NOT INITIAL.
        lv_count = lo_value->get_value( ).
      ENDIF.
    ENDLOOP.
    lo_workloadjiraconfigurati = lo_workload->get_jiraconfiguration( ).
    IF lo_workloadjiraconfigurati IS NOT INITIAL.
      lv_workloadissuemanagement = lo_workloadjiraconfigurati->get_issuemanagementstatus( ).
      lv_issuemanagementtype = lo_workloadjiraconfigurati->get_issuemanagementtype( ).
      lv_jiraprojectkey = lo_workloadjiraconfigurati->get_jiraprojectkey( ).
      lv_statusmessage = lo_workloadjiraconfigurati->get_statusmessage( ).
    ENDIF.
  ENDIF.
ENDIF.