
commonMain.aws.sdk.kotlin.services.auditmanager.serde.AssessmentMetadataDocumentDeserializer.kt Maven / Gradle / Ivy
// Code generated by smithy-kotlin-codegen. DO NOT EDIT!
package aws.sdk.kotlin.services.auditmanager.serde
import aws.sdk.kotlin.services.auditmanager.model.AssessmentMetadata
import aws.sdk.kotlin.services.auditmanager.model.AssessmentStatus
import aws.sdk.kotlin.services.auditmanager.model.Delegation
import aws.sdk.kotlin.services.auditmanager.model.Role
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
import aws.smithy.kotlin.runtime.time.Instant
import aws.smithy.kotlin.runtime.time.TimestampFormat
import kotlin.collections.mutableListOf
internal fun deserializeAssessmentMetadataDocument(deserializer: Deserializer): AssessmentMetadata {
val builder = AssessmentMetadata.Builder()
val ASSESSMENTREPORTSDESTINATION_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Struct, JsonSerialName("assessmentReportsDestination"))
val COMPLIANCETYPE_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("complianceType"))
val CREATIONTIME_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Timestamp, JsonSerialName("creationTime"))
val DELEGATIONS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.List, JsonSerialName("delegations"))
val DESCRIPTION_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("description"))
val ID_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("id"))
val LASTUPDATED_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Timestamp, JsonSerialName("lastUpdated"))
val NAME_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, JsonSerialName("name"))
val ROLES_DESCRIPTOR = SdkFieldDescriptor(SerialKind.List, JsonSerialName("roles"))
val SCOPE_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Struct, JsonSerialName("scope"))
val STATUS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Enum, JsonSerialName("status"))
val OBJ_DESCRIPTOR = SdkObjectDescriptor.build {
field(ASSESSMENTREPORTSDESTINATION_DESCRIPTOR)
field(COMPLIANCETYPE_DESCRIPTOR)
field(CREATIONTIME_DESCRIPTOR)
field(DELEGATIONS_DESCRIPTOR)
field(DESCRIPTION_DESCRIPTOR)
field(ID_DESCRIPTOR)
field(LASTUPDATED_DESCRIPTOR)
field(NAME_DESCRIPTOR)
field(ROLES_DESCRIPTOR)
field(SCOPE_DESCRIPTOR)
field(STATUS_DESCRIPTOR)
}
deserializer.deserializeStruct(OBJ_DESCRIPTOR) {
loop@while (true) {
when (findNextFieldIndex()) {
ASSESSMENTREPORTSDESTINATION_DESCRIPTOR.index -> builder.assessmentReportsDestination = deserializeAssessmentReportsDestinationDocument(deserializer)
COMPLIANCETYPE_DESCRIPTOR.index -> builder.complianceType = deserializeString()
CREATIONTIME_DESCRIPTOR.index -> builder.creationTime = deserializeInstant(TimestampFormat.EPOCH_SECONDS)
DELEGATIONS_DESCRIPTOR.index -> builder.delegations =
deserializer.deserializeList(DELEGATIONS_DESCRIPTOR) {
val col0 = mutableListOf()
while (hasNextElement()) {
val el0 = if (nextHasValue()) { deserializeDelegationDocument(deserializer) } else { deserializeNull(); continue }
col0.add(el0)
}
col0
}
DESCRIPTION_DESCRIPTOR.index -> builder.description = deserializeString()
ID_DESCRIPTOR.index -> builder.id = deserializeString()
LASTUPDATED_DESCRIPTOR.index -> builder.lastUpdated = deserializeInstant(TimestampFormat.EPOCH_SECONDS)
NAME_DESCRIPTOR.index -> builder.name = deserializeString()
ROLES_DESCRIPTOR.index -> builder.roles =
deserializer.deserializeList(ROLES_DESCRIPTOR) {
val col0 = mutableListOf()
while (hasNextElement()) {
val el0 = if (nextHasValue()) { deserializeRoleDocument(deserializer) } else { deserializeNull(); continue }
col0.add(el0)
}
col0
}
SCOPE_DESCRIPTOR.index -> builder.scope = deserializeScopeDocument(deserializer)
STATUS_DESCRIPTOR.index -> builder.status = deserializeString().let { AssessmentStatus.fromValue(it) }
null -> break@loop
else -> skipValue()
}
}
}
builder.correctErrors()
return builder.build()
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy