commonMain.aws.sdk.kotlin.services.glue.serde.DeleteColumnStatisticsForPartitionOperationSerializer.kt Maven / Gradle / Ivy
// Code generated by smithy-kotlin-codegen. DO NOT EDIT!
package aws.sdk.kotlin.services.glue.serde
import aws.sdk.kotlin.services.glue.model.DeleteColumnStatisticsForPartitionRequest
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
internal class DeleteColumnStatisticsForPartitionOperationSerializer: HttpSerializer.NonStreaming {
override fun serialize(context: ExecutionContext, input: DeleteColumnStatisticsForPartitionRequest): HttpRequestBuilder {
val builder = HttpRequestBuilder()
builder.method = HttpMethod.POST
builder.url {
path.encoded = "/"
}
val payload = serializeDeleteColumnStatisticsForPartitionOperationBody(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 serializeDeleteColumnStatisticsForPartitionOperationBody(context: ExecutionContext, input: DeleteColumnStatisticsForPartitionRequest): ByteArray {
val serializer = JsonSerializer()
val CATALOGID_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("CatalogId"))
val COLUMNNAME_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("ColumnName"))
val DATABASENAME_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("DatabaseName"))
val PARTITIONVALUES_DESCRIPTOR = SdkFieldDescriptor(SerialKind.List, JsonSerialName("PartitionValues"))
val TABLENAME_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("TableName"))
val OBJ_DESCRIPTOR = SdkObjectDescriptor.build {
field(CATALOGID_DESCRIPTOR)
field(COLUMNNAME_DESCRIPTOR)
field(DATABASENAME_DESCRIPTOR)
field(PARTITIONVALUES_DESCRIPTOR)
field(TABLENAME_DESCRIPTOR)
}
serializer.serializeStruct(OBJ_DESCRIPTOR) {
input.catalogId?.let { field(CATALOGID_DESCRIPTOR, it) }
input.columnName?.let { field(COLUMNNAME_DESCRIPTOR, it) }
input.databaseName?.let { field(DATABASENAME_DESCRIPTOR, it) }
if (input.partitionValues != null) {
listField(PARTITIONVALUES_DESCRIPTOR) {
for (el0 in input.partitionValues) {
serializeString(el0)
}
}
}
input.tableName?.let { field(TABLENAME_DESCRIPTOR, it) }
}
return serializer.toByteArray()
}