/AWS1/IF_DZN=>CREATEDATASOURCE()¶
About CreateDataSource¶
Creates an Amazon DataZone data source.
Method Signature¶
METHODS /AWS1/IF_DZN~CREATEDATASOURCE
IMPORTING
!IV_NAME TYPE /AWS1/DZNNAME OPTIONAL
!IV_DESCRIPTION TYPE /AWS1/DZNDESCRIPTION OPTIONAL
!IV_DOMAINIDENTIFIER TYPE /AWS1/DZNDOMAINID OPTIONAL
!IV_PROJECTIDENTIFIER TYPE /AWS1/DZNSTRING OPTIONAL
!IV_ENVIRONMENTIDENTIFIER TYPE /AWS1/DZNSTRING OPTIONAL
!IV_CONNECTIONIDENTIFIER TYPE /AWS1/DZNSTRING OPTIONAL
!IV_TYPE TYPE /AWS1/DZNDATASOURCETYPE OPTIONAL
!IO_CONFIGURATION TYPE REF TO /AWS1/CL_DZNDATASRCCONFINPUT OPTIONAL
!IO_RECOMMENDATION TYPE REF TO /AWS1/CL_DZNRECOMMENDATIONCONF OPTIONAL
!IV_ENABLESETTING TYPE /AWS1/DZNENABLESETTING OPTIONAL
!IO_SCHEDULE TYPE REF TO /AWS1/CL_DZNSCHEDULECONF OPTIONAL
!IV_PUBLISHONIMPORT TYPE /AWS1/DZNBOOLEAN OPTIONAL
!IT_ASSETFORMSINPUT TYPE /AWS1/CL_DZNFORMINPUT=>TT_FORMINPUTLIST OPTIONAL
!IV_CLIENTTOKEN TYPE /AWS1/DZNSTRING OPTIONAL
RETURNING
VALUE(OO_OUTPUT) TYPE REF TO /aws1/cl_dzncreatedatasrcout
RAISING
/AWS1/CX_DZNACCESSDENIEDEX
/AWS1/CX_DZNTHROTTLINGEX
/AWS1/CX_DZNUNAUTHORIZEDEX
/AWS1/CX_DZNCONFLICTEXCEPTION
/AWS1/CX_DZNINTERNALSERVEREX
/AWS1/CX_DZNRESOURCENOTFOUNDEX
/AWS1/CX_DZNSERVICEQUOTAEXCDEX
/AWS1/CX_DZNVALIDATIONEX
/AWS1/CX_DZNCLIENTEXC
/AWS1/CX_DZNSERVEREXC
/AWS1/CX_RT_TECHNICAL_GENERIC
/AWS1/CX_RT_SERVICE_GENERIC.
IMPORTING¶
Required arguments:¶
iv_name TYPE /AWS1/DZNNAME /AWS1/DZNNAME¶
The name of the data source.
iv_domainidentifier TYPE /AWS1/DZNDOMAINID /AWS1/DZNDOMAINID¶
The ID of the Amazon DataZone domain where the data source is created.
iv_projectidentifier TYPE /AWS1/DZNSTRING /AWS1/DZNSTRING¶
The identifier of the Amazon DataZone project in which you want to add this data source.
iv_type TYPE /AWS1/DZNDATASOURCETYPE /AWS1/DZNDATASOURCETYPE¶
The type of the data source. In Amazon DataZone, you can use data sources to import technical metadata of assets (data) from the source databases or data warehouses into Amazon DataZone. In the current release of Amazon DataZone, you can create and run data sources for Amazon Web Services Glue and Amazon Redshift.
Optional arguments:¶
iv_description TYPE /AWS1/DZNDESCRIPTION /AWS1/DZNDESCRIPTION¶
The description of the data source.
iv_environmentidentifier TYPE /AWS1/DZNSTRING /AWS1/DZNSTRING¶
The unique identifier of the Amazon DataZone environment to which the data source publishes assets.
iv_connectionidentifier TYPE /AWS1/DZNSTRING /AWS1/DZNSTRING¶
The ID of the connection.
io_configuration TYPE REF TO /AWS1/CL_DZNDATASRCCONFINPUT /AWS1/CL_DZNDATASRCCONFINPUT¶
Specifies the configuration of the data source. It can be set to either
glueRunConfigurationorredshiftRunConfiguration.
io_recommendation TYPE REF TO /AWS1/CL_DZNRECOMMENDATIONCONF /AWS1/CL_DZNRECOMMENDATIONCONF¶
Specifies whether the business name generation is to be enabled for this data source.
iv_enablesetting TYPE /AWS1/DZNENABLESETTING /AWS1/DZNENABLESETTING¶
Specifies whether the data source is enabled.
io_schedule TYPE REF TO /AWS1/CL_DZNSCHEDULECONF /AWS1/CL_DZNSCHEDULECONF¶
The schedule of the data source runs.
iv_publishonimport TYPE /AWS1/DZNBOOLEAN /AWS1/DZNBOOLEAN¶
Specifies whether the assets that this data source creates in the inventory are to be also automatically published to the catalog.
it_assetformsinput TYPE /AWS1/CL_DZNFORMINPUT=>TT_FORMINPUTLIST TT_FORMINPUTLIST¶
The metadata forms that are to be attached to the assets that this data source works with.
iv_clienttoken TYPE /AWS1/DZNSTRING /AWS1/DZNSTRING¶
A unique, case-sensitive identifier that is provided to ensure the idempotency of the request.
RETURNING¶
oo_output TYPE REF TO /aws1/cl_dzncreatedatasrcout /AWS1/CL_DZNCREATEDATASRCOUT¶
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->createdatasource(
io_configuration = new /aws1/cl_dzndatasrcconfinput(
io_gluerunconfiguration = new /aws1/cl_dzngluerunconfinput(
it_relationalfilterconfs = VALUE /aws1/cl_dznrelationalfiltconf=>tt_relationalfilterconfs(
(
new /aws1/cl_dznrelationalfiltconf(
it_filterexpressions = VALUE /aws1/cl_dznfilterexpression=>tt_filterexpressions(
(
new /aws1/cl_dznfilterexpression(
iv_expression = |string|
iv_type = |string|
)
)
)
iv_databasename = |string|
iv_schemaname = |string|
)
)
)
iv_autoimportdataqualityrslt = ABAP_TRUE
iv_catalogname = |string|
iv_dataaccessrole = |string|
)
io_redshiftrunconfiguration = new /aws1/cl_dznredrunconfinput(
io_redshiftcredentialconf = new /aws1/cl_dznredshiftcredconf( |string| )
io_redshiftstorage = new /aws1/cl_dznredshiftstorage(
io_redshiftclustersource = new /aws1/cl_dznredclusterstorage( |string| )
io_redshiftserverlesssource = new /aws1/cl_dznredserverlessstrg( |string| )
)
it_relationalfilterconfs = VALUE /aws1/cl_dznrelationalfiltconf=>tt_relationalfilterconfs(
(
new /aws1/cl_dznrelationalfiltconf(
it_filterexpressions = VALUE /aws1/cl_dznfilterexpression=>tt_filterexpressions(
(
new /aws1/cl_dznfilterexpression(
iv_expression = |string|
iv_type = |string|
)
)
)
iv_databasename = |string|
iv_schemaname = |string|
)
)
)
iv_dataaccessrole = |string|
)
io_sagemakerrunconfiguration = new /aws1/cl_dznsmrunconfinput(
it_trackingassets = VALUE /aws1/cl_dzntrkassetarns_w=>tt_trackingassets(
(
VALUE /aws1/cl_dzntrkassetarns_w=>ts_trackingassets_maprow(
value = VALUE /aws1/cl_dzntrkassetarns_w=>tt_trackingassetarns(
( new /aws1/cl_dzntrkassetarns_w( |string| ) )
)
key = |string|
)
)
)
)
)
io_recommendation = new /aws1/cl_dznrecommendationconf( ABAP_TRUE )
io_schedule = new /aws1/cl_dznscheduleconf(
iv_schedule = |string|
iv_timezone = |string|
)
it_assetformsinput = VALUE /aws1/cl_dznforminput=>tt_forminputlist(
(
new /aws1/cl_dznforminput(
iv_content = |string|
iv_formname = |string|
iv_typeidentifier = |string|
iv_typerevision = |string|
)
)
)
iv_clienttoken = |string|
iv_connectionidentifier = |string|
iv_description = |string|
iv_domainidentifier = |string|
iv_enablesetting = |string|
iv_environmentidentifier = |string|
iv_name = |string|
iv_projectidentifier = |string|
iv_publishonimport = ABAP_TRUE
iv_type = |string|
).
This is an example of reading all possible response values
lo_result = lo_result.
IF lo_result IS NOT INITIAL.
lv_datasourceid = lo_result->get_id( ).
lv_datasourcestatus = lo_result->get_status( ).
lv_datasourcetype = lo_result->get_type( ).
lv_name = lo_result->get_name( ).
lv_description = lo_result->get_description( ).
lv_domainid = lo_result->get_domainid( ).
lv_projectid = lo_result->get_projectid( ).
lv_environmentid = lo_result->get_environmentid( ).
lv_string = lo_result->get_connectionid( ).
lo_datasourceconfiguration = lo_result->get_configuration( ).
IF lo_datasourceconfiguration IS NOT INITIAL.
lo_gluerunconfigurationout = lo_datasourceconfiguration->get_gluerunconfiguration( ).
IF lo_gluerunconfigurationout IS NOT INITIAL.
lv_string = lo_gluerunconfigurationout->get_accountid( ).
lv_string = lo_gluerunconfigurationout->get_region( ).
lv_string = lo_gluerunconfigurationout->get_dataaccessrole( ).
LOOP AT lo_gluerunconfigurationout->get_relationalfilterconfs( ) into lo_row.
lo_row_1 = lo_row.
IF lo_row_1 IS NOT INITIAL.
lv_string = lo_row_1->get_databasename( ).
lv_string = lo_row_1->get_schemaname( ).
LOOP AT lo_row_1->get_filterexpressions( ) into lo_row_2.
lo_row_3 = lo_row_2.
IF lo_row_3 IS NOT INITIAL.
lv_filterexpressiontype = lo_row_3->get_type( ).
lv_string = lo_row_3->get_expression( ).
ENDIF.
ENDLOOP.
ENDIF.
ENDLOOP.
lv_boolean = lo_gluerunconfigurationout->get_autoimpdataqualityrslt( ).
lv_string = lo_gluerunconfigurationout->get_catalogname( ).
ENDIF.
lo_redshiftrunconfiguratio = lo_datasourceconfiguration->get_redshiftrunconfiguration( ).
IF lo_redshiftrunconfiguratio IS NOT INITIAL.
lv_string = lo_redshiftrunconfiguratio->get_accountid( ).
lv_string = lo_redshiftrunconfiguratio->get_region( ).
lv_string = lo_redshiftrunconfiguratio->get_dataaccessrole( ).
LOOP AT lo_redshiftrunconfiguratio->get_relationalfilterconfs( ) into lo_row.
lo_row_1 = lo_row.
IF lo_row_1 IS NOT INITIAL.
lv_string = lo_row_1->get_databasename( ).
lv_string = lo_row_1->get_schemaname( ).
LOOP AT lo_row_1->get_filterexpressions( ) into lo_row_2.
lo_row_3 = lo_row_2.
IF lo_row_3 IS NOT INITIAL.
lv_filterexpressiontype = lo_row_3->get_type( ).
lv_string = lo_row_3->get_expression( ).
ENDIF.
ENDLOOP.
ENDIF.
ENDLOOP.
lo_redshiftcredentialconfi = lo_redshiftrunconfiguratio->get_redshiftcredentialconf( ).
IF lo_redshiftcredentialconfi IS NOT INITIAL.
lv_string = lo_redshiftcredentialconfi->get_secretmanagerarn( ).
ENDIF.
lo_redshiftstorage = lo_redshiftrunconfiguratio->get_redshiftstorage( ).
IF lo_redshiftstorage IS NOT INITIAL.
lo_redshiftclusterstorage = lo_redshiftstorage->get_redshiftclustersource( ).
IF lo_redshiftclusterstorage IS NOT INITIAL.
lv_string = lo_redshiftclusterstorage->get_clustername( ).
ENDIF.
lo_redshiftserverlessstora = lo_redshiftstorage->get_redshiftserverlesssource( ).
IF lo_redshiftserverlessstora IS NOT INITIAL.
lv_string = lo_redshiftserverlessstora->get_workgroupname( ).
ENDIF.
ENDIF.
ENDIF.
lo_sagemakerrunconfigurati = lo_datasourceconfiguration->get_sagemakerrunconf( ).
IF lo_sagemakerrunconfigurati IS NOT INITIAL.
lv_string = lo_sagemakerrunconfigurati->get_accountid( ).
lv_string = lo_sagemakerrunconfigurati->get_region( ).
LOOP AT lo_sagemakerrunconfigurati->get_trackingassets( ) into ls_row_4.
lv_key = ls_row_4-key.
LOOP AT ls_row_4-value into lo_row_5.
lo_row_6 = lo_row_5.
IF lo_row_6 IS NOT INITIAL.
lv_sagemakerresourcearn = lo_row_6->get_value( ).
ENDIF.
ENDLOOP.
ENDLOOP.
ENDIF.
ENDIF.
lo_recommendationconfigura = lo_result->get_recommendation( ).
IF lo_recommendationconfigura IS NOT INITIAL.
lv_boolean = lo_recommendationconfigura->get_enbbusinessnamegenerat00( ).
ENDIF.
lv_enablesetting = lo_result->get_enablesetting( ).
lv_boolean = lo_result->get_publishonimport( ).
LOOP AT lo_result->get_assetformsoutput( ) into lo_row_7.
lo_row_8 = lo_row_7.
IF lo_row_8 IS NOT INITIAL.
lv_formname = lo_row_8->get_formname( ).
lv_formtypename = lo_row_8->get_typename( ).
lv_revision = lo_row_8->get_typerevision( ).
lv_string = lo_row_8->get_content( ).
ENDIF.
ENDLOOP.
lo_scheduleconfiguration = lo_result->get_schedule( ).
IF lo_scheduleconfiguration IS NOT INITIAL.
lv_timezone = lo_scheduleconfiguration->get_timezone( ).
lv_cronstring = lo_scheduleconfiguration->get_schedule( ).
ENDIF.
lv_datasourcerunstatus = lo_result->get_lastrunstatus( ).
lv_datetime = lo_result->get_lastrunat( ).
lo_datasourceerrormessage = lo_result->get_lastrunerrormessage( ).
IF lo_datasourceerrormessage IS NOT INITIAL.
lv_datasourceerrortype = lo_datasourceerrormessage->get_errortype( ).
lv_string = lo_datasourceerrormessage->get_errordetail( ).
ENDIF.
lo_datasourceerrormessage = lo_result->get_errormessage( ).
IF lo_datasourceerrormessage IS NOT INITIAL.
lv_datasourceerrortype = lo_datasourceerrormessage->get_errortype( ).
lv_string = lo_datasourceerrormessage->get_errordetail( ).
ENDIF.
lv_datetime = lo_result->get_createdat( ).
lv_datetime = lo_result->get_updatedat( ).
ENDIF.