Chilkat Online Tools

CreateDataSource autoit Example

AWS AppSync

; This example requires the Chilkat API to have been previously unlocked.
; See Global Unlock Sample for sample code.

$oRest = ObjCreate("Chilkat_9_5_0.Rest")
Local $bSuccess

$oAuthAws = ObjCreate("Chilkat_9_5_0.AuthAws")
$oAuthAws.AccessKey = "AWS_ACCESS_KEY"
$oAuthAws.SecretKey = "AWS_SECRET_KEY"

; Don't forget to change the region to your particular region. (Also make the same change in the call to Connect below.)
$oAuthAws.Region = "us-west-2"
$oAuthAws.ServiceName = "appsync"
; SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
$oRest.SetAuthAws($oAuthAws)

; URL: https://appsync.us-west-2.amazonaws.com/
; Use the same region as specified above.
$bSuccess = $oRest.Connect("appsync.us-west-2.amazonaws.com",443,True,True)
If ($bSuccess <> True) Then
    ConsoleWrite("ConnectFailReason: " & $oRest.ConnectFailReason & @CRLF)
    ConsoleWrite($oRest.LastErrorText & @CRLF)
    Exit
EndIf

; The following code creates the JSON request body.
; The JSON created by this code is shown below.

; Use this online tool to generate code from sample JSON:
; Generate Code to Create JSON

$oJson = ObjCreate("Chilkat_9_5_0.JsonObject")
$oJson.UpdateString("description","string")
$oJson.UpdateString("dynamodbConfig.awsRegion","string")
$oJson.UpdateInt("dynamodbConfig.deltaSyncConfig.baseTableTTL",123)
$oJson.UpdateString("dynamodbConfig.deltaSyncConfig.deltaSyncTableName","string")
$oJson.UpdateInt("dynamodbConfig.deltaSyncConfig.deltaSyncTableTTL",123)
$oJson.UpdateString("dynamodbConfig.tableName","string")
$oJson.UpdateInt("dynamodbConfig.useCallerCredentials",123)
$oJson.UpdateInt("dynamodbConfig.versioned",123)
$oJson.UpdateString("elasticsearchConfig.awsRegion","string")
$oJson.UpdateString("elasticsearchConfig.endpoint","string")
$oJson.UpdateString("httpConfig.authorizationConfig.authorizationType","string")
$oJson.UpdateString("httpConfig.authorizationConfig.awsIamConfig.signingRegion","string")
$oJson.UpdateString("httpConfig.authorizationConfig.awsIamConfig.signingServiceName","string")
$oJson.UpdateString("httpConfig.endpoint","string")
$oJson.UpdateString("lambdaConfig.lambdaFunctionArn","string")
$oJson.UpdateString("name","string")
$oJson.UpdateString("openSearchServiceConfig.awsRegion","string")
$oJson.UpdateString("openSearchServiceConfig.endpoint","string")
$oJson.UpdateString("relationalDatabaseConfig.rdsHttpEndpointConfig.awsRegion","string")
$oJson.UpdateString("relationalDatabaseConfig.rdsHttpEndpointConfig.awsSecretStoreArn","string")
$oJson.UpdateString("relationalDatabaseConfig.rdsHttpEndpointConfig.databaseName","string")
$oJson.UpdateString("relationalDatabaseConfig.rdsHttpEndpointConfig.dbClusterIdentifier","string")
$oJson.UpdateString("relationalDatabaseConfig.rdsHttpEndpointConfig.schema","string")
$oJson.UpdateString("relationalDatabaseConfig.relationalDatabaseSourceType","string")
$oJson.UpdateString("serviceRoleArn","string")
$oJson.UpdateString("type","string")

; The JSON request body created by the above code:

; {
;   "description": "string",
;   "dynamodbConfig": {
;     "awsRegion": "string",
;     "deltaSyncConfig": {
;       "baseTableTTL": number,
;       "deltaSyncTableName": "string",
;       "deltaSyncTableTTL": number
;     },
;     "tableName": "string",
;     "useCallerCredentials": boolean,
;     "versioned": boolean
;   },
;   "elasticsearchConfig": {
;     "awsRegion": "string",
;     "endpoint": "string"
;   },
;   "httpConfig": {
;     "authorizationConfig": {
;       "authorizationType": "string",
;       "awsIamConfig": {
;         "signingRegion": "string",
;         "signingServiceName": "string"
;       }
;     },
;     "endpoint": "string"
;   },
;   "lambdaConfig": {
;     "lambdaFunctionArn": "string"
;   },
;   "name": "string",
;   "openSearchServiceConfig": {
;     "awsRegion": "string",
;     "endpoint": "string"
;   },
;   "relationalDatabaseConfig": {
;     "rdsHttpEndpointConfig": {
;       "awsRegion": "string",
;       "awsSecretStoreArn": "string",
;       "databaseName": "string",
;       "dbClusterIdentifier": "string",
;       "schema": "string"
;     },
;     "relationalDatabaseSourceType": "string"
;   },
;   "serviceRoleArn": "string",
;   "type": "string"
; }

$oRest.AddHeader("Content-Type","application/x-amz-json-1.1")
$oRest.AddHeader("X-Amz-Target","CreateDataSource")

$oSbRequestBody = ObjCreate("Chilkat_9_5_0.StringBuilder")
$oJson.EmitSb($oSbRequestBody)
$oSbResponseBody = ObjCreate("Chilkat_9_5_0.StringBuilder")
$bSuccess = $oRest.FullRequestSb("POST","/v1/apis/{apiId}/datasources",$oSbRequestBody,$oSbResponseBody)
If ($bSuccess <> True) Then
    ConsoleWrite($oRest.LastErrorText & @CRLF)
    Exit
EndIf

Local $iRespStatusCode = $oRest.ResponseStatusCode
ConsoleWrite("response status code = " & $iRespStatusCode & @CRLF)
If ($iRespStatusCode <> 200) Then
    ConsoleWrite("Response Header:" & @CRLF)
    ConsoleWrite($oRest.ResponseHeader & @CRLF)
    ConsoleWrite("Response Body:" & @CRLF)
    ConsoleWrite($oSbResponseBody.GetAsString() & @CRLF)
    Exit
EndIf

$oJResp = ObjCreate("Chilkat_9_5_0.JsonObject")
$oJResp.LoadSb($oSbResponseBody)

; The following code parses the JSON response.
; A sample JSON response is shown below the sample code.

; Use this online tool to generate parsing code from sample JSON:
; Generate Parsing Code from JSON

Local $sDataSourceArn = $oJResp.StringOf("dataSource.dataSourceArn")
Local $sDescription = $oJResp.StringOf("dataSource.description")
Local $sAwsRegion = $oJResp.StringOf("dataSource.dynamodbConfig.awsRegion")
Local $iBaseTableTTL = $oJResp.IntOf("dataSource.dynamodbConfig.deltaSyncConfig.baseTableTTL")
Local $sDeltaSyncTableName = $oJResp.StringOf("dataSource.dynamodbConfig.deltaSyncConfig.deltaSyncTableName")
Local $iDeltaSyncTableTTL = $oJResp.IntOf("dataSource.dynamodbConfig.deltaSyncConfig.deltaSyncTableTTL")
Local $sTableName = $oJResp.StringOf("dataSource.dynamodbConfig.tableName")
Local $iUseCallerCredentials = $oJResp.IntOf("dataSource.dynamodbConfig.useCallerCredentials")
Local $iVersioned = $oJResp.IntOf("dataSource.dynamodbConfig.versioned")
Local $sElasticsearchConfigAwsRegion = $oJResp.StringOf("dataSource.elasticsearchConfig.awsRegion")
Local $sEndpoint = $oJResp.StringOf("dataSource.elasticsearchConfig.endpoint")
Local $sAuthorizationType = $oJResp.StringOf("dataSource.httpConfig.authorizationConfig.authorizationType")
Local $sSigningRegion = $oJResp.StringOf("dataSource.httpConfig.authorizationConfig.awsIamConfig.signingRegion")
Local $sSigningServiceName = $oJResp.StringOf("dataSource.httpConfig.authorizationConfig.awsIamConfig.signingServiceName")
Local $sHttpConfigEndpoint = $oJResp.StringOf("dataSource.httpConfig.endpoint")
Local $sLambdaFunctionArn = $oJResp.StringOf("dataSource.lambdaConfig.lambdaFunctionArn")
Local $sName = $oJResp.StringOf("dataSource.name")
Local $sOpenSearchServiceConfigAwsRegion = $oJResp.StringOf("dataSource.openSearchServiceConfig.awsRegion")
Local $sOpenSearchServiceConfigEndpoint = $oJResp.StringOf("dataSource.openSearchServiceConfig.endpoint")
Local $sRdsHttpEndpointConfigAwsRegion = $oJResp.StringOf("dataSource.relationalDatabaseConfig.rdsHttpEndpointConfig.awsRegion")
Local $sAwsSecretStoreArn = $oJResp.StringOf("dataSource.relationalDatabaseConfig.rdsHttpEndpointConfig.awsSecretStoreArn")
Local $sDatabaseName = $oJResp.StringOf("dataSource.relationalDatabaseConfig.rdsHttpEndpointConfig.databaseName")
Local $sDbClusterIdentifier = $oJResp.StringOf("dataSource.relationalDatabaseConfig.rdsHttpEndpointConfig.dbClusterIdentifier")
Local $sSchema = $oJResp.StringOf("dataSource.relationalDatabaseConfig.rdsHttpEndpointConfig.schema")
Local $sRelationalDatabaseSourceType = $oJResp.StringOf("dataSource.relationalDatabaseConfig.relationalDatabaseSourceType")
Local $sServiceRoleArn = $oJResp.StringOf("dataSource.serviceRoleArn")
Local $sV_Type = $oJResp.StringOf("dataSource.type")

; A sample JSON response body parsed by the above code:

; {
;   "dataSource": {
;     "dataSourceArn": "string",
;     "description": "string",
;     "dynamodbConfig": {
;       "awsRegion": "string",
;       "deltaSyncConfig": {
;         "baseTableTTL": number,
;         "deltaSyncTableName": "string",
;         "deltaSyncTableTTL": number
;       },
;       "tableName": "string",
;       "useCallerCredentials": boolean,
;       "versioned": boolean
;     },
;     "elasticsearchConfig": {
;       "awsRegion": "string",
;       "endpoint": "string"
;     },
;     "httpConfig": {
;       "authorizationConfig": {
;         "authorizationType": "string",
;         "awsIamConfig": {
;           "signingRegion": "string",
;           "signingServiceName": "string"
;         }
;       },
;       "endpoint": "string"
;     },
;     "lambdaConfig": {
;       "lambdaFunctionArn": "string"
;     },
;     "name": "string",
;     "openSearchServiceConfig": {
;       "awsRegion": "string",
;       "endpoint": "string"
;     },
;     "relationalDatabaseConfig": {
;       "rdsHttpEndpointConfig": {
;         "awsRegion": "string",
;         "awsSecretStoreArn": "string",
;         "databaseName": "string",
;         "dbClusterIdentifier": "string",
;         "schema": "string"
;       },
;       "relationalDatabaseSourceType": "string"
;     },
;     "serviceRoleArn": "string",
;     "type": "string"
;   }
; }