All Downloads are FREE. Search and download functionalities are using the official Maven repository.

commonMain.aws.sdk.kotlin.services.cleanrooms.serde.AnalysisRuleAggregationDocumentSerializer.kt Maven / Gradle / Ivy

There is a newer version: 1.3.35
Show newest version
// Code generated by smithy-kotlin-codegen. DO NOT EDIT!

package aws.sdk.kotlin.services.cleanrooms.serde

import aws.sdk.kotlin.services.cleanrooms.model.AnalysisRuleAggregation
import aws.smithy.kotlin.runtime.serde.SdkFieldDescriptor
import aws.smithy.kotlin.runtime.serde.SdkObjectDescriptor
import aws.smithy.kotlin.runtime.serde.SerialKind
import aws.smithy.kotlin.runtime.serde.Serializer
import aws.smithy.kotlin.runtime.serde.asSdkSerializable
import aws.smithy.kotlin.runtime.serde.deserializeList
import aws.smithy.kotlin.runtime.serde.deserializeMap
import aws.smithy.kotlin.runtime.serde.deserializeStruct
import aws.smithy.kotlin.runtime.serde.field
import aws.smithy.kotlin.runtime.serde.json.JsonDeserializer
import aws.smithy.kotlin.runtime.serde.json.JsonSerialName
import aws.smithy.kotlin.runtime.serde.serializeList
import aws.smithy.kotlin.runtime.serde.serializeMap
import aws.smithy.kotlin.runtime.serde.serializeStruct

internal fun serializeAnalysisRuleAggregationDocument(serializer: Serializer, input: AnalysisRuleAggregation) {
    val ADDITIONALANALYSES_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Enum, JsonSerialName("additionalAnalyses"))
    val AGGREGATECOLUMNS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.List, JsonSerialName("aggregateColumns"))
    val ALLOWEDJOINOPERATORS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.List, JsonSerialName("allowedJoinOperators"))
    val DIMENSIONCOLUMNS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.List, JsonSerialName("dimensionColumns"))
    val JOINCOLUMNS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.List, JsonSerialName("joinColumns"))
    val JOINREQUIRED_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("joinRequired"))
    val OUTPUTCONSTRAINTS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.List, JsonSerialName("outputConstraints"))
    val SCALARFUNCTIONS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.List, JsonSerialName("scalarFunctions"))
    val OBJ_DESCRIPTOR = SdkObjectDescriptor.build {
        field(ADDITIONALANALYSES_DESCRIPTOR)
        field(AGGREGATECOLUMNS_DESCRIPTOR)
        field(ALLOWEDJOINOPERATORS_DESCRIPTOR)
        field(DIMENSIONCOLUMNS_DESCRIPTOR)
        field(JOINCOLUMNS_DESCRIPTOR)
        field(JOINREQUIRED_DESCRIPTOR)
        field(OUTPUTCONSTRAINTS_DESCRIPTOR)
        field(SCALARFUNCTIONS_DESCRIPTOR)
    }

    serializer.serializeStruct(OBJ_DESCRIPTOR) {
        listField(AGGREGATECOLUMNS_DESCRIPTOR) {
            for (el0 in input.aggregateColumns) {
                serializeSdkSerializable(asSdkSerializable(el0, ::serializeAggregateColumnDocument))
            }
        }
        listField(JOINCOLUMNS_DESCRIPTOR) {
            for (el0 in input.joinColumns) {
                serializeString(el0)
            }
        }
        input.joinRequired?.let { field(JOINREQUIRED_DESCRIPTOR, it.value) }
        if (input.allowedJoinOperators != null) {
            listField(ALLOWEDJOINOPERATORS_DESCRIPTOR) {
                for (el0 in input.allowedJoinOperators) {
                    serializeString(el0.value)
                }
            }
        }
        listField(DIMENSIONCOLUMNS_DESCRIPTOR) {
            for (el0 in input.dimensionColumns) {
                serializeString(el0)
            }
        }
        listField(SCALARFUNCTIONS_DESCRIPTOR) {
            for (el0 in input.scalarFunctions) {
                serializeString(el0.value)
            }
        }
        listField(OUTPUTCONSTRAINTS_DESCRIPTOR) {
            for (el0 in input.outputConstraints) {
                serializeSdkSerializable(asSdkSerializable(el0, ::serializeAggregationConstraintDocument))
            }
        }
        input.additionalAnalyses?.let { field(ADDITIONALANALYSES_DESCRIPTOR, it.value) }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy