
commonMain.aws.sdk.kotlin.services.kafkaconnect.serde.CreateConnectorOperationSerializer.kt Maven / Gradle / Ivy
// Code generated by smithy-kotlin-codegen. DO NOT EDIT!
package aws.sdk.kotlin.services.kafkaconnect.serde
import aws.sdk.kotlin.services.kafkaconnect.model.Capacity
import aws.sdk.kotlin.services.kafkaconnect.model.CreateConnectorRequest
import aws.sdk.kotlin.services.kafkaconnect.model.KafkaCluster
import aws.sdk.kotlin.services.kafkaconnect.model.KafkaClusterClientAuthentication
import aws.sdk.kotlin.services.kafkaconnect.model.KafkaClusterEncryptionInTransit
import aws.sdk.kotlin.services.kafkaconnect.model.LogDelivery
import aws.sdk.kotlin.services.kafkaconnect.model.Plugin
import aws.sdk.kotlin.services.kafkaconnect.model.WorkerConfiguration
import aws.smithy.kotlin.runtime.http.HttpBody
import aws.smithy.kotlin.runtime.http.HttpMethod
import aws.smithy.kotlin.runtime.http.operation.HttpSerialize
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 CreateConnectorOperationSerializer: HttpSerialize {
override suspend fun serialize(context: ExecutionContext, input: CreateConnectorRequest): HttpRequestBuilder {
val builder = HttpRequestBuilder()
builder.method = HttpMethod.POST
builder.url {
path = "/v1/connectors"
}
val payload = serializeCreateConnectorOperationBody(context, input)
builder.body = HttpBody.fromBytes(payload)
if (builder.body !is HttpBody.Empty) {
builder.headers.setMissing("Content-Type", "application/json")
}
return builder
}
}
private fun serializeCreateConnectorOperationBody(context: ExecutionContext, input: CreateConnectorRequest): ByteArray {
val serializer = JsonSerializer()
val CAPACITY_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Struct, JsonSerialName("capacity"))
val CONNECTORCONFIGURATION_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Map, JsonSerialName("connectorConfiguration"))
val CONNECTORDESCRIPTION_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("connectorDescription"))
val CONNECTORNAME_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("connectorName"))
val KAFKACLUSTER_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Struct, JsonSerialName("kafkaCluster"))
val KAFKACLUSTERCLIENTAUTHENTICATION_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Struct, JsonSerialName("kafkaClusterClientAuthentication"))
val KAFKACLUSTERENCRYPTIONINTRANSIT_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Struct, JsonSerialName("kafkaClusterEncryptionInTransit"))
val KAFKACONNECTVERSION_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("kafkaConnectVersion"))
val LOGDELIVERY_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Struct, JsonSerialName("logDelivery"))
val PLUGINS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.List, JsonSerialName("plugins"))
val SERVICEEXECUTIONROLEARN_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("serviceExecutionRoleArn"))
val WORKERCONFIGURATION_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Struct, JsonSerialName("workerConfiguration"))
val OBJ_DESCRIPTOR = SdkObjectDescriptor.build {
field(CAPACITY_DESCRIPTOR)
field(CONNECTORCONFIGURATION_DESCRIPTOR)
field(CONNECTORDESCRIPTION_DESCRIPTOR)
field(CONNECTORNAME_DESCRIPTOR)
field(KAFKACLUSTER_DESCRIPTOR)
field(KAFKACLUSTERCLIENTAUTHENTICATION_DESCRIPTOR)
field(KAFKACLUSTERENCRYPTIONINTRANSIT_DESCRIPTOR)
field(KAFKACONNECTVERSION_DESCRIPTOR)
field(LOGDELIVERY_DESCRIPTOR)
field(PLUGINS_DESCRIPTOR)
field(SERVICEEXECUTIONROLEARN_DESCRIPTOR)
field(WORKERCONFIGURATION_DESCRIPTOR)
}
serializer.serializeStruct(OBJ_DESCRIPTOR) {
input.capacity?.let { field(CAPACITY_DESCRIPTOR, it, ::serializeCapacityDocument) }
mapField(CONNECTORCONFIGURATION_DESCRIPTOR) {
input.connectorConfiguration.forEach { (key, value) -> entry(key, value) }
}
input.connectorDescription?.let { field(CONNECTORDESCRIPTION_DESCRIPTOR, it) }
field(CONNECTORNAME_DESCRIPTOR, input.connectorName)
input.kafkaCluster?.let { field(KAFKACLUSTER_DESCRIPTOR, it, ::serializeKafkaClusterDocument) }
input.kafkaClusterClientAuthentication?.let { field(KAFKACLUSTERCLIENTAUTHENTICATION_DESCRIPTOR, it, ::serializeKafkaClusterClientAuthenticationDocument) }
input.kafkaClusterEncryptionInTransit?.let { field(KAFKACLUSTERENCRYPTIONINTRANSIT_DESCRIPTOR, it, ::serializeKafkaClusterEncryptionInTransitDocument) }
field(KAFKACONNECTVERSION_DESCRIPTOR, input.kafkaConnectVersion)
input.logDelivery?.let { field(LOGDELIVERY_DESCRIPTOR, it, ::serializeLogDeliveryDocument) }
listField(PLUGINS_DESCRIPTOR) {
for (el0 in input.plugins) {
serializeSdkSerializable(asSdkSerializable(el0, ::serializePluginDocument))
}
}
field(SERVICEEXECUTIONROLEARN_DESCRIPTOR, input.serviceExecutionRoleArn)
input.workerConfiguration?.let { field(WORKERCONFIGURATION_DESCRIPTOR, it, ::serializeWorkerConfigurationDocument) }
}
return serializer.toByteArray()
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy