DescribeJobDefinitions VBScript Example
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