aws-sdk-glue 1.58.0

AWS SDK for AWS Glue
Documentation
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
pub fn ser_amazon_redshift_node_data(
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    input: &crate::types::AmazonRedshiftNodeData,
) -> Result<(), ::aws_smithy_types::error::operation::SerializationError> {
    if let Some(var_1) = &input.access_type {
        object.key("AccessType").string(var_1.as_str());
    }
    if let Some(var_2) = &input.source_type {
        object.key("SourceType").string(var_2.as_str());
    }
    if let Some(var_3) = &input.connection {
        #[allow(unused_mut)]
        let mut object_4 = object.key("Connection").start_object();
        crate::protocol_serde::shape_option::ser_option(&mut object_4, var_3)?;
        object_4.finish();
    }
    if let Some(var_5) = &input.schema {
        #[allow(unused_mut)]
        let mut object_6 = object.key("Schema").start_object();
        crate::protocol_serde::shape_option::ser_option(&mut object_6, var_5)?;
        object_6.finish();
    }
    if let Some(var_7) = &input.table {
        #[allow(unused_mut)]
        let mut object_8 = object.key("Table").start_object();
        crate::protocol_serde::shape_option::ser_option(&mut object_8, var_7)?;
        object_8.finish();
    }
    if let Some(var_9) = &input.catalog_database {
        #[allow(unused_mut)]
        let mut object_10 = object.key("CatalogDatabase").start_object();
        crate::protocol_serde::shape_option::ser_option(&mut object_10, var_9)?;
        object_10.finish();
    }
    if let Some(var_11) = &input.catalog_table {
        #[allow(unused_mut)]
        let mut object_12 = object.key("CatalogTable").start_object();
        crate::protocol_serde::shape_option::ser_option(&mut object_12, var_11)?;
        object_12.finish();
    }
    if let Some(var_13) = &input.catalog_redshift_schema {
        object.key("CatalogRedshiftSchema").string(var_13.as_str());
    }
    if let Some(var_14) = &input.catalog_redshift_table {
        object.key("CatalogRedshiftTable").string(var_14.as_str());
    }
    if let Some(var_15) = &input.temp_dir {
        object.key("TempDir").string(var_15.as_str());
    }
    if let Some(var_16) = &input.iam_role {
        #[allow(unused_mut)]
        let mut object_17 = object.key("IamRole").start_object();
        crate::protocol_serde::shape_option::ser_option(&mut object_17, var_16)?;
        object_17.finish();
    }
    if let Some(var_18) = &input.advanced_options {
        let mut array_19 = object.key("AdvancedOptions").start_array();
        for item_20 in var_18 {
            {
                #[allow(unused_mut)]
                let mut object_21 = array_19.value().start_object();
                crate::protocol_serde::shape_amazon_redshift_advanced_option::ser_amazon_redshift_advanced_option(&mut object_21, item_20)?;
                object_21.finish();
            }
        }
        array_19.finish();
    }
    if let Some(var_22) = &input.sample_query {
        object.key("SampleQuery").string(var_22.as_str());
    }
    if let Some(var_23) = &input.pre_action {
        object.key("PreAction").string(var_23.as_str());
    }
    if let Some(var_24) = &input.post_action {
        object.key("PostAction").string(var_24.as_str());
    }
    if let Some(var_25) = &input.action {
        object.key("Action").string(var_25.as_str());
    }
    if let Some(var_26) = &input.table_prefix {
        object.key("TablePrefix").string(var_26.as_str());
    }
    if input.upsert {
        object.key("Upsert").boolean(input.upsert);
    }
    if let Some(var_27) = &input.merge_action {
        object.key("MergeAction").string(var_27.as_str());
    }
    if let Some(var_28) = &input.merge_when_matched {
        object.key("MergeWhenMatched").string(var_28.as_str());
    }
    if let Some(var_29) = &input.merge_when_not_matched {
        object.key("MergeWhenNotMatched").string(var_29.as_str());
    }
    if let Some(var_30) = &input.merge_clause {
        object.key("MergeClause").string(var_30.as_str());
    }
    if let Some(var_31) = &input.crawler_connection {
        object.key("CrawlerConnection").string(var_31.as_str());
    }
    if let Some(var_32) = &input.table_schema {
        let mut array_33 = object.key("TableSchema").start_array();
        for item_34 in var_32 {
            {
                #[allow(unused_mut)]
                let mut object_35 = array_33.value().start_object();
                crate::protocol_serde::shape_option::ser_option(&mut object_35, item_34)?;
                object_35.finish();
            }
        }
        array_33.finish();
    }
    if let Some(var_36) = &input.staging_table {
        object.key("StagingTable").string(var_36.as_str());
    }
    if let Some(var_37) = &input.selected_columns {
        let mut array_38 = object.key("SelectedColumns").start_array();
        for item_39 in var_37 {
            {
                #[allow(unused_mut)]
                let mut object_40 = array_38.value().start_object();
                crate::protocol_serde::shape_option::ser_option(&mut object_40, item_39)?;
                object_40.finish();
            }
        }
        array_38.finish();
    }
    Ok(())
}

pub(crate) fn de_amazon_redshift_node_data<'a, I>(
    tokens: &mut ::std::iter::Peekable<I>,
) -> Result<Option<crate::types::AmazonRedshiftNodeData>, ::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::AmazonRedshiftNodeDataBuilder::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() {
                        "AccessType" => {
                            builder = builder.set_access_type(
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
                                    .transpose()?,
                            );
                        }
                        "SourceType" => {
                            builder = builder.set_source_type(
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
                                    .transpose()?,
                            );
                        }
                        "Connection" => {
                            builder = builder.set_connection(crate::protocol_serde::shape_option::de_option(tokens)?);
                        }
                        "Schema" => {
                            builder = builder.set_schema(crate::protocol_serde::shape_option::de_option(tokens)?);
                        }
                        "Table" => {
                            builder = builder.set_table(crate::protocol_serde::shape_option::de_option(tokens)?);
                        }
                        "CatalogDatabase" => {
                            builder = builder.set_catalog_database(crate::protocol_serde::shape_option::de_option(tokens)?);
                        }
                        "CatalogTable" => {
                            builder = builder.set_catalog_table(crate::protocol_serde::shape_option::de_option(tokens)?);
                        }
                        "CatalogRedshiftSchema" => {
                            builder = builder.set_catalog_redshift_schema(
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
                                    .transpose()?,
                            );
                        }
                        "CatalogRedshiftTable" => {
                            builder = builder.set_catalog_redshift_table(
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
                                    .transpose()?,
                            );
                        }
                        "TempDir" => {
                            builder = builder.set_temp_dir(
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
                                    .transpose()?,
                            );
                        }
                        "IamRole" => {
                            builder = builder.set_iam_role(crate::protocol_serde::shape_option::de_option(tokens)?);
                        }
                        "AdvancedOptions" => {
                            builder = builder.set_advanced_options(
                                crate::protocol_serde::shape_amazon_redshift_advanced_options::de_amazon_redshift_advanced_options(tokens)?,
                            );
                        }
                        "SampleQuery" => {
                            builder = builder.set_sample_query(
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
                                    .transpose()?,
                            );
                        }
                        "PreAction" => {
                            builder = builder.set_pre_action(
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
                                    .transpose()?,
                            );
                        }
                        "PostAction" => {
                            builder = builder.set_post_action(
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
                                    .transpose()?,
                            );
                        }
                        "Action" => {
                            builder = builder.set_action(
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
                                    .transpose()?,
                            );
                        }
                        "TablePrefix" => {
                            builder = builder.set_table_prefix(
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
                                    .transpose()?,
                            );
                        }
                        "Upsert" => {
                            builder = builder.set_upsert(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
                        }
                        "MergeAction" => {
                            builder = builder.set_merge_action(
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
                                    .transpose()?,
                            );
                        }
                        "MergeWhenMatched" => {
                            builder = builder.set_merge_when_matched(
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
                                    .transpose()?,
                            );
                        }
                        "MergeWhenNotMatched" => {
                            builder = builder.set_merge_when_not_matched(
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
                                    .transpose()?,
                            );
                        }
                        "MergeClause" => {
                            builder = builder.set_merge_clause(
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
                                    .transpose()?,
                            );
                        }
                        "CrawlerConnection" => {
                            builder = builder.set_crawler_connection(
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
                                    .transpose()?,
                            );
                        }
                        "TableSchema" => {
                            builder = builder.set_table_schema(crate::protocol_serde::shape_option_list::de_option_list(tokens)?);
                        }
                        "StagingTable" => {
                            builder = builder.set_staging_table(
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
                                    .transpose()?,
                            );
                        }
                        "SelectedColumns" => {
                            builder = builder.set_selected_columns(crate::protocol_serde::shape_option_list::de_option_list(tokens)?);
                        }
                        _ => ::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",
        )),
    }
}