CreateDataset VB.NET Example
' This example requires the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.
Dim rest As New Chilkat.Rest
Dim success As Boolean
Dim authAws As New Chilkat.AuthAws
authAws.AccessKey = "AWS_ACCESS_KEY"
authAws.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.)
authAws.Region = "us-west-2"
authAws.ServiceName = "iotanalytics"
' SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
rest.SetAuthAws(authAws)
' URL: https://iotanalytics.us-west-2.amazonaws.com/
' Use the same region as specified above.
success = rest.Connect("iotanalytics.us-west-2.amazonaws.com",443,True,True)
If (success <> True) Then
Debug.WriteLine("ConnectFailReason: " & rest.ConnectFailReason)
Debug.WriteLine(rest.LastErrorText)
Exit Sub
End If
' 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
Dim json As New Chilkat.JsonObject
json.UpdateString("actions[0].actionName","string")
json.UpdateString("actions[0].containerAction.executionRoleArn","string")
json.UpdateString("actions[0].containerAction.image","string")
json.UpdateString("actions[0].containerAction.resourceConfiguration.computeType","string")
json.UpdateInt("actions[0].containerAction.resourceConfiguration.volumeSizeInGB",123)
json.UpdateString("actions[0].containerAction.variables[0].datasetContentVersionValue.datasetName","string")
json.UpdateInt("actions[0].containerAction.variables[0].doubleValue",123)
json.UpdateString("actions[0].containerAction.variables[0].name","string")
json.UpdateString("actions[0].containerAction.variables[0].outputFileUriValue.fileName","string")
json.UpdateString("actions[0].containerAction.variables[0].stringValue","string")
json.UpdateInt("actions[0].queryAction.filters[0].deltaTime.offsetSeconds",123)
json.UpdateString("actions[0].queryAction.filters[0].deltaTime.timeExpression","string")
json.UpdateString("actions[0].queryAction.sqlQuery","string")
json.UpdateString("contentDeliveryRules[0].destination.iotEventsDestinationConfiguration.inputName","string")
json.UpdateString("contentDeliveryRules[0].destination.iotEventsDestinationConfiguration.roleArn","string")
json.UpdateString("contentDeliveryRules[0].destination.s3DestinationConfiguration.bucket","string")
json.UpdateString("contentDeliveryRules[0].destination.s3DestinationConfiguration.glueConfiguration.databaseName","string")
json.UpdateString("contentDeliveryRules[0].destination.s3DestinationConfiguration.glueConfiguration.tableName","string")
json.UpdateString("contentDeliveryRules[0].destination.s3DestinationConfiguration.key","string")
json.UpdateString("contentDeliveryRules[0].destination.s3DestinationConfiguration.roleArn","string")
json.UpdateString("contentDeliveryRules[0].entryName","string")
json.UpdateString("datasetName","string")
json.UpdateInt("lateDataRules[0].ruleConfiguration.deltaTimeSessionWindowConfiguration.timeoutInMinutes",123)
json.UpdateString("lateDataRules[0].ruleName","string")
json.UpdateInt("retentionPeriod.numberOfDays",123)
json.UpdateInt("retentionPeriod.unlimited",123)
json.UpdateString("tags[0].key","string")
json.UpdateString("tags[0].value","string")
json.UpdateString("triggers[0].dataset.name","string")
json.UpdateString("triggers[0].schedule.expression","string")
json.UpdateInt("versioningConfiguration.maxVersions",123)
json.UpdateInt("versioningConfiguration.unlimited",123)
' The JSON request body created by the above code:
' {
' "actions": [
' {
' "actionName": "string",
' "containerAction": {
' "executionRoleArn": "string",
' "image": "string",
' "resourceConfiguration": {
' "computeType": "string",
' "volumeSizeInGB": number
' },
' "variables": [
' {
' "datasetContentVersionValue": {
' "datasetName": "string"
' },
' "doubleValue": number,
' "name": "string",
' "outputFileUriValue": {
' "fileName": "string"
' },
' "stringValue": "string"
' }
' ]
' },
' "queryAction": {
' "filters": [
' {
' "deltaTime": {
' "offsetSeconds": number,
' "timeExpression": "string"
' }
' }
' ],
' "sqlQuery": "string"
' }
' }
' ],
' "contentDeliveryRules": [
' {
' "destination": {
' "iotEventsDestinationConfiguration": {
' "inputName": "string",
' "roleArn": "string"
' },
' "s3DestinationConfiguration": {
' "bucket": "string",
' "glueConfiguration": {
' "databaseName": "string",
' "tableName": "string"
' },
' "key": "string",
' "roleArn": "string"
' }
' },
' "entryName": "string"
' }
' ],
' "datasetName": "string",
' "lateDataRules": [
' {
' "ruleConfiguration": {
' "deltaTimeSessionWindowConfiguration": {
' "timeoutInMinutes": number
' }
' },
' "ruleName": "string"
' }
' ],
' "retentionPeriod": {
' "numberOfDays": number,
' "unlimited": boolean
' },
' "tags": [
' {
' "key": "string",
' "value": "string"
' }
' ],
' "triggers": [
' {
' "dataset": {
' "name": "string"
' },
' "schedule": {
' "expression": "string"
' }
' }
' ],
' "versioningConfiguration": {
' "maxVersions": number,
' "unlimited": boolean
' }
' }
rest.AddHeader("Content-Type","application/x-amz-json-1.1")
rest.AddHeader("X-Amz-Target","CreateDataset")
Dim sbRequestBody As New Chilkat.StringBuilder
json.EmitSb(sbRequestBody)
Dim sbResponseBody As New Chilkat.StringBuilder
success = rest.FullRequestSb("POST","/datasets",sbRequestBody,sbResponseBody)
If (success <> True) Then
Debug.WriteLine(rest.LastErrorText)
Exit Sub
End If
Dim respStatusCode As Integer = rest.ResponseStatusCode
Debug.WriteLine("response status code = " & respStatusCode)
If (respStatusCode <> 200) Then
Debug.WriteLine("Response Header:")
Debug.WriteLine(rest.ResponseHeader)
Debug.WriteLine("Response Body:")
Debug.WriteLine(sbResponseBody.GetAsString())
Exit Sub
End If
Dim jResp As New Chilkat.JsonObject
jResp.LoadSb(sbResponseBody)
' 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
Dim datasetArn As String = jResp.StringOf("datasetArn")
Dim datasetName As String = jResp.StringOf("datasetName")
Dim NumberOfDays As Integer = jResp.IntOf("retentionPeriod.numberOfDays")
Dim Unlimited As Integer = jResp.IntOf("retentionPeriod.unlimited")
' A sample JSON response body parsed by the above code:
' {
' "datasetArn": "string",
' "datasetName": "string",
' "retentionPeriod": {
' "numberOfDays": number,
' "unlimited": boolean
' }
' }