Skip to content

/AWS1/IF_NWF=>CREATEPROXY()

About CreateProxy

Creates an Network Firewall Proxy

Attaches a Proxy configuration to a NAT Gateway.

To manage a proxy's tags, use the standard Amazon Web Services resource tagging operations, ListTagsForResource, TagResource, and UntagResource.

To retrieve information about proxies, use ListProxies and DescribeProxy.

Method Signature

METHODS /AWS1/IF_NWF~CREATEPROXY
  IMPORTING
    !IV_PROXYNAME TYPE /AWS1/NWFRESOURCENAME OPTIONAL
    !IV_NATGATEWAYID TYPE /AWS1/NWFNATGATEWAYID OPTIONAL
    !IV_PROXYCONFIGURATIONNAME TYPE /AWS1/NWFRESOURCENAME OPTIONAL
    !IV_PROXYCONFIGURATIONARN TYPE /AWS1/NWFRESOURCEARN OPTIONAL
    !IT_LISTENERPROPERTIES TYPE /AWS1/CL_NWFLISTENERPRPREQUEST=>TT_LISTENERPROPERTIESREQUEST OPTIONAL
    !IO_TLSINTERCEPTPROPERTIES TYPE REF TO /AWS1/CL_NWFTLSINTERCEPTPRPS00 OPTIONAL
    !IT_TAGS TYPE /AWS1/CL_NWFTAG=>TT_TAGLIST OPTIONAL
  RETURNING
    VALUE(OO_OUTPUT) TYPE REF TO /aws1/cl_nwfcreateproxyrsp
  RAISING
    /AWS1/CX_NWFINTERNALSERVERERR
    /AWS1/CX_NWFINVALIDREQUESTEX
    /AWS1/CX_NWFLIMITEXCEEDEDEX
    /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_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.

iv_natgatewayid TYPE /AWS1/NWFNATGATEWAYID /AWS1/NWFNATGATEWAYID

A unique identifier for the NAT gateway to use with proxy resources.

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

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

Optional arguments:

iv_proxyconfigurationname TYPE /AWS1/NWFRESOURCENAME /AWS1/NWFRESOURCENAME

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

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

iv_proxyconfigurationarn TYPE /AWS1/NWFRESOURCEARN /AWS1/NWFRESOURCEARN

The Amazon Resource Name (ARN) of a proxy configuration.

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

it_listenerproperties TYPE /AWS1/CL_NWFLISTENERPRPREQUEST=>TT_LISTENERPROPERTIESREQUEST TT_LISTENERPROPERTIESREQUEST

Listener properties for HTTP and HTTPS traffic.

it_tags TYPE /AWS1/CL_NWFTAG=>TT_TAGLIST TT_TAGLIST

The key:value pairs to associate with the resource.

RETURNING

oo_output TYPE REF TO /aws1/cl_nwfcreateproxyrsp /AWS1/CL_NWFCREATEPROXYRSP

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->createproxy(
  io_tlsinterceptproperties = new /aws1/cl_nwftlsinterceptprps00(
    iv_pcaarn = |string|
    iv_tlsinterceptmode = |string|
  )
  it_listenerproperties = VALUE /aws1/cl_nwflistenerprprequest=>tt_listenerpropertiesrequest(
    (
      new /aws1/cl_nwflistenerprprequest(
        iv_port = 123
        iv_type = |string|
      )
    )
  )
  it_tags = VALUE /aws1/cl_nwftag=>tt_taglist(
    (
      new /aws1/cl_nwftag(
        iv_key = |string|
        iv_value = |string|
      )
    )
  )
  iv_natgatewayid = |string|
  iv_proxyconfigurationarn = |string|
  iv_proxyconfigurationname = |string|
  iv_proxyname = |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.