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

commonMain.aws.sdk.kotlin.services.kafka.serde.CreateClusterOperationSerializer.kt Maven / Gradle / Ivy

// Code generated by smithy-kotlin-codegen. DO NOT EDIT!

package aws.sdk.kotlin.services.kafka.serde

import aws.sdk.kotlin.services.kafka.model.BrokerNodeGroupInfo
import aws.sdk.kotlin.services.kafka.model.ClientAuthentication
import aws.sdk.kotlin.services.kafka.model.ConfigurationInfo
import aws.sdk.kotlin.services.kafka.model.CreateClusterRequest
import aws.sdk.kotlin.services.kafka.model.EncryptionInfo
import aws.sdk.kotlin.services.kafka.model.EnhancedMonitoring
import aws.sdk.kotlin.services.kafka.model.LoggingInfo
import aws.sdk.kotlin.services.kafka.model.OpenMonitoringInfo
import aws.sdk.kotlin.services.kafka.model.StorageMode
import aws.smithy.kotlin.runtime.http.HttpBody
import aws.smithy.kotlin.runtime.http.HttpMethod
import aws.smithy.kotlin.runtime.http.operation.HttpSerializer
import aws.smithy.kotlin.runtime.http.request.HttpRequestBuilder
import aws.smithy.kotlin.runtime.http.request.url
import aws.smithy.kotlin.runtime.operation.ExecutionContext
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.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.json.JsonSerializer
import aws.smithy.kotlin.runtime.serde.serializeList
import aws.smithy.kotlin.runtime.serde.serializeMap
import aws.smithy.kotlin.runtime.serde.serializeStruct


internal class CreateClusterOperationSerializer: HttpSerializer.NonStreaming {
    override fun serialize(context: ExecutionContext, input: CreateClusterRequest): HttpRequestBuilder {
        val builder = HttpRequestBuilder()
        builder.method = HttpMethod.POST

        builder.url {
            path.encoded = "/v1/clusters"
        }

        val payload = serializeCreateClusterOperationBody(context, input)
        builder.body = HttpBody.fromBytes(payload)
        if (builder.body !is HttpBody.Empty) {
            builder.headers.setMissing("Content-Type", "application/json")
        }
        return builder
    }
}

private fun serializeCreateClusterOperationBody(context: ExecutionContext, input: CreateClusterRequest): ByteArray {
    val serializer = JsonSerializer()
    val BROKERNODEGROUPINFO_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Struct, JsonSerialName("brokerNodeGroupInfo"))
    val CLIENTAUTHENTICATION_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Struct, JsonSerialName("clientAuthentication"))
    val CLUSTERNAME_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("clusterName"))
    val CONFIGURATIONINFO_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Struct, JsonSerialName("configurationInfo"))
    val ENCRYPTIONINFO_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Struct, JsonSerialName("encryptionInfo"))
    val ENHANCEDMONITORING_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Enum, JsonSerialName("enhancedMonitoring"))
    val KAFKAVERSION_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("kafkaVersion"))
    val LOGGINGINFO_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Struct, JsonSerialName("loggingInfo"))
    val NUMBEROFBROKERNODES_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Integer, JsonSerialName("numberOfBrokerNodes"))
    val OPENMONITORING_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Struct, JsonSerialName("openMonitoring"))
    val STORAGEMODE_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Enum, JsonSerialName("storageMode"))
    val TAGS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Map, JsonSerialName("tags"))
    val OBJ_DESCRIPTOR = SdkObjectDescriptor.build {
        field(BROKERNODEGROUPINFO_DESCRIPTOR)
        field(CLIENTAUTHENTICATION_DESCRIPTOR)
        field(CLUSTERNAME_DESCRIPTOR)
        field(CONFIGURATIONINFO_DESCRIPTOR)
        field(ENCRYPTIONINFO_DESCRIPTOR)
        field(ENHANCEDMONITORING_DESCRIPTOR)
        field(KAFKAVERSION_DESCRIPTOR)
        field(LOGGINGINFO_DESCRIPTOR)
        field(NUMBEROFBROKERNODES_DESCRIPTOR)
        field(OPENMONITORING_DESCRIPTOR)
        field(STORAGEMODE_DESCRIPTOR)
        field(TAGS_DESCRIPTOR)
    }

    serializer.serializeStruct(OBJ_DESCRIPTOR) {
        input.brokerNodeGroupInfo?.let { field(BROKERNODEGROUPINFO_DESCRIPTOR, it, ::serializeBrokerNodeGroupInfoDocument) }
        input.clientAuthentication?.let { field(CLIENTAUTHENTICATION_DESCRIPTOR, it, ::serializeClientAuthenticationDocument) }
        input.clusterName?.let { field(CLUSTERNAME_DESCRIPTOR, it) }
        input.configurationInfo?.let { field(CONFIGURATIONINFO_DESCRIPTOR, it, ::serializeConfigurationInfoDocument) }
        input.encryptionInfo?.let { field(ENCRYPTIONINFO_DESCRIPTOR, it, ::serializeEncryptionInfoDocument) }
        input.enhancedMonitoring?.let { field(ENHANCEDMONITORING_DESCRIPTOR, it.value) }
        input.kafkaVersion?.let { field(KAFKAVERSION_DESCRIPTOR, it) }
        input.loggingInfo?.let { field(LOGGINGINFO_DESCRIPTOR, it, ::serializeLoggingInfoDocument) }
        input.numberOfBrokerNodes?.let { field(NUMBEROFBROKERNODES_DESCRIPTOR, it) }
        input.openMonitoring?.let { field(OPENMONITORING_DESCRIPTOR, it, ::serializeOpenMonitoringInfoDocument) }
        input.storageMode?.let { field(STORAGEMODE_DESCRIPTOR, it.value) }
        if (input.tags != null) {
            mapField(TAGS_DESCRIPTOR) {
                input.tags.forEach { (key, value) ->
                    entry(key, value)
                }
            }
        }
    }
    return serializer.toByteArray()
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy