aws-sdk-pipes 1.97.0

AWS SDK for Amazon EventBridge Pipes
Documentation
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
pub fn ser_pipe_source_parameters(
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    input: &crate::types::PipeSourceParameters,
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
    if let Some(var_1) = &input.filter_criteria {
        #[allow(unused_mut)]
        let mut object_2 = object.key("FilterCriteria").start_object();
        crate::protocol_serde::shape_filter_criteria::ser_filter_criteria(&mut object_2, var_1)?;
        object_2.finish();
    }
    if let Some(var_3) = &input.kinesis_stream_parameters {
        #[allow(unused_mut)]
        let mut object_4 = object.key("KinesisStreamParameters").start_object();
        crate::protocol_serde::shape_pipe_source_kinesis_stream_parameters::ser_pipe_source_kinesis_stream_parameters(&mut object_4, var_3)?;
        object_4.finish();
    }
    if let Some(var_5) = &input.dynamo_db_stream_parameters {
        #[allow(unused_mut)]
        let mut object_6 = object.key("DynamoDBStreamParameters").start_object();
        crate::protocol_serde::shape_pipe_source_dynamo_db_stream_parameters::ser_pipe_source_dynamo_db_stream_parameters(&mut object_6, var_5)?;
        object_6.finish();
    }
    if let Some(var_7) = &input.sqs_queue_parameters {
        #[allow(unused_mut)]
        let mut object_8 = object.key("SqsQueueParameters").start_object();
        crate::protocol_serde::shape_pipe_source_sqs_queue_parameters::ser_pipe_source_sqs_queue_parameters(&mut object_8, var_7)?;
        object_8.finish();
    }
    if let Some(var_9) = &input.active_mq_broker_parameters {
        #[allow(unused_mut)]
        let mut object_10 = object.key("ActiveMQBrokerParameters").start_object();
        crate::protocol_serde::shape_pipe_source_active_mq_broker_parameters::ser_pipe_source_active_mq_broker_parameters(&mut object_10, var_9)?;
        object_10.finish();
    }
    if let Some(var_11) = &input.rabbit_mq_broker_parameters {
        #[allow(unused_mut)]
        let mut object_12 = object.key("RabbitMQBrokerParameters").start_object();
        crate::protocol_serde::shape_pipe_source_rabbit_mq_broker_parameters::ser_pipe_source_rabbit_mq_broker_parameters(&mut object_12, var_11)?;
        object_12.finish();
    }
    if let Some(var_13) = &input.managed_streaming_kafka_parameters {
        #[allow(unused_mut)]
        let mut object_14 = object.key("ManagedStreamingKafkaParameters").start_object();
        crate::protocol_serde::shape_pipe_source_managed_streaming_kafka_parameters::ser_pipe_source_managed_streaming_kafka_parameters(
            &mut object_14,
            var_13,
        )?;
        object_14.finish();
    }
    if let Some(var_15) = &input.self_managed_kafka_parameters {
        #[allow(unused_mut)]
        let mut object_16 = object.key("SelfManagedKafkaParameters").start_object();
        crate::protocol_serde::shape_pipe_source_self_managed_kafka_parameters::ser_pipe_source_self_managed_kafka_parameters(
            &mut object_16,
            var_15,
        )?;
        object_16.finish();
    }
    Ok(())
}

pub(crate) fn de_pipe_source_parameters<'a, I>(
    tokens: &mut ::std::iter::Peekable<I>,
    _value: &'a [u8],
) -> ::std::result::Result<Option<crate::types::PipeSourceParameters>, ::aws_smithy_json::deserialize::error::DeserializeError>
where
    I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
{
    match tokens.next().transpose()? {
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
        Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => {
            #[allow(unused_mut)]
            let mut builder = crate::types::builders::PipeSourceParametersBuilder::default();
            loop {
                match tokens.next().transpose()? {
                    Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
                        "FilterCriteria" => {
                            builder = builder.set_filter_criteria(crate::protocol_serde::shape_filter_criteria::de_filter_criteria(tokens, _value)?);
                        }
                        "KinesisStreamParameters" => {
                            builder = builder.set_kinesis_stream_parameters(
                                crate::protocol_serde::shape_pipe_source_kinesis_stream_parameters::de_pipe_source_kinesis_stream_parameters(
                                    tokens, _value,
                                )?,
                            );
                        }
                        "DynamoDBStreamParameters" => {
                            builder = builder.set_dynamo_db_stream_parameters(
                                crate::protocol_serde::shape_pipe_source_dynamo_db_stream_parameters::de_pipe_source_dynamo_db_stream_parameters(
                                    tokens, _value,
                                )?,
                            );
                        }
                        "SqsQueueParameters" => {
                            builder = builder.set_sqs_queue_parameters(
                                crate::protocol_serde::shape_pipe_source_sqs_queue_parameters::de_pipe_source_sqs_queue_parameters(tokens, _value)?,
                            );
                        }
                        "ActiveMQBrokerParameters" => {
                            builder = builder.set_active_mq_broker_parameters(
                                crate::protocol_serde::shape_pipe_source_active_mq_broker_parameters::de_pipe_source_active_mq_broker_parameters(
                                    tokens, _value,
                                )?,
                            );
                        }
                        "RabbitMQBrokerParameters" => {
                            builder = builder.set_rabbit_mq_broker_parameters(
                                crate::protocol_serde::shape_pipe_source_rabbit_mq_broker_parameters::de_pipe_source_rabbit_mq_broker_parameters(
                                    tokens, _value,
                                )?,
                            );
                        }
                        "ManagedStreamingKafkaParameters" => {
                            builder = builder.set_managed_streaming_kafka_parameters(
                                    crate::protocol_serde::shape_pipe_source_managed_streaming_kafka_parameters::de_pipe_source_managed_streaming_kafka_parameters(tokens, _value)?
                                );
                        }
                        "SelfManagedKafkaParameters" => {
                            builder = builder.set_self_managed_kafka_parameters(
                                crate::protocol_serde::shape_pipe_source_self_managed_kafka_parameters::de_pipe_source_self_managed_kafka_parameters(
                                    tokens, _value,
                                )?,
                            );
                        }
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
                    },
                    other => {
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
                            "expected object key or end object, found: {other:?}"
                        )))
                    }
                }
            }
            Ok(Some(builder.build()))
        }
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
            "expected start object or null",
        )),
    }
}