Chilkat Online Tools

DescribeJobDefinitions Python Example

AWS Batch

import sys
import chilkat

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

rest = chilkat.CkRest()

authAws = chilkat.CkAuthAws()
authAws.put_AccessKey("AWS_ACCESS_KEY")
authAws.put_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.put_Region("us-west-2")
authAws.put_ServiceName("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):
    print("ConnectFailReason: " + str(rest.get_ConnectFailReason()))
    print(rest.lastErrorText())
    sys.exit()

# 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.CkJsonObject()
json.UpdateString("jobDefinitionName","string")
json.UpdateString("jobDefinitions[0]","string")
json.UpdateInt("maxResults",123)
json.UpdateString("nextToken","string")
json.UpdateString("status","string")

# The JSON request body created by the above code:

# {
#   "jobDefinitionName": "string",
#   "jobDefinitions": [
#     "string"
#   ],
#   "maxResults": number,
#   "nextToken": "string",
#   "status": "string"
# }

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

sbRequestBody = chilkat.CkStringBuilder()
json.EmitSb(sbRequestBody)
sbResponseBody = chilkat.CkStringBuilder()
success = rest.FullRequestSb("POST","/v1/describejobdefinitions",sbRequestBody,sbResponseBody)
if (success != True):
    print(rest.lastErrorText())
    sys.exit()

respStatusCode = rest.get_ResponseStatusCode()
print("response status code = " + str(respStatusCode))
if (respStatusCode != 200):
    print("Response Header:")
    print(rest.responseHeader())
    print("Response Body:")
    print(sbResponseBody.getAsString())
    sys.exit()

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

nextToken = jResp.stringOf("nextToken")
i = 0
count_i = jResp.SizeOfArray("jobDefinitions")
while i < count_i :
    jResp.put_I(i)
    ExecutionRoleArn = jResp.stringOf("jobDefinitions[i].containerProperties.executionRoleArn")
    PlatformVersion = jResp.stringOf("jobDefinitions[i].containerProperties.fargatePlatformConfiguration.platformVersion")
    Image = jResp.stringOf("jobDefinitions[i].containerProperties.image")
    InstanceType = jResp.stringOf("jobDefinitions[i].containerProperties.instanceType")
    JobRoleArn = jResp.stringOf("jobDefinitions[i].containerProperties.jobRoleArn")
    InitProcessEnabled = jResp.IntOf("jobDefinitions[i].containerProperties.linuxParameters.initProcessEnabled")
    MaxSwap = jResp.IntOf("jobDefinitions[i].containerProperties.linuxParameters.maxSwap")
    SharedMemorySize = jResp.IntOf("jobDefinitions[i].containerProperties.linuxParameters.sharedMemorySize")
    Swappiness = jResp.IntOf("jobDefinitions[i].containerProperties.linuxParameters.swappiness")
    LogDriver = jResp.stringOf("jobDefinitions[i].containerProperties.logConfiguration.logDriver")
    v_String = jResp.stringOf("jobDefinitions[i].containerProperties.logConfiguration.options.string")
    Memory = jResp.IntOf("jobDefinitions[i].containerProperties.memory")
    AssignPublicIp = jResp.stringOf("jobDefinitions[i].containerProperties.networkConfiguration.assignPublicIp")
    Privileged = jResp.IntOf("jobDefinitions[i].containerProperties.privileged")
    ReadonlyRootFilesystem = jResp.IntOf("jobDefinitions[i].containerProperties.readonlyRootFilesystem")
    User = jResp.stringOf("jobDefinitions[i].containerProperties.user")
    Vcpus = jResp.IntOf("jobDefinitions[i].containerProperties.vcpus")
    jobDefinitionArn = jResp.stringOf("jobDefinitions[i].jobDefinitionArn")
    jobDefinitionName = jResp.stringOf("jobDefinitions[i].jobDefinitionName")
    MainNode = jResp.IntOf("jobDefinitions[i].nodeProperties.mainNode")
    NumNodes = jResp.IntOf("jobDefinitions[i].nodeProperties.numNodes")
    parametersString = jResp.stringOf("jobDefinitions[i].parameters.string")
    propagateTags = jResp.IntOf("jobDefinitions[i].propagateTags")
    Attempts = jResp.IntOf("jobDefinitions[i].retryStrategy.attempts")
    revision = jResp.IntOf("jobDefinitions[i].revision")
    schedulingPriority = jResp.IntOf("jobDefinitions[i].schedulingPriority")
    status = jResp.stringOf("jobDefinitions[i].status")
    tagsString = jResp.stringOf("jobDefinitions[i].tags.string")
    AttemptDurationSeconds = jResp.IntOf("jobDefinitions[i].timeout.attemptDurationSeconds")
    v_type = jResp.stringOf("jobDefinitions[i].type")
    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.command")
    while j < count_j :
        jResp.put_J(j)
        strVal = jResp.stringOf("jobDefinitions[i].containerProperties.command[j]")
        j = j + 1

    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.environment")
    while j < count_j :
        jResp.put_J(j)
        name = jResp.stringOf("jobDefinitions[i].containerProperties.environment[j].name")
        value = jResp.stringOf("jobDefinitions[i].containerProperties.environment[j].value")
        j = j + 1

    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.linuxParameters.devices")
    while j < count_j :
        jResp.put_J(j)
        containerPath = jResp.stringOf("jobDefinitions[i].containerProperties.linuxParameters.devices[j].containerPath")
        hostPath = jResp.stringOf("jobDefinitions[i].containerProperties.linuxParameters.devices[j].hostPath")
        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].containerProperties.linuxParameters.devices[j].permissions")
        while k < count_k :
            jResp.put_K(k)
            strVal = jResp.stringOf("jobDefinitions[i].containerProperties.linuxParameters.devices[j].permissions[k]")
            k = k + 1

        j = j + 1

    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.linuxParameters.tmpfs")
    while j < count_j :
        jResp.put_J(j)
        containerPath = jResp.stringOf("jobDefinitions[i].containerProperties.linuxParameters.tmpfs[j].containerPath")
        size = jResp.IntOf("jobDefinitions[i].containerProperties.linuxParameters.tmpfs[j].size")
        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].containerProperties.linuxParameters.tmpfs[j].mountOptions")
        while k < count_k :
            jResp.put_K(k)
            strVal = jResp.stringOf("jobDefinitions[i].containerProperties.linuxParameters.tmpfs[j].mountOptions[k]")
            k = k + 1

        j = j + 1

    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.logConfiguration.secretOptions")
    while j < count_j :
        jResp.put_J(j)
        name = jResp.stringOf("jobDefinitions[i].containerProperties.logConfiguration.secretOptions[j].name")
        valueFrom = jResp.stringOf("jobDefinitions[i].containerProperties.logConfiguration.secretOptions[j].valueFrom")
        j = j + 1

    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.mountPoints")
    while j < count_j :
        jResp.put_J(j)
        containerPath = jResp.stringOf("jobDefinitions[i].containerProperties.mountPoints[j].containerPath")
        readOnly = jResp.IntOf("jobDefinitions[i].containerProperties.mountPoints[j].readOnly")
        sourceVolume = jResp.stringOf("jobDefinitions[i].containerProperties.mountPoints[j].sourceVolume")
        j = j + 1

    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.resourceRequirements")
    while j < count_j :
        jResp.put_J(j)
        v_type = jResp.stringOf("jobDefinitions[i].containerProperties.resourceRequirements[j].type")
        value = jResp.stringOf("jobDefinitions[i].containerProperties.resourceRequirements[j].value")
        j = j + 1

    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.secrets")
    while j < count_j :
        jResp.put_J(j)
        name = jResp.stringOf("jobDefinitions[i].containerProperties.secrets[j].name")
        valueFrom = jResp.stringOf("jobDefinitions[i].containerProperties.secrets[j].valueFrom")
        j = j + 1

    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.ulimits")
    while j < count_j :
        jResp.put_J(j)
        hardLimit = jResp.IntOf("jobDefinitions[i].containerProperties.ulimits[j].hardLimit")
        name = jResp.stringOf("jobDefinitions[i].containerProperties.ulimits[j].name")
        softLimit = jResp.IntOf("jobDefinitions[i].containerProperties.ulimits[j].softLimit")
        j = j + 1

    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.volumes")
    while j < count_j :
        jResp.put_J(j)
        AccessPointId = jResp.stringOf("jobDefinitions[i].containerProperties.volumes[j].efsVolumeConfiguration.authorizationConfig.accessPointId")
        Iam = jResp.stringOf("jobDefinitions[i].containerProperties.volumes[j].efsVolumeConfiguration.authorizationConfig.iam")
        FileSystemId = jResp.stringOf("jobDefinitions[i].containerProperties.volumes[j].efsVolumeConfiguration.fileSystemId")
        RootDirectory = jResp.stringOf("jobDefinitions[i].containerProperties.volumes[j].efsVolumeConfiguration.rootDirectory")
        TransitEncryption = jResp.stringOf("jobDefinitions[i].containerProperties.volumes[j].efsVolumeConfiguration.transitEncryption")
        TransitEncryptionPort = jResp.IntOf("jobDefinitions[i].containerProperties.volumes[j].efsVolumeConfiguration.transitEncryptionPort")
        SourcePath = jResp.stringOf("jobDefinitions[i].containerProperties.volumes[j].host.sourcePath")
        name = jResp.stringOf("jobDefinitions[i].containerProperties.volumes[j].name")
        j = j + 1

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

        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.environment")
        while k < count_k :
            jResp.put_K(k)
            name = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.environment[k].name")
            value = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.environment[k].value")
            k = k + 1

        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.devices")
        while k < count_k :
            jResp.put_K(k)
            containerPath = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.devices[k].containerPath")
            hostPath = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.devices[k].hostPath")

            # json1 is a CkJsonObject
            json1 = jResp.ObjectOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.devices[k]")
            i1 = 0
            count_i1 = json1.SizeOfArray("permissions")
            while i1 < count_i1 :
                json1.put_I(i1)
                strVal = json1.stringOf("permissions[i]")
                i1 = i1 + 1

            k = k + 1

        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.tmpfs")
        while k < count_k :
            jResp.put_K(k)
            containerPath = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.tmpfs[k].containerPath")
            size = jResp.IntOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.tmpfs[k].size")

            # json1 is a CkJsonObject
            json1 = jResp.ObjectOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.tmpfs[k]")
            i1 = 0
            count_i1 = json1.SizeOfArray("mountOptions")
            while i1 < count_i1 :
                json1.put_I(i1)
                strVal = json1.stringOf("mountOptions[i]")
                i1 = i1 + 1

            k = k + 1

        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.logConfiguration.secretOptions")
        while k < count_k :
            jResp.put_K(k)
            name = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.logConfiguration.secretOptions[k].name")
            valueFrom = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.logConfiguration.secretOptions[k].valueFrom")
            k = k + 1

        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.mountPoints")
        while k < count_k :
            jResp.put_K(k)
            containerPath = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.mountPoints[k].containerPath")
            readOnly = jResp.IntOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.mountPoints[k].readOnly")
            sourceVolume = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.mountPoints[k].sourceVolume")
            k = k + 1

        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.resourceRequirements")
        while k < count_k :
            jResp.put_K(k)
            v_type = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.resourceRequirements[k].type")
            value = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.resourceRequirements[k].value")
            k = k + 1

        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.secrets")
        while k < count_k :
            jResp.put_K(k)
            name = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.secrets[k].name")
            valueFrom = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.secrets[k].valueFrom")
            k = k + 1

        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.ulimits")
        while k < count_k :
            jResp.put_K(k)
            hardLimit = jResp.IntOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.ulimits[k].hardLimit")
            name = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.ulimits[k].name")
            softLimit = jResp.IntOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.ulimits[k].softLimit")
            k = k + 1

        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.volumes")
        while k < count_k :
            jResp.put_K(k)
            AuthorizationConfigAccessPointId = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.volumes[k].efsVolumeConfiguration.authorizationConfig.accessPointId")
            AuthorizationConfigIam = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.volumes[k].efsVolumeConfiguration.authorizationConfig.iam")
            efsVolumeConfigurationFileSystemId = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.volumes[k].efsVolumeConfiguration.fileSystemId")
            efsVolumeConfigurationRootDirectory = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.volumes[k].efsVolumeConfiguration.rootDirectory")
            efsVolumeConfigurationTransitEncryption = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.volumes[k].efsVolumeConfiguration.transitEncryption")
            efsVolumeConfigurationTransitEncryptionPort = jResp.IntOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.volumes[k].efsVolumeConfiguration.transitEncryptionPort")
            hostSourcePath = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.volumes[k].host.sourcePath")
            name = jResp.stringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.volumes[k].name")
            k = k + 1

        j = j + 1

    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].platformCapabilities")
    while j < count_j :
        jResp.put_J(j)
        strVal = jResp.stringOf("jobDefinitions[i].platformCapabilities[j]")
        j = j + 1

    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].retryStrategy.evaluateOnExit")
    while j < count_j :
        jResp.put_J(j)
        action = jResp.stringOf("jobDefinitions[i].retryStrategy.evaluateOnExit[j].action")
        onExitCode = jResp.stringOf("jobDefinitions[i].retryStrategy.evaluateOnExit[j].onExitCode")
        onReason = jResp.stringOf("jobDefinitions[i].retryStrategy.evaluateOnExit[j].onReason")
        onStatusReason = jResp.stringOf("jobDefinitions[i].retryStrategy.evaluateOnExit[j].onStatusReason")
        j = j + 1

    i = i + 1

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

# {
#   "jobDefinitions": [
#     {
#       "containerProperties": {
#         "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"
#           }
#         ]
#       },
#       "jobDefinitionArn": "string",
#       "jobDefinitionName": "string",
#       "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"
#           }
#         ]
#       },
#       "revision": number,
#       "schedulingPriority": number,
#       "status": "string",
#       "tags": {
#         "string": "string"
#       },
#       "timeout": {
#         "attemptDurationSeconds": number
#       },
#       "type": "string"
#     }
#   ],
#   "nextToken": "string"
# }