commonMain.aws.sdk.kotlin.services.cloudsearch.model.LiteralOptions.kt Maven / Gradle / Ivy
// Code generated by smithy-kotlin-codegen. DO NOT EDIT!
package aws.sdk.kotlin.services.cloudsearch.model
/**
* Options for literal field. Present if `IndexFieldType` specifies the field is of type `literal`. All options are enabled by default.
*/
public class LiteralOptions private constructor(builder: Builder) {
/**
* A value to use for the field if the field isn't specified for a document.
*/
public val defaultValue: kotlin.String? = builder.defaultValue
/**
* Whether facet information can be returned for the field.
*/
public val facetEnabled: kotlin.Boolean? = builder.facetEnabled
/**
* Whether the contents of the field can be returned in the search results.
*/
public val returnEnabled: kotlin.Boolean? = builder.returnEnabled
/**
* Whether the contents of the field are searchable.
*/
public val searchEnabled: kotlin.Boolean? = builder.searchEnabled
/**
* Whether the field can be used to sort the search results.
*/
public val sortEnabled: kotlin.Boolean? = builder.sortEnabled
/**
* A string that represents the name of an index field. CloudSearch supports regular index fields as well as dynamic fields. A dynamic field's name defines a pattern that begins or ends with a wildcard. Any document fields that don't map to a regular index field but do match a dynamic field's pattern are configured with the dynamic field's indexing options.
*
* Regular field names begin with a letter and can contain the following characters: a-z (lowercase), 0-9, and _ (underscore). Dynamic field names must begin or end with a wildcard (*). The wildcard can also be the only character in a dynamic field name. Multiple wildcards, and wildcards embedded within a string are not supported.
*
* The name `score` is reserved and cannot be used as a field name. To reference a document's ID, you can use the name `_id`.
*/
public val sourceField: kotlin.String? = builder.sourceField
public companion object {
public operator fun invoke(block: Builder.() -> kotlin.Unit): aws.sdk.kotlin.services.cloudsearch.model.LiteralOptions = Builder().apply(block).build()
}
override fun toString(): kotlin.String = buildString {
append("LiteralOptions(")
append("defaultValue=$defaultValue,")
append("facetEnabled=$facetEnabled,")
append("returnEnabled=$returnEnabled,")
append("searchEnabled=$searchEnabled,")
append("sortEnabled=$sortEnabled,")
append("sourceField=$sourceField")
append(")")
}
override fun hashCode(): kotlin.Int {
var result = defaultValue?.hashCode() ?: 0
result = 31 * result + (facetEnabled?.hashCode() ?: 0)
result = 31 * result + (returnEnabled?.hashCode() ?: 0)
result = 31 * result + (searchEnabled?.hashCode() ?: 0)
result = 31 * result + (sortEnabled?.hashCode() ?: 0)
result = 31 * result + (sourceField?.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 LiteralOptions
if (defaultValue != other.defaultValue) return false
if (facetEnabled != other.facetEnabled) return false
if (returnEnabled != other.returnEnabled) return false
if (searchEnabled != other.searchEnabled) return false
if (sortEnabled != other.sortEnabled) return false
if (sourceField != other.sourceField) return false
return true
}
public inline fun copy(block: Builder.() -> kotlin.Unit = {}): aws.sdk.kotlin.services.cloudsearch.model.LiteralOptions = Builder(this).apply(block).build()
public class Builder {
/**
* A value to use for the field if the field isn't specified for a document.
*/
public var defaultValue: kotlin.String? = null
/**
* Whether facet information can be returned for the field.
*/
public var facetEnabled: kotlin.Boolean? = null
/**
* Whether the contents of the field can be returned in the search results.
*/
public var returnEnabled: kotlin.Boolean? = null
/**
* Whether the contents of the field are searchable.
*/
public var searchEnabled: kotlin.Boolean? = null
/**
* Whether the field can be used to sort the search results.
*/
public var sortEnabled: kotlin.Boolean? = null
/**
* A string that represents the name of an index field. CloudSearch supports regular index fields as well as dynamic fields. A dynamic field's name defines a pattern that begins or ends with a wildcard. Any document fields that don't map to a regular index field but do match a dynamic field's pattern are configured with the dynamic field's indexing options.
*
* Regular field names begin with a letter and can contain the following characters: a-z (lowercase), 0-9, and _ (underscore). Dynamic field names must begin or end with a wildcard (*). The wildcard can also be the only character in a dynamic field name. Multiple wildcards, and wildcards embedded within a string are not supported.
*
* The name `score` is reserved and cannot be used as a field name. To reference a document's ID, you can use the name `_id`.
*/
public var sourceField: kotlin.String? = null
@PublishedApi
internal constructor()
@PublishedApi
internal constructor(x: aws.sdk.kotlin.services.cloudsearch.model.LiteralOptions) : this() {
this.defaultValue = x.defaultValue
this.facetEnabled = x.facetEnabled
this.returnEnabled = x.returnEnabled
this.searchEnabled = x.searchEnabled
this.sortEnabled = x.sortEnabled
this.sourceField = x.sourceField
}
@PublishedApi
internal fun build(): aws.sdk.kotlin.services.cloudsearch.model.LiteralOptions = LiteralOptions(this)
internal fun correctErrors(): Builder {
return this
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy