commonMain.aws.sdk.kotlin.services.secretsmanager.serde.CreateSecretOperationSerializer.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of secretsmanager-jvm Show documentation
Show all versions of secretsmanager-jvm Show documentation
The AWS SDK for Kotlin client for Secrets Manager
The newest version!
// Code generated by smithy-kotlin-codegen. DO NOT EDIT!
package aws.sdk.kotlin.services.secretsmanager.serde
import aws.sdk.kotlin.services.secretsmanager.model.CreateSecretRequest
import aws.sdk.kotlin.services.secretsmanager.model.ReplicaRegionType
import aws.sdk.kotlin.services.secretsmanager.model.Tag
import aws.smithy.kotlin.runtime.client.idempotencyTokenProvider
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
import aws.smithy.kotlin.runtime.text.encoding.encodeBase64String
internal class CreateSecretOperationSerializer: HttpSerializer.NonStreaming {
override fun serialize(context: ExecutionContext, input: CreateSecretRequest): HttpRequestBuilder {
val builder = HttpRequestBuilder()
builder.method = HttpMethod.POST
builder.url {
path.encoded = "/"
}
val payload = serializeCreateSecretOperationBody(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 serializeCreateSecretOperationBody(context: ExecutionContext, input: CreateSecretRequest): ByteArray {
val serializer = JsonSerializer()
val ADDREPLICAREGIONS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.List, JsonSerialName("AddReplicaRegions"))
val CLIENTREQUESTTOKEN_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("ClientRequestToken"))
val DESCRIPTION_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("Description"))
val FORCEOVERWRITEREPLICASECRET_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Boolean, JsonSerialName("ForceOverwriteReplicaSecret"))
val KMSKEYID_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("KmsKeyId"))
val NAME_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("Name"))
val SECRETBINARY_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Blob, JsonSerialName("SecretBinary"))
val SECRETSTRING_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("SecretString"))
val TAGS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.List, JsonSerialName("Tags"))
val OBJ_DESCRIPTOR = SdkObjectDescriptor.build {
field(ADDREPLICAREGIONS_DESCRIPTOR)
field(CLIENTREQUESTTOKEN_DESCRIPTOR)
field(DESCRIPTION_DESCRIPTOR)
field(FORCEOVERWRITEREPLICASECRET_DESCRIPTOR)
field(KMSKEYID_DESCRIPTOR)
field(NAME_DESCRIPTOR)
field(SECRETBINARY_DESCRIPTOR)
field(SECRETSTRING_DESCRIPTOR)
field(TAGS_DESCRIPTOR)
}
serializer.serializeStruct(OBJ_DESCRIPTOR) {
if (input.addReplicaRegions != null) {
listField(ADDREPLICAREGIONS_DESCRIPTOR) {
for (el0 in input.addReplicaRegions) {
serializeSdkSerializable(asSdkSerializable(el0, ::serializeReplicaRegionTypeDocument))
}
}
}
input.clientRequestToken?.let { field(CLIENTREQUESTTOKEN_DESCRIPTOR, it) } ?: field(CLIENTREQUESTTOKEN_DESCRIPTOR, context.idempotencyTokenProvider.generateToken())
input.description?.let { field(DESCRIPTION_DESCRIPTOR, it) }
input.forceOverwriteReplicaSecret?.let { field(FORCEOVERWRITEREPLICASECRET_DESCRIPTOR, it) }
input.kmsKeyId?.let { field(KMSKEYID_DESCRIPTOR, it) }
input.name?.let { field(NAME_DESCRIPTOR, it) }
input.secretBinary?.let { field(SECRETBINARY_DESCRIPTOR, it.encodeBase64String()) }
input.secretString?.let { field(SECRETSTRING_DESCRIPTOR, it) }
if (input.tags != null) {
listField(TAGS_DESCRIPTOR) {
for (el0 in input.tags) {
serializeSdkSerializable(asSdkSerializable(el0, ::serializeTagDocument))
}
}
}
}
return serializer.toByteArray()
}