Chilkat Online Tools

DescribeJobDefinitions VBScript Example

AWS Batch

Dim fso, outFile
Set fso = CreateObject("Scripting.FileSystemObject")
Set outFile = fso.CreateTextFile("output.txt", True)

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

set rest = CreateObject("Chilkat_9_5_0.Rest")

set authAws = CreateObject("Chilkat_9_5_0.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 = "batch"
' SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
success = 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,1,1)
If (success <> 1) Then
    outFile.WriteLine("ConnectFailReason: " & rest.ConnectFailReason)
    outFile.WriteLine(rest.LastErrorText)
    WScript.Quit
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

set json = CreateObject("Chilkat_9_5_0.JsonObject")
success = json.UpdateString("jobDefinitionName","string")
success = json.UpdateString("jobDefinitions[0]","string")
success = json.UpdateInt("maxResults",123)
success = json.UpdateString("nextToken","string")
success = json.UpdateString("status","string")

' The JSON request body created by the above code:

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

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

set sbRequestBody = CreateObject("Chilkat_9_5_0.StringBuilder")
success = json.EmitSb(sbRequestBody)
set sbResponseBody = CreateObject("Chilkat_9_5_0.StringBuilder")
success = rest.FullRequestSb("POST","/v1/describejobdefinitions",sbRequestBody,sbResponseBody)
If (success <> 1) Then
    outFile.WriteLine(rest.LastErrorText)
    WScript.Quit
End If

respStatusCode = rest.ResponseStatusCode
outFile.WriteLine("response status code = " & respStatusCode)
If (respStatusCode <> 200) Then
    outFile.WriteLine("Response Header:")
    outFile.WriteLine(rest.ResponseHeader)
    outFile.WriteLine("Response Body:")
    outFile.WriteLine(sbResponseBody.GetAsString())
    WScript.Quit
End If

set jResp = CreateObject("Chilkat_9_5_0.JsonObject")
success = 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")
Do While i < count_i
    jResp.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")
    Do While j < count_j
        jResp.J = j
        strVal = jResp.StringOf("jobDefinitions[i].containerProperties.command[j]")
        j = j + 1
    Loop
    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.environment")
    Do While j < count_j
        jResp.J = j
        name = jResp.StringOf("jobDefinitions[i].containerProperties.environment[j].name")
        value = jResp.StringOf("jobDefinitions[i].containerProperties.environment[j].value")
        j = j + 1
    Loop
    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.linuxParameters.devices")
    Do While j < count_j
        jResp.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")
        Do While k < count_k
            jResp.K = k
            strVal = jResp.StringOf("jobDefinitions[i].containerProperties.linuxParameters.devices[j].permissions[k]")
            k = k + 1
        Loop
        j = j + 1
    Loop
    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.linuxParameters.tmpfs")
    Do While j < count_j
        jResp.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")
        Do While k < count_k
            jResp.K = k
            strVal = jResp.StringOf("jobDefinitions[i].containerProperties.linuxParameters.tmpfs[j].mountOptions[k]")
            k = k + 1
        Loop
        j = j + 1
    Loop
    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.logConfiguration.secretOptions")
    Do While j < count_j
        jResp.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
    Loop
    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.mountPoints")
    Do While j < count_j
        jResp.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
    Loop
    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.resourceRequirements")
    Do While j < count_j
        jResp.J = j
        v_type = jResp.StringOf("jobDefinitions[i].containerProperties.resourceRequirements[j].type")
        value = jResp.StringOf("jobDefinitions[i].containerProperties.resourceRequirements[j].value")
        j = j + 1
    Loop
    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.secrets")
    Do While j < count_j
        jResp.J = j
        name = jResp.StringOf("jobDefinitions[i].containerProperties.secrets[j].name")
        valueFrom = jResp.StringOf("jobDefinitions[i].containerProperties.secrets[j].valueFrom")
        j = j + 1
    Loop
    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.ulimits")
    Do While j < count_j
        jResp.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
    Loop
    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].containerProperties.volumes")
    Do While j < count_j
        jResp.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
    Loop
    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties")
    Do While j < count_j
        jResp.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")
        Do While k < count_k
            jResp.K = k
            strVal = jResp.StringOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.command[k]")
            k = k + 1
        Loop
        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.environment")
        Do While k < count_k
            jResp.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
        Loop
        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.devices")
        Do While k < count_k
            jResp.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 Chilkat_9_5_0.JsonObject
            Set json1 = jResp.ObjectOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.devices[k]")
            i1 = 0
            count_i1 = json1.SizeOfArray("permissions")
            Do While i1 < count_i1
                json1.I = i1
                strVal = json1.StringOf("permissions[i]")
                i1 = i1 + 1
            Loop

            k = k + 1
        Loop
        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.tmpfs")
        Do While k < count_k
            jResp.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 Chilkat_9_5_0.JsonObject
            Set json1 = jResp.ObjectOf("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.linuxParameters.tmpfs[k]")
            i1 = 0
            count_i1 = json1.SizeOfArray("mountOptions")
            Do While i1 < count_i1
                json1.I = i1
                strVal = json1.StringOf("mountOptions[i]")
                i1 = i1 + 1
            Loop

            k = k + 1
        Loop
        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.logConfiguration.secretOptions")
        Do While k < count_k
            jResp.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
        Loop
        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.mountPoints")
        Do While k < count_k
            jResp.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
        Loop
        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.resourceRequirements")
        Do While k < count_k
            jResp.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
        Loop
        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.secrets")
        Do While k < count_k
            jResp.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
        Loop
        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.ulimits")
        Do While k < count_k
            jResp.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
        Loop
        k = 0
        count_k = jResp.SizeOfArray("jobDefinitions[i].nodeProperties.nodeRangeProperties[j].container.volumes")
        Do While k < count_k
            jResp.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
        Loop
        j = j + 1
    Loop
    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].platformCapabilities")
    Do While j < count_j
        jResp.J = j
        strVal = jResp.StringOf("jobDefinitions[i].platformCapabilities[j]")
        j = j + 1
    Loop
    j = 0
    count_j = jResp.SizeOfArray("jobDefinitions[i].retryStrategy.evaluateOnExit")
    Do While j < count_j
        jResp.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
    Loop
    i = i + 1
Loop

' 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"
' }

outFile.Close