commonMain.aws.sdk.kotlin.services.databrew.model.ConditionExpression.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of databrew-jvm Show documentation
Show all versions of databrew-jvm Show documentation
The AWS Kotlin client for DataBrew
// Code generated by smithy-kotlin-codegen. DO NOT EDIT!
package aws.sdk.kotlin.services.databrew.model
/**
* Represents an individual condition that evaluates to true or false.
*
* Conditions are used with recipe actions. The action is only performed for column values where the condition evaluates to true.
*
* If a recipe requires more than one condition, then the recipe must specify multiple `ConditionExpression` elements. Each condition is applied to the rows in a dataset first, before the recipe action is performed.
*/
public class ConditionExpression private constructor(builder: Builder) {
/**
* A specific condition to apply to a recipe action. For more information, see [Recipe structure](https://docs.aws.amazon.com/databrew/latest/dg/recipes.html#recipes.structure) in the *Glue DataBrew Developer Guide*.
*/
public val condition: kotlin.String = requireNotNull(builder.condition) { "A non-null value must be provided for condition" }
/**
* A column to apply this condition to.
*/
public val targetColumn: kotlin.String = requireNotNull(builder.targetColumn) { "A non-null value must be provided for targetColumn" }
/**
* A value that the condition must evaluate to for the condition to succeed.
*/
public val value: kotlin.String? = builder.value
public companion object {
public operator fun invoke(block: Builder.() -> kotlin.Unit): aws.sdk.kotlin.services.databrew.model.ConditionExpression = Builder().apply(block).build()
}
override fun toString(): kotlin.String = buildString {
append("ConditionExpression(")
append("condition=$condition,")
append("targetColumn=$targetColumn,")
append("value=$value")
append(")")
}
override fun hashCode(): kotlin.Int {
var result = condition.hashCode()
result = 31 * result + (targetColumn.hashCode())
result = 31 * result + (value?.hashCode() ?: 0)
return result
}
override fun equals(other: kotlin.Any?): kotlin.Boolean {
if (this === other) return true
if (other == null || this::class != other::class) return false
other as ConditionExpression
if (condition != other.condition) return false
if (targetColumn != other.targetColumn) return false
if (value != other.value) return false
return true
}
public inline fun copy(block: Builder.() -> kotlin.Unit = {}): aws.sdk.kotlin.services.databrew.model.ConditionExpression = Builder(this).apply(block).build()
public class Builder {
/**
* A specific condition to apply to a recipe action. For more information, see [Recipe structure](https://docs.aws.amazon.com/databrew/latest/dg/recipes.html#recipes.structure) in the *Glue DataBrew Developer Guide*.
*/
public var condition: kotlin.String? = null
/**
* A column to apply this condition to.
*/
public var targetColumn: kotlin.String? = null
/**
* A value that the condition must evaluate to for the condition to succeed.
*/
public var value: kotlin.String? = null
@PublishedApi
internal constructor()
@PublishedApi
internal constructor(x: aws.sdk.kotlin.services.databrew.model.ConditionExpression) : this() {
this.condition = x.condition
this.targetColumn = x.targetColumn
this.value = x.value
}
@PublishedApi
internal fun build(): aws.sdk.kotlin.services.databrew.model.ConditionExpression = ConditionExpression(this)
internal fun correctErrors(): Builder {
if (condition == null) condition = ""
if (targetColumn == null) targetColumn = ""
return this
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy