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

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