Chilkat Online Tools

DescribeJobs Go Example

AWS Batch

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

    rest := chilkat.NewRest()
    var success bool

    authAws := chilkat.NewAuthAws()
    authAws.SetAccessKey("AWS_ACCESS_KEY")
    authAws.SetSecretKey("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.SetRegion("us-west-2")
    authAws.SetServiceName("batch")
    // SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
    rest.SetAuthAws(authAws)

    // URL: https://batch.us-west-2.amazonaws.com/
    // Use the same region as specified above.
    success = rest.Connect("batch.us-west-2.amazonaws.com",443,true,true)
    if success != true {
        fmt.Println("ConnectFailReason: ", rest.ConnectFailReason())
        fmt.Println(rest.LastErrorText())
        rest.DisposeRest()
        authAws.DisposeAuthAws()
        return
    }

    // 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

    json := chilkat.NewJsonObject()
    json.UpdateString("jobs[0]","string")

    // The JSON request body created by the above code:

    // {
    //   "jobs": [
    //     "string"
    //   ]
    // }

    rest.AddHeader("Content-Type","application/x-amz-json-1.1")
    rest.AddHeader("X-Amz-Target","DescribeJobs")

    sbRequestBody := chilkat.NewStringBuilder()
    json.EmitSb(sbRequestBody)
    sbResponseBody := chilkat.NewStringBuilder()
    success = rest.FullRequestSb("POST","/v1/describejobs",sbRequestBody,sbResponseBody)
    if success != true {
        fmt.Println(rest.LastErrorText())
        rest.DisposeRest()
        authAws.DisposeAuthAws()
        json.DisposeJsonObject()
        sbRequestBody.DisposeStringBuilder()
        sbResponseBody.DisposeStringBuilder()
        return
    }

    respStatusCode := rest.ResponseStatusCode()
    fmt.Println("response status code = ", respStatusCode)
    if respStatusCode != 200 {
        fmt.Println("Response Header:")
        fmt.Println(rest.ResponseHeader())
        fmt.Println("Response Body:")
        fmt.Println(*sbResponseBody.GetAsString())
        rest.DisposeRest()
        authAws.DisposeAuthAws()
        json.DisposeJsonObject()
        sbRequestBody.DisposeStringBuilder()
        sbResponseBody.DisposeStringBuilder()
        return
    }

    jResp := chilkat.NewJsonObject()
    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

    var Index int
    var Size int
    var v_String int
ContainerInstanceArn_DECLARATION
ExecutionRoleArn_DECLARATION
    var ExitCode int
PlatformVersion_DECLARATION
Image_DECLARATION
InstanceType_DECLARATION
JobRoleArn_DECLARATION
    var InitProcessEnabled int
    var MaxSwap int
    var SharedMemorySize int
    var Swappiness int
LogDriver_DECLARATION
OptionsString_DECLARATION
LogStreamName_DECLARATION
    var Memory int
AssignPublicIp_DECLARATION
    var Privileged int
    var ReadonlyRootFilesystem int
Reason_DECLARATION
TaskArn_DECLARATION
User_DECLARATION
    var Vcpus int
    var createdAt int
jobArn_DECLARATION
jobDefinition_DECLARATION
jobId_DECLARATION
jobName_DECLARATION
jobQueue_DECLARATION
    var IsMainNode int
    var NodeIndex int
    var MainNode int
    var NumNodes int
parametersString_DECLARATION
    var propagateTags int
    var Attempts int
    var schedulingPriority int
shareIdentifier_DECLARATION
    var startedAt int
status_DECLARATION
statusReason_DECLARATION
    var stoppedAt int
tagsString_DECLARATION
    var AttemptDurationSeconds int
    var j int
    var count_j int
containerContainerInstanceArn_DECLARATION
    var containerExitCode int
containerLogStreamName_DECLARATION
containerReason_DECLARATION
containerTaskArn_DECLARATION
    var k int
    var count_k int
attachmentId_DECLARATION
ipv6Address_DECLARATION
privateIpv4Address_DECLARATION
strVal_DECLARATION
name_DECLARATION
value_DECLARATION
containerPath_DECLARATION
hostPath_DECLARATION
    var size int
valueFrom_DECLARATION
    var readOnly int
sourceVolume_DECLARATION
v_type_DECLARATION
    var hardLimit int
    var softLimit int
AccessPointId_DECLARATION
Iam_DECLARATION
FileSystemId_DECLARATION
RootDirectory_DECLARATION
TransitEncryption_DECLARATION
    var TransitEncryptionPort int
SourcePath_DECLARATION
containerExecutionRoleArn_DECLARATION
FargatePlatformConfigurationPlatformVersion_DECLARATION
containerImage_DECLARATION
containerInstanceType_DECLARATION
containerJobRoleArn_DECLARATION
    var LinuxParametersInitProcessEnabled int
    var LinuxParametersMaxSwap int
    var LinuxParametersSharedMemorySize int
    var LinuxParametersSwappiness int
LogConfigurationLogDriver_DECLARATION
    var containerMemory int
NetworkConfigurationAssignPublicIp_DECLARATION
    var containerPrivileged int
    var containerReadonlyRootFilesystem int
containerUser_DECLARATION
    var containerVcpus int
targetNodes_DECLARATION
    // json1 is a JsonObject
    var i1 int
    var count_i1 int
AuthorizationConfigAccessPointId_DECLARATION
AuthorizationConfigIam_DECLARATION
efsVolumeConfigurationFileSystemId_DECLARATION
efsVolumeConfigurationRootDirectory_DECLARATION
efsVolumeConfigurationTransitEncryption_DECLARATION
    var efsVolumeConfigurationTransitEncryptionPort int
hostSourcePath_DECLARATION
action_DECLARATION
onExitCode_DECLARATION
onReason_DECLARATION
onStatusReason_DECLARATION

    i := 0
    count_i := jResp.SizeOfArray("jobs")
    for i < count_i {
        jResp.SetI(i)
        Index = jResp.IntOf("jobs[i].arrayProperties.index")
        Size = jResp.IntOf("jobs[i].arrayProperties.size")
        v_String = jResp.IntOf("jobs[i].arrayProperties.statusSummary.string")
        ContainerInstanceArn = *jResp.StringOf("jobs[i].container.containerInstanceArn")
        ExecutionRoleArn = *jResp.StringOf("jobs[i].container.executionRoleArn")
        ExitCode = jResp.IntOf("jobs[i].container.exitCode")
        PlatformVersion = *jResp.StringOf("jobs[i].container.fargatePlatformConfiguration.platformVersion")
        Image = *jResp.StringOf("jobs[i].container.image")
        InstanceType = *jResp.StringOf("jobs[i].container.instanceType")
        JobRoleArn = *jResp.StringOf("jobs[i].container.jobRoleArn")
        InitProcessEnabled = jResp.IntOf("jobs[i].container.linuxParameters.initProcessEnabled")
        MaxSwap = jResp.IntOf("jobs[i].container.linuxParameters.maxSwap")
        SharedMemorySize = jResp.IntOf("jobs[i].container.linuxParameters.sharedMemorySize")
        Swappiness = jResp.IntOf("jobs[i].container.linuxParameters.swappiness")
        LogDriver = *jResp.StringOf("jobs[i].container.logConfiguration.logDriver")
        OptionsString = *jResp.StringOf("jobs[i].container.logConfiguration.options.string")
        LogStreamName = *jResp.StringOf("jobs[i].container.logStreamName")
        Memory = jResp.IntOf("jobs[i].container.memory")
        AssignPublicIp = *jResp.StringOf("jobs[i].container.networkConfiguration.assignPublicIp")
        Privileged = jResp.IntOf("jobs[i].container.privileged")
        ReadonlyRootFilesystem = jResp.IntOf("jobs[i].container.readonlyRootFilesystem")
        Reason = *jResp.StringOf("jobs[i].container.reason")
        TaskArn = *jResp.StringOf("jobs[i].container.taskArn")
        User = *jResp.StringOf("jobs[i].container.user")
        Vcpus = jResp.IntOf("jobs[i].container.vcpus")
        createdAt = jResp.IntOf("jobs[i].createdAt")
        jobArn = *jResp.StringOf("jobs[i].jobArn")
        jobDefinition = *jResp.StringOf("jobs[i].jobDefinition")
        jobId = *jResp.StringOf("jobs[i].jobId")
        jobName = *jResp.StringOf("jobs[i].jobName")
        jobQueue = *jResp.StringOf("jobs[i].jobQueue")
        IsMainNode = jResp.IntOf("jobs[i].nodeDetails.isMainNode")
        NodeIndex = jResp.IntOf("jobs[i].nodeDetails.nodeIndex")
        MainNode = jResp.IntOf("jobs[i].nodeProperties.mainNode")
        NumNodes = jResp.IntOf("jobs[i].nodeProperties.numNodes")
        parametersString = *jResp.StringOf("jobs[i].parameters.string")
        propagateTags = jResp.IntOf("jobs[i].propagateTags")
        Attempts = jResp.IntOf("jobs[i].retryStrategy.attempts")
        schedulingPriority = jResp.IntOf("jobs[i].schedulingPriority")
        shareIdentifier = *jResp.StringOf("jobs[i].shareIdentifier")
        startedAt = jResp.IntOf("jobs[i].startedAt")
        status = *jResp.StringOf("jobs[i].status")
        statusReason = *jResp.StringOf("jobs[i].statusReason")
        stoppedAt = jResp.IntOf("jobs[i].stoppedAt")
        tagsString = *jResp.StringOf("jobs[i].tags.string")
        AttemptDurationSeconds = jResp.IntOf("jobs[i].timeout.attemptDurationSeconds")
        j = 0
        count_j = jResp.SizeOfArray("jobs[i].attempts")
        for j < count_j {
            jResp.SetJ(j)
            containerContainerInstanceArn = *jResp.StringOf("jobs[i].attempts[j].container.containerInstanceArn")
            containerExitCode = jResp.IntOf("jobs[i].attempts[j].container.exitCode")
            containerLogStreamName = *jResp.StringOf("jobs[i].attempts[j].container.logStreamName")
            containerReason = *jResp.StringOf("jobs[i].attempts[j].container.reason")
            containerTaskArn = *jResp.StringOf("jobs[i].attempts[j].container.taskArn")
            startedAt = jResp.IntOf("jobs[i].attempts[j].startedAt")
            statusReason = *jResp.StringOf("jobs[i].attempts[j].statusReason")
            stoppedAt = jResp.IntOf("jobs[i].attempts[j].stoppedAt")
            k = 0
            count_k = jResp.SizeOfArray("jobs[i].attempts[j].container.networkInterfaces")
            for k < count_k {
                jResp.SetK(k)
                attachmentId = *jResp.StringOf("jobs[i].attempts[j].container.networkInterfaces[k].attachmentId")
                ipv6Address = *jResp.StringOf("jobs[i].attempts[j].container.networkInterfaces[k].ipv6Address")
                privateIpv4Address = *jResp.StringOf("jobs[i].attempts[j].container.networkInterfaces[k].privateIpv4Address")
                k = k + 1
            }

            j = j + 1
        }

        j = 0
        count_j = jResp.SizeOfArray("jobs[i].container.command")
        for j < count_j {
            jResp.SetJ(j)
            strVal = *jResp.StringOf("jobs[i].container.command[j]")
            j = j + 1
        }

        j = 0
        count_j = jResp.SizeOfArray("jobs[i].container.environment")
        for j < count_j {
            jResp.SetJ(j)
            name = *jResp.StringOf("jobs[i].container.environment[j].name")
            value = *jResp.StringOf("jobs[i].container.environment[j].value")
            j = j + 1
        }

        j = 0
        count_j = jResp.SizeOfArray("jobs[i].container.linuxParameters.devices")
        for j < count_j {
            jResp.SetJ(j)
            containerPath = *jResp.StringOf("jobs[i].container.linuxParameters.devices[j].containerPath")
            hostPath = *jResp.StringOf("jobs[i].container.linuxParameters.devices[j].hostPath")
            k = 0
            count_k = jResp.SizeOfArray("jobs[i].container.linuxParameters.devices[j].permissions")
            for k < count_k {
                jResp.SetK(k)
                strVal = *jResp.StringOf("jobs[i].container.linuxParameters.devices[j].permissions[k]")
                k = k + 1
            }

            j = j + 1
        }

        j = 0
        count_j = jResp.SizeOfArray("jobs[i].container.linuxParameters.tmpfs")
        for j < count_j {
            jResp.SetJ(j)
            containerPath = *jResp.StringOf("jobs[i].container.linuxParameters.tmpfs[j].containerPath")
            size = jResp.IntOf("jobs[i].container.linuxParameters.tmpfs[j].size")
            k = 0
            count_k = jResp.SizeOfArray("jobs[i].container.linuxParameters.tmpfs[j].mountOptions")
            for k < count_k {
                jResp.SetK(k)
                strVal = *jResp.StringOf("jobs[i].container.linuxParameters.tmpfs[j].mountOptions[k]")
                k = k + 1
            }

            j = j + 1
        }

        j = 0
        count_j = jResp.SizeOfArray("jobs[i].container.logConfiguration.secretOptions")
        for j < count_j {
            jResp.SetJ(j)
            name = *jResp.StringOf("jobs[i].container.logConfiguration.secretOptions[j].name")
            valueFrom = *jResp.StringOf("jobs[i].container.logConfiguration.secretOptions[j].valueFrom")
            j = j + 1
        }

        j = 0
        count_j = jResp.SizeOfArray("jobs[i].container.mountPoints")
        for j < count_j {
            jResp.SetJ(j)
            containerPath = *jResp.StringOf("jobs[i].container.mountPoints[j].containerPath")
            readOnly = jResp.IntOf("jobs[i].container.mountPoints[j].readOnly")
            sourceVolume = *jResp.StringOf("jobs[i].container.mountPoints[j].sourceVolume")
            j = j + 1
        }

        j = 0
        count_j = jResp.SizeOfArray("jobs[i].container.networkInterfaces")
        for j < count_j {
            jResp.SetJ(j)
            attachmentId = *jResp.StringOf("jobs[i].container.networkInterfaces[j].attachmentId")
            ipv6Address = *jResp.StringOf("jobs[i].container.networkInterfaces[j].ipv6Address")
            privateIpv4Address = *jResp.StringOf("jobs[i].container.networkInterfaces[j].privateIpv4Address")
            j = j + 1
        }

        j = 0
        count_j = jResp.SizeOfArray("jobs[i].container.resourceRequirements")
        for j < count_j {
            jResp.SetJ(j)
            v_type = *jResp.StringOf("jobs[i].container.resourceRequirements[j].type")
            value = *jResp.StringOf("jobs[i].container.resourceRequirements[j].value")
            j = j + 1
        }

        j = 0
        count_j = jResp.SizeOfArray("jobs[i].container.secrets")
        for j < count_j {
            jResp.SetJ(j)
            name = *jResp.StringOf("jobs[i].container.secrets[j].name")
            valueFrom = *jResp.StringOf("jobs[i].container.secrets[j].valueFrom")
            j = j + 1
        }

        j = 0
        count_j = jResp.SizeOfArray("jobs[i].container.ulimits")
        for j < count_j {
            jResp.SetJ(j)
            hardLimit = jResp.IntOf("jobs[i].container.ulimits[j].hardLimit")
            name = *jResp.StringOf("jobs[i].container.ulimits[j].name")
            softLimit = jResp.IntOf("jobs[i].container.ulimits[j].softLimit")
            j = j + 1
        }

        j = 0
        count_j = jResp.SizeOfArray("jobs[i].container.volumes")
        for j < count_j {
            jResp.SetJ(j)
            AccessPointId = *jResp.StringOf("jobs[i].container.volumes[j].efsVolumeConfiguration.authorizationConfig.accessPointId")
            Iam = *jResp.StringOf("jobs[i].container.volumes[j].efsVolumeConfiguration.authorizationConfig.iam")
            FileSystemId = *jResp.StringOf("jobs[i].container.volumes[j].efsVolumeConfiguration.fileSystemId")
            RootDirectory = *jResp.StringOf("jobs[i].container.volumes[j].efsVolumeConfiguration.rootDirectory")
            TransitEncryption = *jResp.StringOf("jobs[i].container.volumes[j].efsVolumeConfiguration.transitEncryption")
            TransitEncryptionPort = jResp.IntOf("jobs[i].container.volumes[j].efsVolumeConfiguration.transitEncryptionPort")
            SourcePath = *jResp.StringOf("jobs[i].container.volumes[j].host.sourcePath")
            name = *jResp.StringOf("jobs[i].container.volumes[j].name")
            j = j + 1
        }

        j = 0
        count_j = jResp.SizeOfArray("jobs[i].dependsOn")
        for j < count_j {
            jResp.SetJ(j)
            jobId = *jResp.StringOf("jobs[i].dependsOn[j].jobId")
            v_type = *jResp.StringOf("jobs[i].dependsOn[j].type")
            j = j + 1
        }

        j = 0
        count_j = jResp.SizeOfArray("jobs[i].nodeProperties.nodeRangeProperties")
        for j < count_j {
            jResp.SetJ(j)
            containerExecutionRoleArn = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.executionRoleArn")
            FargatePlatformConfigurationPlatformVersion = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.fargatePlatformConfiguration.platformVersion")
            containerImage = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.image")
            containerInstanceType = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.instanceType")
            containerJobRoleArn = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.jobRoleArn")
            LinuxParametersInitProcessEnabled = jResp.IntOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.initProcessEnabled")
            LinuxParametersMaxSwap = jResp.IntOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.maxSwap")
            LinuxParametersSharedMemorySize = jResp.IntOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.sharedMemorySize")
            LinuxParametersSwappiness = jResp.IntOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.swappiness")
            LogConfigurationLogDriver = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.logConfiguration.logDriver")
            OptionsString = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.logConfiguration.options.string")
            containerMemory = jResp.IntOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.memory")
            NetworkConfigurationAssignPublicIp = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.networkConfiguration.assignPublicIp")
            containerPrivileged = jResp.IntOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.privileged")
            containerReadonlyRootFilesystem = jResp.IntOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.readonlyRootFilesystem")
            containerUser = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.user")
            containerVcpus = jResp.IntOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.vcpus")
            targetNodes = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].targetNodes")
            k = 0
            count_k = jResp.SizeOfArray("jobs[i].nodeProperties.nodeRangeProperties[j].container.command")
            for k < count_k {
                jResp.SetK(k)
                strVal = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.command[k]")
                k = k + 1
            }

            k = 0
            count_k = jResp.SizeOfArray("jobs[i].nodeProperties.nodeRangeProperties[j].container.environment")
            for k < count_k {
                jResp.SetK(k)
                name = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.environment[k].name")
                value = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.environment[k].value")
                k = k + 1
            }

            k = 0
            count_k = jResp.SizeOfArray("jobs[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.devices")
            for k < count_k {
                jResp.SetK(k)
                containerPath = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.devices[k].containerPath")
                hostPath = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.devices[k].hostPath")

                json1 := jResp.ObjectOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.devices[k]")
                i1 = 0
                count_i1 = json1.SizeOfArray("permissions")
                for i1 < count_i1 {
                    json1.SetI(i1)
                    strVal = *json1.StringOf("permissions[i]")
                    i1 = i1 + 1
                }

                json1.DisposeJsonObject()
                k = k + 1
            }

            k = 0
            count_k = jResp.SizeOfArray("jobs[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.tmpfs")
            for k < count_k {
                jResp.SetK(k)
                containerPath = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.tmpfs[k].containerPath")
                size = jResp.IntOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.tmpfs[k].size")

                json1 = jResp.ObjectOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.tmpfs[k]")
                i1 = 0
                count_i1 = json1.SizeOfArray("mountOptions")
                for i1 < count_i1 {
                    json1.SetI(i1)
                    strVal = *json1.StringOf("mountOptions[i]")
                    i1 = i1 + 1
                }

                json1.DisposeJsonObject()
                k = k + 1
            }

            k = 0
            count_k = jResp.SizeOfArray("jobs[i].nodeProperties.nodeRangeProperties[j].container.logConfiguration.secretOptions")
            for k < count_k {
                jResp.SetK(k)
                name = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.logConfiguration.secretOptions[k].name")
                valueFrom = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.logConfiguration.secretOptions[k].valueFrom")
                k = k + 1
            }

            k = 0
            count_k = jResp.SizeOfArray("jobs[i].nodeProperties.nodeRangeProperties[j].container.mountPoints")
            for k < count_k {
                jResp.SetK(k)
                containerPath = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.mountPoints[k].containerPath")
                readOnly = jResp.IntOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.mountPoints[k].readOnly")
                sourceVolume = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.mountPoints[k].sourceVolume")
                k = k + 1
            }

            k = 0
            count_k = jResp.SizeOfArray("jobs[i].nodeProperties.nodeRangeProperties[j].container.resourceRequirements")
            for k < count_k {
                jResp.SetK(k)
                v_type = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.resourceRequirements[k].type")
                value = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.resourceRequirements[k].value")
                k = k + 1
            }

            k = 0
            count_k = jResp.SizeOfArray("jobs[i].nodeProperties.nodeRangeProperties[j].container.secrets")
            for k < count_k {
                jResp.SetK(k)
                name = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.secrets[k].name")
                valueFrom = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.secrets[k].valueFrom")
                k = k + 1
            }

            k = 0
            count_k = jResp.SizeOfArray("jobs[i].nodeProperties.nodeRangeProperties[j].container.ulimits")
            for k < count_k {
                jResp.SetK(k)
                hardLimit = jResp.IntOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.ulimits[k].hardLimit")
                name = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.ulimits[k].name")
                softLimit = jResp.IntOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.ulimits[k].softLimit")
                k = k + 1
            }

            k = 0
            count_k = jResp.SizeOfArray("jobs[i].nodeProperties.nodeRangeProperties[j].container.volumes")
            for k < count_k {
                jResp.SetK(k)
                AuthorizationConfigAccessPointId = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.volumes[k].efsVolumeConfiguration.authorizationConfig.accessPointId")
                AuthorizationConfigIam = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.volumes[k].efsVolumeConfiguration.authorizationConfig.iam")
                efsVolumeConfigurationFileSystemId = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.volumes[k].efsVolumeConfiguration.fileSystemId")
                efsVolumeConfigurationRootDirectory = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.volumes[k].efsVolumeConfiguration.rootDirectory")
                efsVolumeConfigurationTransitEncryption = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.volumes[k].efsVolumeConfiguration.transitEncryption")
                efsVolumeConfigurationTransitEncryptionPort = jResp.IntOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.volumes[k].efsVolumeConfiguration.transitEncryptionPort")
                hostSourcePath = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.volumes[k].host.sourcePath")
                name = *jResp.StringOf("jobs[i].nodeProperties.nodeRangeProperties[j].container.volumes[k].name")
                k = k + 1
            }

            j = j + 1
        }

        j = 0
        count_j = jResp.SizeOfArray("jobs[i].platformCapabilities")
        for j < count_j {
            jResp.SetJ(j)
            strVal = *jResp.StringOf("jobs[i].platformCapabilities[j]")
            j = j + 1
        }

        j = 0
        count_j = jResp.SizeOfArray("jobs[i].retryStrategy.evaluateOnExit")
        for j < count_j {
            jResp.SetJ(j)
            action = *jResp.StringOf("jobs[i].retryStrategy.evaluateOnExit[j].action")
            onExitCode = *jResp.StringOf("jobs[i].retryStrategy.evaluateOnExit[j].onExitCode")
            onReason = *jResp.StringOf("jobs[i].retryStrategy.evaluateOnExit[j].onReason")
            onStatusReason = *jResp.StringOf("jobs[i].retryStrategy.evaluateOnExit[j].onStatusReason")
            j = j + 1
        }

        i = i + 1
    }

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

    // {
    //   "jobs": [
    //     {
    //       "arrayProperties": {
    //         "index": number,
    //         "size": number,
    //         "statusSummary": {
    //           "string": number
    //         }
    //       },
    //       "attempts": [
    //         {
    //           "container": {
    //             "containerInstanceArn": "string",
    //             "exitCode": number,
    //             "logStreamName": "string",
    //             "networkInterfaces": [
    //               {
    //                 "attachmentId": "string",
    //                 "ipv6Address": "string",
    //                 "privateIpv4Address": "string"
    //               }
    //             ],
    //             "reason": "string",
    //             "taskArn": "string"
    //           },
    //           "startedAt": number,
    //           "statusReason": "string",
    //           "stoppedAt": number
    //         }
    //       ],
    //       "container": {
    //         "command": [
    //           "string"
    //         ],
    //         "containerInstanceArn": "string",
    //         "environment": [
    //           {
    //             "name": "string",
    //             "value": "string"
    //           }
    //         ],
    //         "executionRoleArn": "string",
    //         "exitCode": number,
    //         "fargatePlatformConfiguration": {
    //           "platformVersion": "string"
    //         },
    //         "image": "string",
    //         "instanceType": "string",
    //         "jobRoleArn": "string",
    //         "linuxParameters": {
    //           "devices": [
    //             {
    //               "containerPath": "string",
    //               "hostPath": "string",
    //               "permissions": [
    //                 "string"
    //               ]
    //             }
    //           ],
    //           "initProcessEnabled": boolean,
    //           "maxSwap": number,
    //           "sharedMemorySize": number,
    //           "swappiness": number,
    //           "tmpfs": [
    //             {
    //               "containerPath": "string",
    //               "mountOptions": [
    //                 "string"
    //               ],
    //               "size": number
    //             }
    //           ]
    //         },
    //         "logConfiguration": {
    //           "logDriver": "string",
    //           "options": {
    //             "string": "string"
    //           },
    //           "secretOptions": [
    //             {
    //               "name": "string",
    //               "valueFrom": "string"
    //             }
    //           ]
    //         },
    //         "logStreamName": "string",
    //         "memory": number,
    //         "mountPoints": [
    //           {
    //             "containerPath": "string",
    //             "readOnly": boolean,
    //             "sourceVolume": "string"
    //           }
    //         ],
    //         "networkConfiguration": {
    //           "assignPublicIp": "string"
    //         },
    //         "networkInterfaces": [
    //           {
    //             "attachmentId": "string",
    //             "ipv6Address": "string",
    //             "privateIpv4Address": "string"
    //           }
    //         ],
    //         "privileged": boolean,
    //         "readonlyRootFilesystem": boolean,
    //         "reason": "string",
    //         "resourceRequirements": [
    //           {
    //             "type": "string",
    //             "value": "string"
    //           }
    //         ],
    //         "secrets": [
    //           {
    //             "name": "string",
    //             "valueFrom": "string"
    //           }
    //         ],
    //         "taskArn": "string",
    //         "ulimits": [
    //           {
    //             "hardLimit": number,
    //             "name": "string",
    //             "softLimit": number
    //           }
    //         ],
    //         "user": "string",
    //         "vcpus": number,
    //         "volumes": [
    //           {
    //             "efsVolumeConfiguration": {
    //               "authorizationConfig": {
    //                 "accessPointId": "string",
    //                 "iam": "string"
    //               },
    //               "fileSystemId": "string",
    //               "rootDirectory": "string",
    //               "transitEncryption": "string",
    //               "transitEncryptionPort": number
    //             },
    //             "host": {
    //               "sourcePath": "string"
    //             },
    //             "name": "string"
    //           }
    //         ]
    //       },
    //       "createdAt": number,
    //       "dependsOn": [
    //         {
    //           "jobId": "string",
    //           "type": "string"
    //         }
    //       ],
    //       "jobArn": "string",
    //       "jobDefinition": "string",
    //       "jobId": "string",
    //       "jobName": "string",
    //       "jobQueue": "string",
    //       "nodeDetails": {
    //         "isMainNode": boolean,
    //         "nodeIndex": number
    //       },
    //       "nodeProperties": {
    //         "mainNode": number,
    //         "nodeRangeProperties": [
    //           {
    //             "container": {
    //               "command": [
    //                 "string"
    //               ],
    //               "environment": [
    //                 {
    //                   "name": "string",
    //                   "value": "string"
    //                 }
    //               ],
    //               "executionRoleArn": "string",
    //               "fargatePlatformConfiguration": {
    //                 "platformVersion": "string"
    //               },
    //               "image": "string",
    //               "instanceType": "string",
    //               "jobRoleArn": "string",
    //               "linuxParameters": {
    //                 "devices": [
    //                   {
    //                     "containerPath": "string",
    //                     "hostPath": "string",
    //                     "permissions": [
    //                       "string"
    //                     ]
    //                   }
    //                 ],
    //                 "initProcessEnabled": boolean,
    //                 "maxSwap": number,
    //                 "sharedMemorySize": number,
    //                 "swappiness": number,
    //                 "tmpfs": [
    //                   {
    //                     "containerPath": "string",
    //                     "mountOptions": [
    //                       "string"
    //                     ],
    //                     "size": number
    //                   }
    //                 ]
    //               },
    //               "logConfiguration": {
    //                 "logDriver": "string",
    //                 "options": {
    //                   "string": "string"
    //                 },
    //                 "secretOptions": [
    //                   {
    //                     "name": "string",
    //                     "valueFrom": "string"
    //                   }
    //                 ]
    //               },
    //               "memory": number,
    //               "mountPoints": [
    //                 {
    //                   "containerPath": "string",
    //                   "readOnly": boolean,
    //                   "sourceVolume": "string"
    //                 }
    //               ],
    //               "networkConfiguration": {
    //                 "assignPublicIp": "string"
    //               },
    //               "privileged": boolean,
    //               "readonlyRootFilesystem": boolean,
    //               "resourceRequirements": [
    //                 {
    //                   "type": "string",
    //                   "value": "string"
    //                 }
    //               ],
    //               "secrets": [
    //                 {
    //                   "name": "string",
    //                   "valueFrom": "string"
    //                 }
    //               ],
    //               "ulimits": [
    //                 {
    //                   "hardLimit": number,
    //                   "name": "string",
    //                   "softLimit": number
    //                 }
    //               ],
    //               "user": "string",
    //               "vcpus": number,
    //               "volumes": [
    //                 {
    //                   "efsVolumeConfiguration": {
    //                     "authorizationConfig": {
    //                       "accessPointId": "string",
    //                       "iam": "string"
    //                     },
    //                     "fileSystemId": "string",
    //                     "rootDirectory": "string",
    //                     "transitEncryption": "string",
    //                     "transitEncryptionPort": number
    //                   },
    //                   "host": {
    //                     "sourcePath": "string"
    //                   },
    //                   "name": "string"
    //                 }
    //               ]
    //             },
    //             "targetNodes": "string"
    //           }
    //         ],
    //         "numNodes": number
    //       },
    //       "parameters": {
    //         "string": "string"
    //       },
    //       "platformCapabilities": [
    //         "string"
    //       ],
    //       "propagateTags": boolean,
    //       "retryStrategy": {
    //         "attempts": number,
    //         "evaluateOnExit": [
    //           {
    //             "action": "string",
    //             "onExitCode": "string",
    //             "onReason": "string",
    //             "onStatusReason": "string"
    //           }
    //         ]
    //       },
    //       "schedulingPriority": number,
    //       "shareIdentifier": "string",
    //       "startedAt": number,
    //       "status": "string",
    //       "statusReason": "string",
    //       "stoppedAt": number,
    //       "tags": {
    //         "string": "string"
    //       },
    //       "timeout": {
    //         "attemptDurationSeconds": number
    //       }
    //     }
    //   ]
    // }

    rest.DisposeRest()
    authAws.DisposeAuthAws()
    json.DisposeJsonObject()
    sbRequestBody.DisposeStringBuilder()
    sbResponseBody.DisposeStringBuilder()
    jResp.DisposeJsonObject()