
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