All Downloads are FREE. Search and download functionalities are using the official Maven repository.

commonMain.aws.sdk.kotlin.services.elasticloadbalancingv2.serde.AuthenticateOidcActionConfigDocumentSerializer.kt Maven / Gradle / Ivy

// Code generated by smithy-kotlin-codegen. DO NOT EDIT!

package aws.sdk.kotlin.services.elasticloadbalancingv2.serde

import aws.sdk.kotlin.services.elasticloadbalancingv2.model.AuthenticateOidcActionConfig
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.Serializer
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.formurl.FormUrlSerialName
import aws.smithy.kotlin.runtime.serde.serializeList
import aws.smithy.kotlin.runtime.serde.serializeMap
import aws.smithy.kotlin.runtime.serde.serializeStruct

internal fun serializeAuthenticateOidcActionConfigDocument(serializer: Serializer, input: AuthenticateOidcActionConfig) {
    val AUTHENTICATIONREQUESTEXTRAPARAMS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Map, FormUrlSerialName("AuthenticationRequestExtraParams"))
    val AUTHORIZATIONENDPOINT_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, FormUrlSerialName("AuthorizationEndpoint"))
    val CLIENTID_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, FormUrlSerialName("ClientId"))
    val CLIENTSECRET_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, FormUrlSerialName("ClientSecret"))
    val ISSUER_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, FormUrlSerialName("Issuer"))
    val ONUNAUTHENTICATEDREQUEST_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Enum, FormUrlSerialName("OnUnauthenticatedRequest"))
    val SCOPE_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, FormUrlSerialName("Scope"))
    val SESSIONCOOKIENAME_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, FormUrlSerialName("SessionCookieName"))
    val SESSIONTIMEOUT_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Long, FormUrlSerialName("SessionTimeout"))
    val TOKENENDPOINT_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, FormUrlSerialName("TokenEndpoint"))
    val USEEXISTINGCLIENTSECRET_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Boolean, FormUrlSerialName("UseExistingClientSecret"))
    val USERINFOENDPOINT_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, FormUrlSerialName("UserInfoEndpoint"))
    val OBJ_DESCRIPTOR = SdkObjectDescriptor.build {
        trait(FormUrlSerialName("AuthenticateOidcActionConfig"))
        field(AUTHENTICATIONREQUESTEXTRAPARAMS_DESCRIPTOR)
        field(AUTHORIZATIONENDPOINT_DESCRIPTOR)
        field(CLIENTID_DESCRIPTOR)
        field(CLIENTSECRET_DESCRIPTOR)
        field(ISSUER_DESCRIPTOR)
        field(ONUNAUTHENTICATEDREQUEST_DESCRIPTOR)
        field(SCOPE_DESCRIPTOR)
        field(SESSIONCOOKIENAME_DESCRIPTOR)
        field(SESSIONTIMEOUT_DESCRIPTOR)
        field(TOKENENDPOINT_DESCRIPTOR)
        field(USEEXISTINGCLIENTSECRET_DESCRIPTOR)
        field(USERINFOENDPOINT_DESCRIPTOR)
    }

    serializer.serializeStruct(OBJ_DESCRIPTOR) {
        input.issuer?.let { field(ISSUER_DESCRIPTOR, it) }
        input.authorizationEndpoint?.let { field(AUTHORIZATIONENDPOINT_DESCRIPTOR, it) }
        input.tokenEndpoint?.let { field(TOKENENDPOINT_DESCRIPTOR, it) }
        input.userInfoEndpoint?.let { field(USERINFOENDPOINT_DESCRIPTOR, it) }
        input.clientId?.let { field(CLIENTID_DESCRIPTOR, it) }
        input.clientSecret?.let { field(CLIENTSECRET_DESCRIPTOR, it) }
        input.sessionCookieName?.let { field(SESSIONCOOKIENAME_DESCRIPTOR, it) }
        input.scope?.let { field(SCOPE_DESCRIPTOR, it) }
        input.sessionTimeout?.let { field(SESSIONTIMEOUT_DESCRIPTOR, it) }
        if (input.authenticationRequestExtraParams != null) {
            mapField(AUTHENTICATIONREQUESTEXTRAPARAMS_DESCRIPTOR) {
                input.authenticationRequestExtraParams.forEach { (key, value) ->
                    entry(key, value)
                }
            }
        }
        input.onUnauthenticatedRequest?.let { field(ONUNAUTHENTICATEDREQUEST_DESCRIPTOR, it.value) }
        input.useExistingClientSecret?.let { field(USEEXISTINGCLIENTSECRET_DESCRIPTOR, it) }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy