![JAR search and dependency download from the Maven repository](/logo.png)
com.pulumi.awsnative.batch.kotlin.outputs.GetJobDefinitionResult.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pulumi-aws-native-kotlin Show documentation
Show all versions of pulumi-aws-native-kotlin Show documentation
Build cloud applications and infrastructure by combining the safety and reliability of infrastructure as code with the power of the Kotlin programming language.
@file:Suppress("NAME_SHADOWING", "DEPRECATION")
package com.pulumi.awsnative.batch.kotlin.outputs
import kotlin.Any
import kotlin.Boolean
import kotlin.Int
import kotlin.String
import kotlin.Suppress
import kotlin.collections.List
/**
*
* @property containerProperties An object with properties specific to Amazon ECS-based jobs. When `containerProperties` is used in the job definition, it can't be used in addition to `eksProperties` , `ecsProperties` , or `nodeProperties` .
* @property ecsProperties An object that contains the properties for the Amazon ECS resources of a job.When `ecsProperties` is used in the job definition, it can't be used in addition to `containerProperties` , `eksProperties` , or `nodeProperties` .
* @property eksProperties An object with properties that are specific to Amazon EKS-based jobs. When `eksProperties` is used in the job definition, it can't be used in addition to `containerProperties` , `ecsProperties` , or `nodeProperties` .
* @property id
* @property nodeProperties An object with properties that are specific to multi-node parallel jobs. When `nodeProperties` is used in the job definition, it can't be used in addition to `containerProperties` , `ecsProperties` , or `eksProperties` .
* > If the job runs on Fargate resources, don't specify `nodeProperties` . Use `containerProperties` instead.
* @property parameters Default parameters or parameter substitution placeholders that are set in the job definition. Parameters are specified as a key-value pair mapping. Parameters in a `SubmitJob` request override any corresponding parameter defaults from the job definition. For more information about specifying parameters, see [Job definition parameters](https://docs.aws.amazon.com/batch/latest/userguide/job_definition_parameters.html) in the *AWS Batch User Guide* .
* Search the [CloudFormation User Guide](https://docs.aws.amazon.com/cloudformation/) for `AWS::Batch::JobDefinition` for more information about the expected schema for this property.
* @property platformCapabilities The platform capabilities required by the job definition. If no value is specified, it defaults to `EC2` . Jobs run on Fargate resources specify `FARGATE` .
* @property propagateTags Specifies whether to propagate the tags from the job or job definition to the corresponding Amazon ECS task. If no value is specified, the tags aren't propagated. Tags can only be propagated to the tasks when the tasks are created. For tags with the same name, job tags are given priority over job definitions tags. If the total number of combined tags from the job and job definition is over 50, the job is moved to the `FAILED` state.
* @property retryStrategy The retry strategy to use for failed jobs that are submitted with this job definition.
* @property schedulingPriority The scheduling priority of the job definition. This only affects jobs in job queues with a fair share policy. Jobs with a higher scheduling priority are scheduled before jobs with a lower scheduling priority.
* @property timeout The timeout time for jobs that are submitted with this job definition. After the amount of time you specify passes, AWS Batch terminates your jobs if they aren't finished.
* @property type The type of job definition. For more information about multi-node parallel jobs, see [Creating a multi-node parallel job definition](https://docs.aws.amazon.com/batch/latest/userguide/multi-node-job-def.html) in the *AWS Batch User Guide* .
* - If the value is `container` , then one of the following is required: `containerProperties` , `ecsProperties` , or `eksProperties` .
* - If the value is `multinode` , then `nodeProperties` is required.
* > If the job is run on Fargate resources, then `multinode` isn't supported.
*/
public data class GetJobDefinitionResult(
public val containerProperties: JobDefinitionContainerProperties? = null,
public val ecsProperties: JobDefinitionEcsProperties? = null,
public val eksProperties: JobDefinitionEksProperties? = null,
public val id: String? = null,
public val nodeProperties: JobDefinitionNodeProperties? = null,
public val parameters: Any? = null,
public val platformCapabilities: List? = null,
public val propagateTags: Boolean? = null,
public val retryStrategy: JobDefinitionRetryStrategy? = null,
public val schedulingPriority: Int? = null,
public val timeout: JobDefinitionTimeout? = null,
public val type: String? = null,
) {
public companion object {
public fun toKotlin(javaType: com.pulumi.awsnative.batch.outputs.GetJobDefinitionResult): GetJobDefinitionResult = GetJobDefinitionResult(
containerProperties = javaType.containerProperties().map({ args0 ->
args0.let({ args0 ->
com.pulumi.awsnative.batch.kotlin.outputs.JobDefinitionContainerProperties.Companion.toKotlin(args0)
})
}).orElse(null),
ecsProperties = javaType.ecsProperties().map({ args0 ->
args0.let({ args0 ->
com.pulumi.awsnative.batch.kotlin.outputs.JobDefinitionEcsProperties.Companion.toKotlin(args0)
})
}).orElse(null),
eksProperties = javaType.eksProperties().map({ args0 ->
args0.let({ args0 ->
com.pulumi.awsnative.batch.kotlin.outputs.JobDefinitionEksProperties.Companion.toKotlin(args0)
})
}).orElse(null),
id = javaType.id().map({ args0 -> args0 }).orElse(null),
nodeProperties = javaType.nodeProperties().map({ args0 ->
args0.let({ args0 ->
com.pulumi.awsnative.batch.kotlin.outputs.JobDefinitionNodeProperties.Companion.toKotlin(args0)
})
}).orElse(null),
parameters = javaType.parameters().map({ args0 -> args0 }).orElse(null),
platformCapabilities = javaType.platformCapabilities().map({ args0 -> args0 }),
propagateTags = javaType.propagateTags().map({ args0 -> args0 }).orElse(null),
retryStrategy = javaType.retryStrategy().map({ args0 ->
args0.let({ args0 ->
com.pulumi.awsnative.batch.kotlin.outputs.JobDefinitionRetryStrategy.Companion.toKotlin(args0)
})
}).orElse(null),
schedulingPriority = javaType.schedulingPriority().map({ args0 -> args0 }).orElse(null),
timeout = javaType.timeout().map({ args0 ->
args0.let({ args0 ->
com.pulumi.awsnative.batch.kotlin.outputs.JobDefinitionTimeout.Companion.toKotlin(args0)
})
}).orElse(null),
type = javaType.type().map({ args0 -> args0 }).orElse(null),
)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy