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

commonMain.aws.sdk.kotlin.services.acmpca.serde.CreateCertificateAuthorityOperationSerializer.kt Maven / Gradle / Ivy

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

package aws.sdk.kotlin.services.acmpca.serde

import aws.sdk.kotlin.services.acmpca.model.CertificateAuthorityConfiguration
import aws.sdk.kotlin.services.acmpca.model.CertificateAuthorityType
import aws.sdk.kotlin.services.acmpca.model.CertificateAuthorityUsageMode
import aws.sdk.kotlin.services.acmpca.model.CreateCertificateAuthorityRequest
import aws.sdk.kotlin.services.acmpca.model.KeyStorageSecurityStandard
import aws.sdk.kotlin.services.acmpca.model.RevocationConfiguration
import aws.sdk.kotlin.services.acmpca.model.Tag
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 CreateCertificateAuthorityOperationSerializer: HttpSerialize {
    override suspend fun serialize(context: ExecutionContext, input: CreateCertificateAuthorityRequest): HttpRequestBuilder {
        val builder = HttpRequestBuilder()
        builder.method = HttpMethod.POST

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

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

private fun serializeCreateCertificateAuthorityOperationBody(context: ExecutionContext, input: CreateCertificateAuthorityRequest): ByteArray {
    val serializer = JsonSerializer()
    val CERTIFICATEAUTHORITYCONFIGURATION_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Struct, JsonSerialName("CertificateAuthorityConfiguration"))
    val CERTIFICATEAUTHORITYTYPE_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Enum, JsonSerialName("CertificateAuthorityType"))
    val IDEMPOTENCYTOKEN_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("IdempotencyToken"))
    val KEYSTORAGESECURITYSTANDARD_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Enum, JsonSerialName("KeyStorageSecurityStandard"))
    val REVOCATIONCONFIGURATION_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Struct, JsonSerialName("RevocationConfiguration"))
    val TAGS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.List, JsonSerialName("Tags"))
    val USAGEMODE_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Enum, JsonSerialName("UsageMode"))
    val OBJ_DESCRIPTOR = SdkObjectDescriptor.build {
        field(CERTIFICATEAUTHORITYCONFIGURATION_DESCRIPTOR)
        field(CERTIFICATEAUTHORITYTYPE_DESCRIPTOR)
        field(IDEMPOTENCYTOKEN_DESCRIPTOR)
        field(KEYSTORAGESECURITYSTANDARD_DESCRIPTOR)
        field(REVOCATIONCONFIGURATION_DESCRIPTOR)
        field(TAGS_DESCRIPTOR)
        field(USAGEMODE_DESCRIPTOR)
    }

    serializer.serializeStruct(OBJ_DESCRIPTOR) {
        input.certificateAuthorityConfiguration?.let { field(CERTIFICATEAUTHORITYCONFIGURATION_DESCRIPTOR, it, ::serializeCertificateAuthorityConfigurationDocument) }
        input.certificateAuthorityType?.let { field(CERTIFICATEAUTHORITYTYPE_DESCRIPTOR, it.value) }
        input.idempotencyToken?.let { field(IDEMPOTENCYTOKEN_DESCRIPTOR, it) }
        input.keyStorageSecurityStandard?.let { field(KEYSTORAGESECURITYSTANDARD_DESCRIPTOR, it.value) }
        input.revocationConfiguration?.let { field(REVOCATIONCONFIGURATION_DESCRIPTOR, it, ::serializeRevocationConfigurationDocument) }
        if (input.tags != null) {
            listField(TAGS_DESCRIPTOR) {
                for (el0 in input.tags) {
                    serializeSdkSerializable(asSdkSerializable(el0, ::serializeTagDocument))
                }
            }
        }
        input.usageMode?.let { field(USAGEMODE_DESCRIPTOR, it.value) }
    }
    return serializer.toByteArray()
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy