
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