commonMain.aws.sdk.kotlin.services.redshift.serde.AuthorizeClusterSecurityGroupIngressOperationSerializer.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of redshift-jvm Show documentation
Show all versions of redshift-jvm Show documentation
The AWS SDK for Kotlin client for Redshift
// Code generated by smithy-kotlin-codegen. DO NOT EDIT!
package aws.sdk.kotlin.services.redshift.serde
import aws.sdk.kotlin.services.redshift.model.AuthorizeClusterSecurityGroupIngressRequest
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.formurl.FormUrlSerialName
import aws.smithy.kotlin.runtime.serde.formurl.FormUrlSerializer
import aws.smithy.kotlin.runtime.serde.formurl.QueryLiteral
import aws.smithy.kotlin.runtime.serde.serializeList
import aws.smithy.kotlin.runtime.serde.serializeMap
import aws.smithy.kotlin.runtime.serde.serializeStruct
internal class AuthorizeClusterSecurityGroupIngressOperationSerializer: HttpSerializer.NonStreaming {
override fun serialize(context: ExecutionContext, input: AuthorizeClusterSecurityGroupIngressRequest): HttpRequestBuilder {
val builder = HttpRequestBuilder()
builder.method = HttpMethod.POST
builder.url {
path.encoded = "/"
}
val payload = serializeAuthorizeClusterSecurityGroupIngressOperationBody(context, input)
builder.body = HttpBody.fromBytes(payload)
if (builder.body !is HttpBody.Empty) {
builder.headers.setMissing("Content-Type", "application/x-www-form-urlencoded")
}
return builder
}
}
private fun serializeAuthorizeClusterSecurityGroupIngressOperationBody(context: ExecutionContext, input: AuthorizeClusterSecurityGroupIngressRequest): ByteArray {
val serializer = FormUrlSerializer()
val CIDRIP_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, FormUrlSerialName("CIDRIP"))
val CLUSTERSECURITYGROUPNAME_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, FormUrlSerialName("ClusterSecurityGroupName"))
val EC2SECURITYGROUPNAME_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, FormUrlSerialName("EC2SecurityGroupName"))
val EC2SECURITYGROUPOWNERID_DESCRIPTOR = SdkFieldDescriptor(SerialKind.String, FormUrlSerialName("EC2SecurityGroupOwnerId"))
val OBJ_DESCRIPTOR = SdkObjectDescriptor.build {
trait(FormUrlSerialName("AuthorizeClusterSecurityGroupIngressMessage"))
trait(QueryLiteral("Action", "AuthorizeClusterSecurityGroupIngress"))
trait(QueryLiteral("Version", "2012-12-01"))
field(CIDRIP_DESCRIPTOR)
field(CLUSTERSECURITYGROUPNAME_DESCRIPTOR)
field(EC2SECURITYGROUPNAME_DESCRIPTOR)
field(EC2SECURITYGROUPOWNERID_DESCRIPTOR)
}
serializer.serializeStruct(OBJ_DESCRIPTOR) {
input.cidrip?.let { field(CIDRIP_DESCRIPTOR, it) }
input.clusterSecurityGroupName?.let { field(CLUSTERSECURITYGROUPNAME_DESCRIPTOR, it) }
input.ec2SecurityGroupName?.let { field(EC2SECURITYGROUPNAME_DESCRIPTOR, it) }
input.ec2SecurityGroupOwnerId?.let { field(EC2SECURITYGROUPOWNERID_DESCRIPTOR, it) }
}
return serializer.toByteArray()
}