Skip to content

/AWS1/IF_NWF=>UPDATEPROXY()

About UpdateProxy

Updates the properties of the specified proxy.

Method Signature

METHODS /AWS1/IF_NWF~UPDATEPROXY
  IMPORTING
    !IV_NATGATEWAYID TYPE /AWS1/NWFNATGATEWAYID OPTIONAL
    !IV_PROXYNAME TYPE /AWS1/NWFRESOURCENAME OPTIONAL
    !IV_PROXYARN TYPE /AWS1/NWFRESOURCEARN OPTIONAL
    !IT_LISTENERPROPERTIESTOADD TYPE /AWS1/CL_NWFLISTENERPRPREQUEST=>TT_LISTENERPROPERTIESREQUEST OPTIONAL
    !IT_LISTENERPROPSTOREMOVE TYPE /AWS1/CL_NWFLISTENERPRPREQUEST=>TT_LISTENERPROPERTIESREQUEST OPTIONAL
    !IO_TLSINTERCEPTPROPERTIES TYPE REF TO /AWS1/CL_NWFTLSINTERCEPTPRPS00 OPTIONAL
    !IV_UPDATETOKEN TYPE /AWS1/NWFUPDATETOKEN OPTIONAL
  RETURNING
    VALUE(OO_OUTPUT) TYPE REF TO /aws1/cl_nwfupdateproxyrsp
  RAISING
    /AWS1/CX_NWFINTERNALSERVERERR
    /AWS1/CX_NWFINVALIDREQUESTEX
    /AWS1/CX_NWFRESOURCENOTFOUNDEX
    /AWS1/CX_NWFTHROTTLINGEX
    /AWS1/CX_NWFUNSUPPORTEDOPEX
    /AWS1/CX_NWFCLIENTEXC
    /AWS1/CX_NWFSERVEREXC
    /AWS1/CX_RT_TECHNICAL_GENERIC
    /AWS1/CX_RT_SERVICE_GENERIC.

IMPORTING

Required arguments:

iv_natgatewayid TYPE /AWS1/NWFNATGATEWAYID /AWS1/NWFNATGATEWAYID

The NAT Gateway the proxy is attached to.

iv_updatetoken TYPE /AWS1/NWFUPDATETOKEN /AWS1/NWFUPDATETOKEN

A token used for optimistic locking. Network Firewall returns a token to your requests that access the proxy. The token marks the state of the proxy resource at the time of the request.

To make changes to the proxy, you provide the token in your request. Network Firewall uses the token to ensure that the proxy hasn't changed since you last retrieved it. If it has changed, the operation fails with an InvalidTokenException. If this happens, retrieve the proxy again to get a current copy of it with a current token. Reapply your changes as needed, then try the operation again using the new token.

Optional arguments:

iv_proxyname TYPE /AWS1/NWFRESOURCENAME /AWS1/NWFRESOURCENAME

The descriptive name of the proxy. You can't change the name of a proxy after you create it.

You must specify the ARN or the name, and you can specify both.

iv_proxyarn TYPE /AWS1/NWFRESOURCEARN /AWS1/NWFRESOURCEARN

The Amazon Resource Name (ARN) of a proxy.

You must specify the ARN or the name, and you can specify both.

it_listenerpropertiestoadd TYPE /AWS1/CL_NWFLISTENERPRPREQUEST=>TT_LISTENERPROPERTIESREQUEST TT_LISTENERPROPERTIESREQUEST

Listener properties for HTTP and HTTPS traffic to add.

it_listenerpropstoremove TYPE /AWS1/CL_NWFLISTENERPRPREQUEST=>TT_LISTENERPROPERTIESREQUEST TT_LISTENERPROPERTIESREQUEST

Listener properties for HTTP and HTTPS traffic to remove.

io_tlsinterceptproperties TYPE REF TO /AWS1/CL_NWFTLSINTERCEPTPRPS00 /AWS1/CL_NWFTLSINTERCEPTPRPS00

TLS decryption on traffic to filter on attributes in the HTTP header.

RETURNING

oo_output TYPE REF TO /aws1/cl_nwfupdateproxyrsp /AWS1/CL_NWFUPDATEPROXYRSP

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->updateproxy(
  io_tlsinterceptproperties = new /aws1/cl_nwftlsinterceptprps00(
    iv_pcaarn = |string|
    iv_tlsinterceptmode = |string|
  )
  it_listenerpropertiestoadd = VALUE /aws1/cl_nwflistenerprprequest=>tt_listenerpropertiesrequest(
    (
      new /aws1/cl_nwflistenerprprequest(
        iv_port = 123
        iv_type = |string|
      )
    )
  )
  it_listenerpropstoremove = VALUE /aws1/cl_nwflistenerprprequest=>tt_listenerpropertiesrequest(
    (
      new /aws1/cl_nwflistenerprprequest(
        iv_port = 123
        iv_type = |string|
      )
    )
  )
  iv_natgatewayid = |string|
  iv_proxyarn = |string|
  iv_proxyname = |string|
  iv_updatetoken = |string|
).

This is an example of reading all possible response values

lo_result = lo_result.
IF lo_result IS NOT INITIAL.
  lo_proxy = lo_result->get_proxy( ).
  IF lo_proxy IS NOT INITIAL.
    lv_createtime = lo_proxy->get_createtime( ).
    lv_deletetime = lo_proxy->get_deletetime( ).
    lv_updatetime = lo_proxy->get_updatetime( ).
    lv_failurecode = lo_proxy->get_failurecode( ).
    lv_failuremessage = lo_proxy->get_failuremessage( ).
    lv_proxystate = lo_proxy->get_proxystate( ).
    lv_proxymodifystate = lo_proxy->get_proxymodifystate( ).
    lv_natgatewayid = lo_proxy->get_natgatewayid( ).
    lv_resourcename = lo_proxy->get_proxyconfigurationname( ).
    lv_resourcearn = lo_proxy->get_proxyconfigurationarn( ).
    lv_resourcename = lo_proxy->get_proxyname( ).
    lv_resourcearn = lo_proxy->get_proxyarn( ).
    LOOP AT lo_proxy->get_listenerproperties( ) into lo_row.
      lo_row_1 = lo_row.
      IF lo_row_1 IS NOT INITIAL.
        lv_natgatewayport = lo_row_1->get_port( ).
        lv_listenerpropertytype = lo_row_1->get_type( ).
      ENDIF.
    ENDLOOP.
    lo_tlsinterceptproperties = lo_proxy->get_tlsinterceptproperties( ).
    IF lo_tlsinterceptproperties IS NOT INITIAL.
      lv_resourcearn = lo_tlsinterceptproperties->get_pcaarn( ).
      lv_tlsinterceptmode = lo_tlsinterceptproperties->get_tlsinterceptmode( ).
    ENDIF.
    LOOP AT lo_proxy->get_tags( ) into lo_row_2.
      lo_row_3 = lo_row_2.
      IF lo_row_3 IS NOT INITIAL.
        lv_tagkey = lo_row_3->get_key( ).
        lv_tagvalue = lo_row_3->get_value( ).
      ENDIF.
    ENDLOOP.
  ENDIF.
  lv_updatetoken = lo_result->get_updatetoken( ).
ENDIF.