aws-sdk-lambda 1.121.0

AWS SDK for AWS Lambda
Documentation
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
pub fn ser_create_event_source_mapping_input_input(
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    input: &crate::operation::create_event_source_mapping::CreateEventSourceMappingInput,
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
    if let Some(var_1) = &input.amazon_managed_kafka_event_source_config {
        #[allow(unused_mut)]
        let mut object_2 = object.key("AmazonManagedKafkaEventSourceConfig").start_object();
        crate::protocol_serde::shape_amazon_managed_kafka_event_source_config::ser_amazon_managed_kafka_event_source_config(&mut object_2, var_1)?;
        object_2.finish();
    }
    if let Some(var_3) = &input.batch_size {
        object.key("BatchSize").number(
            #[allow(clippy::useless_conversion)]
            ::aws_smithy_types::Number::NegInt((*var_3).into()),
        );
    }
    if let Some(var_4) = &input.bisect_batch_on_function_error {
        object.key("BisectBatchOnFunctionError").boolean(*var_4);
    }
    if let Some(var_5) = &input.destination_config {
        #[allow(unused_mut)]
        let mut object_6 = object.key("DestinationConfig").start_object();
        crate::protocol_serde::shape_destination_config::ser_destination_config(&mut object_6, var_5)?;
        object_6.finish();
    }
    if let Some(var_7) = &input.document_db_event_source_config {
        #[allow(unused_mut)]
        let mut object_8 = object.key("DocumentDBEventSourceConfig").start_object();
        crate::protocol_serde::shape_document_db_event_source_config::ser_document_db_event_source_config(&mut object_8, var_7)?;
        object_8.finish();
    }
    if let Some(var_9) = &input.enabled {
        object.key("Enabled").boolean(*var_9);
    }
    if let Some(var_10) = &input.event_source_arn {
        object.key("EventSourceArn").string(var_10.as_str());
    }
    if let Some(var_11) = &input.filter_criteria {
        #[allow(unused_mut)]
        let mut object_12 = object.key("FilterCriteria").start_object();
        crate::protocol_serde::shape_filter_criteria::ser_filter_criteria(&mut object_12, var_11)?;
        object_12.finish();
    }
    if let Some(var_13) = &input.function_name {
        object.key("FunctionName").string(var_13.as_str());
    }
    if let Some(var_14) = &input.function_response_types {
        let mut array_15 = object.key("FunctionResponseTypes").start_array();
        for item_16 in var_14 {
            {
                array_15.value().string(item_16.as_str());
            }
        }
        array_15.finish();
    }
    if let Some(var_17) = &input.kms_key_arn {
        object.key("KMSKeyArn").string(var_17.as_str());
    }
    if let Some(var_18) = &input.logging_config {
        #[allow(unused_mut)]
        let mut object_19 = object.key("LoggingConfig").start_object();
        crate::protocol_serde::shape_event_source_mapping_logging_config::ser_event_source_mapping_logging_config(&mut object_19, var_18)?;
        object_19.finish();
    }
    if let Some(var_20) = &input.maximum_batching_window_in_seconds {
        object.key("MaximumBatchingWindowInSeconds").number(
            #[allow(clippy::useless_conversion)]
            ::aws_smithy_types::Number::NegInt((*var_20).into()),
        );
    }
    if let Some(var_21) = &input.maximum_record_age_in_seconds {
        object.key("MaximumRecordAgeInSeconds").number(
            #[allow(clippy::useless_conversion)]
            ::aws_smithy_types::Number::NegInt((*var_21).into()),
        );
    }
    if let Some(var_22) = &input.maximum_retry_attempts {
        object.key("MaximumRetryAttempts").number(
            #[allow(clippy::useless_conversion)]
            ::aws_smithy_types::Number::NegInt((*var_22).into()),
        );
    }
    if let Some(var_23) = &input.metrics_config {
        #[allow(unused_mut)]
        let mut object_24 = object.key("MetricsConfig").start_object();
        crate::protocol_serde::shape_event_source_mapping_metrics_config::ser_event_source_mapping_metrics_config(&mut object_24, var_23)?;
        object_24.finish();
    }
    if let Some(var_25) = &input.parallelization_factor {
        object.key("ParallelizationFactor").number(
            #[allow(clippy::useless_conversion)]
            ::aws_smithy_types::Number::NegInt((*var_25).into()),
        );
    }
    if let Some(var_26) = &input.provisioned_poller_config {
        #[allow(unused_mut)]
        let mut object_27 = object.key("ProvisionedPollerConfig").start_object();
        crate::protocol_serde::shape_provisioned_poller_config::ser_provisioned_poller_config(&mut object_27, var_26)?;
        object_27.finish();
    }
    if let Some(var_28) = &input.queues {
        let mut array_29 = object.key("Queues").start_array();
        for item_30 in var_28 {
            {
                array_29.value().string(item_30.as_str());
            }
        }
        array_29.finish();
    }
    if let Some(var_31) = &input.scaling_config {
        #[allow(unused_mut)]
        let mut object_32 = object.key("ScalingConfig").start_object();
        crate::protocol_serde::shape_scaling_config::ser_scaling_config(&mut object_32, var_31)?;
        object_32.finish();
    }
    if let Some(var_33) = &input.self_managed_event_source {
        #[allow(unused_mut)]
        let mut object_34 = object.key("SelfManagedEventSource").start_object();
        crate::protocol_serde::shape_self_managed_event_source::ser_self_managed_event_source(&mut object_34, var_33)?;
        object_34.finish();
    }
    if let Some(var_35) = &input.self_managed_kafka_event_source_config {
        #[allow(unused_mut)]
        let mut object_36 = object.key("SelfManagedKafkaEventSourceConfig").start_object();
        crate::protocol_serde::shape_self_managed_kafka_event_source_config::ser_self_managed_kafka_event_source_config(&mut object_36, var_35)?;
        object_36.finish();
    }
    if let Some(var_37) = &input.source_access_configurations {
        let mut array_38 = object.key("SourceAccessConfigurations").start_array();
        for item_39 in var_37 {
            {
                #[allow(unused_mut)]
                let mut object_40 = array_38.value().start_object();
                crate::protocol_serde::shape_source_access_configuration::ser_source_access_configuration(&mut object_40, item_39)?;
                object_40.finish();
            }
        }
        array_38.finish();
    }
    if let Some(var_41) = &input.starting_position {
        object.key("StartingPosition").string(var_41.as_str());
    }
    if let Some(var_42) = &input.starting_position_timestamp {
        object
            .key("StartingPositionTimestamp")
            .date_time(var_42, ::aws_smithy_types::date_time::Format::EpochSeconds)?;
    }
    if let Some(var_43) = &input.tags {
        #[allow(unused_mut)]
        let mut object_44 = object.key("Tags").start_object();
        for (key_45, value_46) in var_43 {
            {
                object_44.key(key_45.as_str()).string(value_46.as_str());
            }
        }
        object_44.finish();
    }
    if let Some(var_47) = &input.topics {
        let mut array_48 = object.key("Topics").start_array();
        for item_49 in var_47 {
            {
                array_48.value().string(item_49.as_str());
            }
        }
        array_48.finish();
    }
    if let Some(var_50) = &input.tumbling_window_in_seconds {
        object.key("TumblingWindowInSeconds").number(
            #[allow(clippy::useless_conversion)]
            ::aws_smithy_types::Number::NegInt((*var_50).into()),
        );
    }
    Ok(())
}