
commonMain.aws.sdk.kotlin.services.kafka.serde.UpdateStorageOperationSerializer.kt Maven / Gradle / Ivy
// Code generated by smithy-kotlin-codegen. DO NOT EDIT!
package aws.sdk.kotlin.services.kafka.serde
import aws.sdk.kotlin.services.kafka.model.ProvisionedThroughput
import aws.sdk.kotlin.services.kafka.model.StorageMode
import aws.sdk.kotlin.services.kafka.model.UpdateStorageRequest
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.PercentEncoding
internal class UpdateStorageOperationSerializer: HttpSerializer.NonStreaming {
override fun serialize(context: ExecutionContext, input: UpdateStorageRequest): HttpRequestBuilder {
val builder = HttpRequestBuilder()
builder.method = HttpMethod.PUT
builder.url {
requireNotNull(input.clusterArn) { "clusterArn is bound to the URI and must not be null" }
path.encodedSegments {
add(PercentEncoding.Path.encode("v1"))
add(PercentEncoding.Path.encode("clusters"))
add(PercentEncoding.SmithyLabel.encode(input.clusterArn))
add(PercentEncoding.Path.encode("storage"))
}
}
val payload = serializeUpdateStorageOperationBody(context, input)
builder.body = HttpBody.fromBytes(payload)
if (builder.body !is HttpBody.Empty) {
builder.headers.setMissing("Content-Type", "application/json")
}
return builder
}
}
private fun serializeUpdateStorageOperationBody(context: ExecutionContext, input: UpdateStorageRequest): ByteArray {
val serializer = JsonSerializer()
val CURRENTVERSION_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("currentVersion"))
val PROVISIONEDTHROUGHPUT_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Struct, JsonSerialName("provisionedThroughput"))
val STORAGEMODE_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Enum, JsonSerialName("storageMode"))
val VOLUMESIZEGB_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Integer, JsonSerialName("volumeSizeGB"))
val OBJ_DESCRIPTOR = SdkObjectDescriptor.build {
field(CURRENTVERSION_DESCRIPTOR)
field(PROVISIONEDTHROUGHPUT_DESCRIPTOR)
field(STORAGEMODE_DESCRIPTOR)
field(VOLUMESIZEGB_DESCRIPTOR)
}
serializer.serializeStruct(OBJ_DESCRIPTOR) {
input.currentVersion?.let { field(CURRENTVERSION_DESCRIPTOR, it) }
input.provisionedThroughput?.let { field(PROVISIONEDTHROUGHPUT_DESCRIPTOR, it, ::serializeProvisionedThroughputDocument) }
input.storageMode?.let { field(STORAGEMODE_DESCRIPTOR, it.value) }
input.volumeSizeGb?.let { field(VOLUMESIZEGB_DESCRIPTOR, it) }
}
return serializer.toByteArray()
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy