
commonMain.aws.sdk.kotlin.services.pipes.serde.PipeSourceDynamoDbStreamParametersDocumentDeserializer.kt Maven / Gradle / Ivy
// Code generated by smithy-kotlin-codegen. DO NOT EDIT!
package aws.sdk.kotlin.services.pipes.serde
import aws.sdk.kotlin.services.pipes.model.DynamoDbStreamStartPosition
import aws.sdk.kotlin.services.pipes.model.OnPartialBatchItemFailureStreams
import aws.sdk.kotlin.services.pipes.model.PipeSourceDynamoDbStreamParameters
import aws.smithy.kotlin.runtime.serde.Deserializer
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.serializeList
import aws.smithy.kotlin.runtime.serde.serializeMap
import aws.smithy.kotlin.runtime.serde.serializeStruct
internal fun deserializePipeSourceDynamoDbStreamParametersDocument(deserializer: Deserializer): PipeSourceDynamoDbStreamParameters {
val builder = PipeSourceDynamoDbStreamParameters.Builder()
val BATCHSIZE_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Integer, JsonSerialName("BatchSize"))
val DEADLETTERCONFIG_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Struct, JsonSerialName("DeadLetterConfig"))
val MAXIMUMBATCHINGWINDOWINSECONDS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Integer, JsonSerialName("MaximumBatchingWindowInSeconds"))
val MAXIMUMRECORDAGEINSECONDS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Integer, JsonSerialName("MaximumRecordAgeInSeconds"))
val MAXIMUMRETRYATTEMPTS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Integer, JsonSerialName("MaximumRetryAttempts"))
val ONPARTIALBATCHITEMFAILURE_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("OnPartialBatchItemFailure"))
val PARALLELIZATIONFACTOR_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Integer, JsonSerialName("ParallelizationFactor"))
val STARTINGPOSITION_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("StartingPosition"))
val OBJ_DESCRIPTOR = SdkObjectDescriptor.build {
field(BATCHSIZE_DESCRIPTOR)
field(DEADLETTERCONFIG_DESCRIPTOR)
field(MAXIMUMBATCHINGWINDOWINSECONDS_DESCRIPTOR)
field(MAXIMUMRECORDAGEINSECONDS_DESCRIPTOR)
field(MAXIMUMRETRYATTEMPTS_DESCRIPTOR)
field(ONPARTIALBATCHITEMFAILURE_DESCRIPTOR)
field(PARALLELIZATIONFACTOR_DESCRIPTOR)
field(STARTINGPOSITION_DESCRIPTOR)
}
deserializer.deserializeStruct(OBJ_DESCRIPTOR) {
loop@while (true) {
when (findNextFieldIndex()) {
BATCHSIZE_DESCRIPTOR.index -> builder.batchSize = deserializeInt()
DEADLETTERCONFIG_DESCRIPTOR.index -> builder.deadLetterConfig = deserializeDeadLetterConfigDocument(deserializer)
MAXIMUMBATCHINGWINDOWINSECONDS_DESCRIPTOR.index -> builder.maximumBatchingWindowInSeconds = deserializeInt()
MAXIMUMRECORDAGEINSECONDS_DESCRIPTOR.index -> builder.maximumRecordAgeInSeconds = deserializeInt()
MAXIMUMRETRYATTEMPTS_DESCRIPTOR.index -> builder.maximumRetryAttempts = deserializeInt()
ONPARTIALBATCHITEMFAILURE_DESCRIPTOR.index -> builder.onPartialBatchItemFailure = deserializeString().let { OnPartialBatchItemFailureStreams.fromValue(it) }
PARALLELIZATIONFACTOR_DESCRIPTOR.index -> builder.parallelizationFactor = deserializeInt()
STARTINGPOSITION_DESCRIPTOR.index -> builder.startingPosition = deserializeString().let { DynamoDbStreamStartPosition.fromValue(it) }
null -> break@loop
else -> skipValue()
}
}
}
builder.correctErrors()
return builder.build()
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy