AWS SDK

AWS SDK

rev. e063993ca0ab793f44c575dbe707d50a5e3e2406 (ignoring whitespace)

Files changed:

tmp-codegen-diff/aws-sdk/sdk/cloudwatchlogs/src/operation/get_log_anomaly_detector/_get_log_anomaly_detector_input.rs

@@ -1,1 +108,120 @@
   17     17   
    "com.amazonaws.cloudwatchlogs.synthetic",
   18     18   
    "GetLogAnomalyDetectorInput",
   19     19   
);
   20     20   
static GETLOGANOMALYDETECTORINPUT_MEMBER_ANOMALY_DETECTOR_ARN: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   21     21   
    ::aws_smithy_schema::ShapeId::from_static(
   22     22   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogAnomalyDetectorInput$anomalyDetectorArn",
   23     23   
        "com.amazonaws.cloudwatchlogs.synthetic",
   24     24   
        "GetLogAnomalyDetectorInput",
   25     25   
    ),
   26     26   
    ::aws_smithy_schema::ShapeType::String,
   27         -
    "anomaly_detector_arn",
          27  +
    "anomalyDetectorArn",
   28     28   
    0,
   29     29   
);
   30     30   
static GETLOGANOMALYDETECTORINPUT_SCHEMA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_struct(
   31     31   
    GETLOGANOMALYDETECTORINPUT_SCHEMA_ID,
   32     32   
    ::aws_smithy_schema::ShapeType::Structure,
   33     33   
    &[&GETLOGANOMALYDETECTORINPUT_MEMBER_ANOMALY_DETECTOR_ARN],
   34     34   
);
   35     35   
impl GetLogAnomalyDetectorInput {
   36     36   
    /// The schema for this shape.
   37     37   
    pub const SCHEMA: &'static ::aws_smithy_schema::Schema = &GETLOGANOMALYDETECTORINPUT_SCHEMA;
   38     38   
}
   39     39   
impl ::aws_smithy_schema::serde::SerializableStruct for GetLogAnomalyDetectorInput {
   40     40   
    #[allow(unused_variables, clippy::diverging_sub_expression)]
   41     41   
    fn serialize_members(
   42     42   
        &self,
   43     43   
        ser: &mut dyn ::aws_smithy_schema::serde::ShapeSerializer,
   44     44   
    ) -> ::std::result::Result<(), ::aws_smithy_schema::serde::SerdeError> {
   45     45   
        if let Some(ref val) = self.anomaly_detector_arn {
   46     46   
            ser.write_string(&GETLOGANOMALYDETECTORINPUT_MEMBER_ANOMALY_DETECTOR_ARN, val)?;
   47     47   
        }
   48     48   
        Ok(())
   49     49   
    }
   50     50   
}
   51     51   
impl GetLogAnomalyDetectorInput {
   52     52   
    /// Deserializes this structure from a [`ShapeDeserializer`].
   53         -
    pub fn deserialize<D: ::aws_smithy_schema::serde::ShapeDeserializer>(
   54         -
        deserializer: &mut D,
          53  +
    pub fn deserialize(
          54  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
   55     55   
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
   56     56   
        #[allow(unused_variables, unused_mut)]
   57     57   
        let mut builder = Self::builder();
   58     58   
        #[allow(
   59     59   
            unused_variables,
   60     60   
            unreachable_code,
   61     61   
            clippy::single_match,
   62     62   
            clippy::match_single_binding,
   63     63   
            clippy::diverging_sub_expression
   64     64   
        )]
   65         -
        deserializer.read_struct(&GETLOGANOMALYDETECTORINPUT_SCHEMA, (), |_, member, deser| {
          65  +
        deserializer.read_struct(&GETLOGANOMALYDETECTORINPUT_SCHEMA, &mut |member, deser| {
   66     66   
            match member.member_index() {
   67     67   
                Some(0) => {
   68     68   
                    builder.anomaly_detector_arn = Some(deser.read_string(member)?);
   69     69   
                }
   70     70   
                _ => {}
   71     71   
            }
   72     72   
            Ok(())
   73     73   
        })?;
          74  +
        builder.anomaly_detector_arn = builder.anomaly_detector_arn.or(Some(String::new()));
   74     75   
        builder
   75     76   
            .build()
   76     77   
            .map_err(|e| aws_smithy_schema::serde::SerdeError::Custom { message: e.to_string() })
   77     78   
    }
   78     79   
}
          80  +
impl GetLogAnomalyDetectorInput {
          81  +
    /// Deserializes this structure from a body deserializer and HTTP response.
          82  +
    pub fn deserialize_with_response(
          83  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
          84  +
        _headers: &::aws_smithy_runtime_api::http::Headers,
          85  +
        _status: u16,
          86  +
        _body: &[u8],
          87  +
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
          88  +
        Self::deserialize(deserializer)
          89  +
    }
          90  +
}
   79     91   
impl GetLogAnomalyDetectorInput {
   80     92   
    /// Creates a new builder-style object to manufacture [`GetLogAnomalyDetectorInput`](crate::operation::get_log_anomaly_detector::GetLogAnomalyDetectorInput).
   81     93   
    pub fn builder() -> crate::operation::get_log_anomaly_detector::builders::GetLogAnomalyDetectorInputBuilder {
   82     94   
        crate::operation::get_log_anomaly_detector::builders::GetLogAnomalyDetectorInputBuilder::default()
   83     95   
    }
   84     96   
}
   85     97   
   86     98   
/// A builder for [`GetLogAnomalyDetectorInput`](crate::operation::get_log_anomaly_detector::GetLogAnomalyDetectorInput).
   87     99   
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
   88    100   
#[non_exhaustive]

tmp-codegen-diff/aws-sdk/sdk/cloudwatchlogs/src/operation/get_log_anomaly_detector/_get_log_anomaly_detector_output.rs

@@ -48,48 +286,345 @@
   68     68   
    "com.amazonaws.cloudwatchlogs.synthetic",
   69     69   
    "GetLogAnomalyDetectorOutput",
   70     70   
);
   71     71   
static GETLOGANOMALYDETECTOROUTPUT_MEMBER_DETECTOR_NAME: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   72     72   
    ::aws_smithy_schema::ShapeId::from_static(
   73     73   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogAnomalyDetectorOutput$detectorName",
   74     74   
        "com.amazonaws.cloudwatchlogs.synthetic",
   75     75   
        "GetLogAnomalyDetectorOutput",
   76     76   
    ),
   77     77   
    ::aws_smithy_schema::ShapeType::String,
   78         -
    "detector_name",
          78  +
    "detectorName",
   79     79   
    0,
   80     80   
);
   81     81   
static GETLOGANOMALYDETECTOROUTPUT_MEMBER_LOG_GROUP_ARN_LIST: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   82     82   
    ::aws_smithy_schema::ShapeId::from_static(
   83     83   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogAnomalyDetectorOutput$logGroupArnList",
   84     84   
        "com.amazonaws.cloudwatchlogs.synthetic",
   85     85   
        "GetLogAnomalyDetectorOutput",
   86     86   
    ),
   87     87   
    ::aws_smithy_schema::ShapeType::List,
   88         -
    "log_group_arn_list",
          88  +
    "logGroupArnList",
   89     89   
    1,
   90     90   
);
   91     91   
static GETLOGANOMALYDETECTOROUTPUT_MEMBER_EVALUATION_FREQUENCY: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   92     92   
    ::aws_smithy_schema::ShapeId::from_static(
   93     93   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogAnomalyDetectorOutput$evaluationFrequency",
   94     94   
        "com.amazonaws.cloudwatchlogs.synthetic",
   95     95   
        "GetLogAnomalyDetectorOutput",
   96     96   
    ),
   97     97   
    ::aws_smithy_schema::ShapeType::String,
   98         -
    "evaluation_frequency",
          98  +
    "evaluationFrequency",
   99     99   
    2,
  100    100   
);
  101    101   
static GETLOGANOMALYDETECTOROUTPUT_MEMBER_FILTER_PATTERN: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  102    102   
    ::aws_smithy_schema::ShapeId::from_static(
  103    103   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogAnomalyDetectorOutput$filterPattern",
  104    104   
        "com.amazonaws.cloudwatchlogs.synthetic",
  105    105   
        "GetLogAnomalyDetectorOutput",
  106    106   
    ),
  107    107   
    ::aws_smithy_schema::ShapeType::String,
  108         -
    "filter_pattern",
         108  +
    "filterPattern",
  109    109   
    3,
  110    110   
);
  111    111   
static GETLOGANOMALYDETECTOROUTPUT_MEMBER_ANOMALY_DETECTOR_STATUS: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  112    112   
    ::aws_smithy_schema::ShapeId::from_static(
  113    113   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogAnomalyDetectorOutput$anomalyDetectorStatus",
  114    114   
        "com.amazonaws.cloudwatchlogs.synthetic",
  115    115   
        "GetLogAnomalyDetectorOutput",
  116    116   
    ),
  117    117   
    ::aws_smithy_schema::ShapeType::String,
  118         -
    "anomaly_detector_status",
         118  +
    "anomalyDetectorStatus",
  119    119   
    4,
  120    120   
);
  121    121   
static GETLOGANOMALYDETECTOROUTPUT_MEMBER_KMS_KEY_ID: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  122    122   
    ::aws_smithy_schema::ShapeId::from_static(
  123    123   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogAnomalyDetectorOutput$kmsKeyId",
  124    124   
        "com.amazonaws.cloudwatchlogs.synthetic",
  125    125   
        "GetLogAnomalyDetectorOutput",
  126    126   
    ),
  127    127   
    ::aws_smithy_schema::ShapeType::String,
  128         -
    "kms_key_id",
         128  +
    "kmsKeyId",
  129    129   
    5,
  130    130   
);
  131    131   
static GETLOGANOMALYDETECTOROUTPUT_MEMBER_CREATION_TIME_STAMP: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  132    132   
    ::aws_smithy_schema::ShapeId::from_static(
  133    133   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogAnomalyDetectorOutput$creationTimeStamp",
  134    134   
        "com.amazonaws.cloudwatchlogs.synthetic",
  135    135   
        "GetLogAnomalyDetectorOutput",
  136    136   
    ),
  137    137   
    ::aws_smithy_schema::ShapeType::Long,
  138         -
    "creation_time_stamp",
         138  +
    "creationTimeStamp",
  139    139   
    6,
  140    140   
);
  141    141   
static GETLOGANOMALYDETECTOROUTPUT_MEMBER_LAST_MODIFIED_TIME_STAMP: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  142    142   
    ::aws_smithy_schema::ShapeId::from_static(
  143    143   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogAnomalyDetectorOutput$lastModifiedTimeStamp",
  144    144   
        "com.amazonaws.cloudwatchlogs.synthetic",
  145    145   
        "GetLogAnomalyDetectorOutput",
  146    146   
    ),
  147    147   
    ::aws_smithy_schema::ShapeType::Long,
  148         -
    "last_modified_time_stamp",
         148  +
    "lastModifiedTimeStamp",
  149    149   
    7,
  150    150   
);
  151    151   
static GETLOGANOMALYDETECTOROUTPUT_MEMBER_ANOMALY_VISIBILITY_TIME: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  152    152   
    ::aws_smithy_schema::ShapeId::from_static(
  153    153   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogAnomalyDetectorOutput$anomalyVisibilityTime",
  154    154   
        "com.amazonaws.cloudwatchlogs.synthetic",
  155    155   
        "GetLogAnomalyDetectorOutput",
  156    156   
    ),
  157    157   
    ::aws_smithy_schema::ShapeType::Long,
  158         -
    "anomaly_visibility_time",
         158  +
    "anomalyVisibilityTime",
  159    159   
    8,
  160    160   
);
         161  +
static GETLOGANOMALYDETECTOROUTPUT_MEMBER__REQUEST_ID: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
         162  +
    ::aws_smithy_schema::ShapeId::from_static("synthetic#request_id", "synthetic", "request_id"),
         163  +
    ::aws_smithy_schema::ShapeType::String,
         164  +
    "request_id",
         165  +
    9,
         166  +
)
         167  +
.with_http_header("x-amzn-requestid");
  161    168   
static GETLOGANOMALYDETECTOROUTPUT_SCHEMA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_struct(
  162    169   
    GETLOGANOMALYDETECTOROUTPUT_SCHEMA_ID,
  163    170   
    ::aws_smithy_schema::ShapeType::Structure,
  164    171   
    &[
  165    172   
        &GETLOGANOMALYDETECTOROUTPUT_MEMBER_DETECTOR_NAME,
  166    173   
        &GETLOGANOMALYDETECTOROUTPUT_MEMBER_LOG_GROUP_ARN_LIST,
  167    174   
        &GETLOGANOMALYDETECTOROUTPUT_MEMBER_EVALUATION_FREQUENCY,
  168    175   
        &GETLOGANOMALYDETECTOROUTPUT_MEMBER_FILTER_PATTERN,
  169    176   
        &GETLOGANOMALYDETECTOROUTPUT_MEMBER_ANOMALY_DETECTOR_STATUS,
  170    177   
        &GETLOGANOMALYDETECTOROUTPUT_MEMBER_KMS_KEY_ID,
  171    178   
        &GETLOGANOMALYDETECTOROUTPUT_MEMBER_CREATION_TIME_STAMP,
  172    179   
        &GETLOGANOMALYDETECTOROUTPUT_MEMBER_LAST_MODIFIED_TIME_STAMP,
  173    180   
        &GETLOGANOMALYDETECTOROUTPUT_MEMBER_ANOMALY_VISIBILITY_TIME,
         181  +
        &GETLOGANOMALYDETECTOROUTPUT_MEMBER__REQUEST_ID,
  174    182   
    ],
  175    183   
);
  176    184   
impl GetLogAnomalyDetectorOutput {
  177    185   
    /// The schema for this shape.
  178    186   
    pub const SCHEMA: &'static ::aws_smithy_schema::Schema = &GETLOGANOMALYDETECTOROUTPUT_SCHEMA;
  179    187   
}
  180    188   
impl ::aws_smithy_schema::serde::SerializableStruct for GetLogAnomalyDetectorOutput {
  181    189   
    #[allow(unused_variables, clippy::diverging_sub_expression)]
  182    190   
    fn serialize_members(
  183    191   
        &self,
  184    192   
        ser: &mut dyn ::aws_smithy_schema::serde::ShapeSerializer,
  185    193   
    ) -> ::std::result::Result<(), ::aws_smithy_schema::serde::SerdeError> {
  186    194   
        if let Some(ref val) = self.detector_name {
  187    195   
            ser.write_string(&GETLOGANOMALYDETECTOROUTPUT_MEMBER_DETECTOR_NAME, val)?;
  188    196   
        }
  189    197   
        if let Some(ref val) = self.log_group_arn_list {
  190    198   
            ser.write_list(
  191    199   
                &GETLOGANOMALYDETECTOROUTPUT_MEMBER_LOG_GROUP_ARN_LIST,
  192    200   
                &|ser: &mut dyn ::aws_smithy_schema::serde::ShapeSerializer| {
  193    201   
                    for item in val {
  194    202   
                        ser.write_string(&aws_smithy_schema::prelude::STRING, item)?;
  195    203   
                    }
  196    204   
                    Ok(())
  197    205   
                },
  198    206   
            )?;
  199    207   
        }
  200    208   
        if let Some(ref val) = self.evaluation_frequency {
  201    209   
            ser.write_string(&GETLOGANOMALYDETECTOROUTPUT_MEMBER_EVALUATION_FREQUENCY, val.as_str())?;
  202    210   
        }
  203    211   
        if let Some(ref val) = self.filter_pattern {
  204    212   
            ser.write_string(&GETLOGANOMALYDETECTOROUTPUT_MEMBER_FILTER_PATTERN, val)?;
  205    213   
        }
  206    214   
        if let Some(ref val) = self.anomaly_detector_status {
  207    215   
            ser.write_string(&GETLOGANOMALYDETECTOROUTPUT_MEMBER_ANOMALY_DETECTOR_STATUS, val.as_str())?;
  208    216   
        }
  209    217   
        if let Some(ref val) = self.kms_key_id {
  210    218   
            ser.write_string(&GETLOGANOMALYDETECTOROUTPUT_MEMBER_KMS_KEY_ID, val)?;
  211    219   
        }
  212    220   
        {
  213    221   
            let val = &self.creation_time_stamp;
  214    222   
            ser.write_long(&GETLOGANOMALYDETECTOROUTPUT_MEMBER_CREATION_TIME_STAMP, *val)?;
  215    223   
        }
  216    224   
        {
  217    225   
            let val = &self.last_modified_time_stamp;
  218    226   
            ser.write_long(&GETLOGANOMALYDETECTOROUTPUT_MEMBER_LAST_MODIFIED_TIME_STAMP, *val)?;
  219    227   
        }
  220    228   
        if let Some(ref val) = self.anomaly_visibility_time {
  221    229   
            ser.write_long(&GETLOGANOMALYDETECTOROUTPUT_MEMBER_ANOMALY_VISIBILITY_TIME, *val)?;
  222    230   
        }
  223    231   
        Ok(())
  224    232   
    }
  225    233   
}
  226    234   
impl GetLogAnomalyDetectorOutput {
  227    235   
    /// Deserializes this structure from a [`ShapeDeserializer`].
  228         -
    pub fn deserialize<D: ::aws_smithy_schema::serde::ShapeDeserializer>(
  229         -
        deserializer: &mut D,
         236  +
    pub fn deserialize(
         237  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
         238  +
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
         239  +
        #[allow(unused_variables, unused_mut)]
         240  +
        let mut builder = Self::builder();
         241  +
        #[allow(
         242  +
            unused_variables,
         243  +
            unreachable_code,
         244  +
            clippy::single_match,
         245  +
            clippy::match_single_binding,
         246  +
            clippy::diverging_sub_expression
         247  +
        )]
         248  +
        deserializer.read_struct(&GETLOGANOMALYDETECTOROUTPUT_SCHEMA, &mut |member, deser| {
         249  +
            match member.member_index() {
         250  +
                Some(0) => {
         251  +
                    builder.detector_name = Some(deser.read_string(member)?);
         252  +
                }
         253  +
                Some(1) => {
         254  +
                    builder.log_group_arn_list = Some(deser.read_string_list(member)?);
         255  +
                }
         256  +
                Some(2) => {
         257  +
                    builder.evaluation_frequency = Some(crate::types::EvaluationFrequency::from(deser.read_string(member)?.as_str()));
         258  +
                }
         259  +
                Some(3) => {
         260  +
                    builder.filter_pattern = Some(deser.read_string(member)?);
         261  +
                }
         262  +
                Some(4) => {
         263  +
                    builder.anomaly_detector_status = Some(crate::types::AnomalyDetectorStatus::from(deser.read_string(member)?.as_str()));
         264  +
                }
         265  +
                Some(5) => {
         266  +
                    builder.kms_key_id = Some(deser.read_string(member)?);
         267  +
                }
         268  +
                Some(6) => {
         269  +
                    builder.creation_time_stamp = Some(deser.read_long(member)?);
         270  +
                }
         271  +
                Some(7) => {
         272  +
                    builder.last_modified_time_stamp = Some(deser.read_long(member)?);
         273  +
                }
         274  +
                Some(8) => {
         275  +
                    builder.anomaly_visibility_time = Some(deser.read_long(member)?);
         276  +
                }
         277  +
                Some(9) => {
         278  +
                    builder._request_id = Some(deser.read_string(member)?);
         279  +
                }
         280  +
                _ => {}
         281  +
            }
         282  +
            Ok(())
         283  +
        })?;
         284  +
        Ok(builder.build())
         285  +
    }
         286  +
}
         287  +
impl GetLogAnomalyDetectorOutput {
         288  +
    /// Deserializes this structure from a body deserializer and HTTP response headers.
         289  +
    /// Header-bound members are read directly from headers, avoiding runtime
         290  +
    /// member iteration overhead. Body members are read via the deserializer.
         291  +
    pub fn deserialize_with_response(
         292  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
         293  +
        headers: &::aws_smithy_runtime_api::http::Headers,
         294  +
        _status: u16,
         295  +
        _body: &[u8],
  230    296   
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
  231    297   
        #[allow(unused_variables, unused_mut)]
  232    298   
        let mut builder = Self::builder();
         299  +
        if let Some(val) = headers.get("x-amzn-requestid") {
         300  +
            builder._request_id = Some(val.to_string());
         301  +
        }
  233    302   
        #[allow(
  234    303   
            unused_variables,
  235    304   
            unreachable_code,
  236    305   
            clippy::single_match,
  237    306   
            clippy::match_single_binding,
  238    307   
            clippy::diverging_sub_expression
  239    308   
        )]
  240         -
        deserializer.read_struct(&GETLOGANOMALYDETECTOROUTPUT_SCHEMA, (), |_, member, deser| {
         309  +
        deserializer.read_struct(&GETLOGANOMALYDETECTOROUTPUT_SCHEMA, &mut |member, deser| {
  241    310   
            match member.member_index() {
  242    311   
                Some(0) => {
  243    312   
                    builder.detector_name = Some(deser.read_string(member)?);
  244    313   
                }
  245    314   
                Some(1) => {
  246         -
                    builder.log_group_arn_list = Some({
  247         -
                        let container = if let Some(cap) = deser.container_size() {
  248         -
                            Vec::with_capacity(cap)
  249         -
                        } else {
  250         -
                            Vec::new()
  251         -
                        };
  252         -
                        deser.read_list(member, container, |mut list, deser| {
  253         -
                            list.push(deser.read_string(member)?);
  254         -
                            Ok(list)
  255         -
                        })?
  256         -
                    });
         315  +
                    builder.log_group_arn_list = Some(deser.read_string_list(member)?);
  257    316   
                }
  258    317   
                Some(2) => {
  259    318   
                    builder.evaluation_frequency = Some(crate::types::EvaluationFrequency::from(deser.read_string(member)?.as_str()));
  260    319   
                }
  261    320   
                Some(3) => {
  262    321   
                    builder.filter_pattern = Some(deser.read_string(member)?);
  263    322   
                }
  264    323   
                Some(4) => {
  265    324   
                    builder.anomaly_detector_status = Some(crate::types::AnomalyDetectorStatus::from(deser.read_string(member)?.as_str()));
  266    325   
                }

tmp-codegen-diff/aws-sdk/sdk/cloudwatchlogs/src/operation/get_log_events.rs

@@ -1,1 +40,44 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2      2   
/// Orchestration and serialization glue logic for `GetLogEvents`.
    3      3   
#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
    4      4   
#[non_exhaustive]
    5      5   
pub struct GetLogEvents;
    6      6   
impl GetLogEvents {
    7      7   
    /// Creates a new `GetLogEvents`
    8      8   
    pub fn new() -> Self {
    9      9   
        Self
   10     10   
    }
          11  +
    /// The schema for this operation's input shape.
          12  +
    pub const INPUT_SCHEMA: &'static ::aws_smithy_schema::Schema = crate::operation::get_log_events::GetLogEventsInput::SCHEMA;
          13  +
    /// The schema for this operation's output shape.
          14  +
    pub const OUTPUT_SCHEMA: &'static ::aws_smithy_schema::Schema = crate::operation::get_log_events::GetLogEventsOutput::SCHEMA;
   11     15   
    pub(crate) async fn orchestrate(
   12     16   
        runtime_plugins: &::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
   13     17   
        input: crate::operation::get_log_events::GetLogEventsInput,
   14     18   
    ) -> ::std::result::Result<
   15     19   
        crate::operation::get_log_events::GetLogEventsOutput,
   16     20   
        ::aws_smithy_runtime_api::client::result::SdkError<
   17     21   
            crate::operation::get_log_events::GetLogEventsError,
   18     22   
            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
   19     23   
        >,
   20     24   
    > {
@@ -118,122 +245,330 @@
  138    142   
                crate::operation::get_log_events::GetLogEventsError,
  139    143   
            >::new());
  140    144   
  141    145   
        ::std::borrow::Cow::Owned(rcb)
  142    146   
    }
  143    147   
}
  144    148   
  145    149   
#[derive(Debug)]
  146    150   
struct GetLogEventsResponseDeserializer;
  147    151   
impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for GetLogEventsResponseDeserializer {
  148         -
    fn deserialize_nonstreaming(
         152  +
    fn deserialize_nonstreaming_with_config(
  149    153   
        &self,
  150    154   
        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
         155  +
        _cfg: &::aws_smithy_types::config_bag::ConfigBag,
  151    156   
    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
  152    157   
        let (success, status) = (response.status().is_success(), response.status().as_u16());
  153         -
        let headers = response.headers();
  154         -
        let body = response.body().bytes().expect("body loaded");
  155    158   
        #[allow(unused_mut)]
  156    159   
        let mut force_error = false;
  157    160   
        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
  158         -
        let parse_result = if !success && status != 200 || force_error {
  159         -
            crate::protocol_serde::shape_get_log_events::de_get_log_events_http_error(status, headers, body)
  160         -
        } else {
  161         -
            crate::protocol_serde::shape_get_log_events::de_get_log_events_http_response(status, headers, body)
         161  +
        if !success && status != 200 || force_error {
         162  +
            let headers = response.headers();
         163  +
            let body = response.body().bytes().expect("body loaded");
         164  +
            #[allow(unused_mut)]
         165  +
            let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(status, headers, body).map_err(|e| {
         166  +
                ::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(::aws_smithy_runtime_api::box_error::BoxError::from(e))
         167  +
            })?;
         168  +
            generic_builder = ::aws_types::request_id::apply_request_id(generic_builder, headers);
         169  +
            let generic = generic_builder.build();
         170  +
            let error_code = match generic.code() {
         171  +
                ::std::option::Option::Some(code) => code,
         172  +
                ::std::option::Option::None => {
         173  +
                    return ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(
         174  +
                        ::aws_smithy_runtime_api::box_error::BoxError::from(crate::operation::get_log_events::GetLogEventsError::unhandled(generic)),
         175  +
                    ))
         176  +
                }
  162    177   
            };
  163         -
        crate::protocol_serde::type_erase_result(parse_result)
         178  +
            let _error_message = generic.message().map(|msg| msg.to_owned());
         179  +
            let protocol = _cfg
         180  +
                .load::<::aws_smithy_schema::protocol::SharedClientProtocol>()
         181  +
                .expect("a SharedClientProtocol is required");
         182  +
            let err = match error_code {
         183  +
                "InvalidParameterException" => crate::operation::get_log_events::GetLogEventsError::InvalidParameterException({
         184  +
                    let mut tmp = match protocol
         185  +
                        .deserialize_response(response, crate::types::error::InvalidParameterException::SCHEMA, _cfg)
         186  +
                        .and_then(|mut deser| {
         187  +
                            crate::types::error::InvalidParameterException::deserialize_with_response(
         188  +
                                &mut *deser,
         189  +
                                response.headers(),
         190  +
                                response.status().into(),
         191  +
                                body,
         192  +
                            )
         193  +
                        }) {
         194  +
                        ::std::result::Result::Ok(val) => val,
         195  +
                        ::std::result::Result::Err(e) => {
         196  +
                            return ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(
         197  +
                                ::aws_smithy_runtime_api::box_error::BoxError::from(e),
         198  +
                            ))
         199  +
                        }
         200  +
                    };
         201  +
                    tmp.meta = generic;
         202  +
                    if tmp.message.is_none() {
         203  +
                        tmp.message = _error_message;
         204  +
                    }
         205  +
                    tmp
         206  +
                }),
         207  +
                "ResourceNotFoundException" => crate::operation::get_log_events::GetLogEventsError::ResourceNotFoundException({
         208  +
                    let mut tmp = match protocol
         209  +
                        .deserialize_response(response, crate::types::error::ResourceNotFoundException::SCHEMA, _cfg)
         210  +
                        .and_then(|mut deser| {
         211  +
                            crate::types::error::ResourceNotFoundException::deserialize_with_response(
         212  +
                                &mut *deser,
         213  +
                                response.headers(),
         214  +
                                response.status().into(),
         215  +
                                body,
         216  +
                            )
         217  +
                        }) {
         218  +
                        ::std::result::Result::Ok(val) => val,
         219  +
                        ::std::result::Result::Err(e) => {
         220  +
                            return ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(
         221  +
                                ::aws_smithy_runtime_api::box_error::BoxError::from(e),
         222  +
                            ))
         223  +
                        }
         224  +
                    };
         225  +
                    tmp.meta = generic;
         226  +
                    if tmp.message.is_none() {
         227  +
                        tmp.message = _error_message;
         228  +
                    }
         229  +
                    tmp
         230  +
                }),
         231  +
                "ServiceUnavailableException" => crate::operation::get_log_events::GetLogEventsError::ServiceUnavailableException({
         232  +
                    let mut tmp = match protocol
         233  +
                        .deserialize_response(response, crate::types::error::ServiceUnavailableException::SCHEMA, _cfg)
         234  +
                        .and_then(|mut deser| {
         235  +
                            crate::types::error::ServiceUnavailableException::deserialize_with_response(
         236  +
                                &mut *deser,
         237  +
                                response.headers(),
         238  +
                                response.status().into(),
         239  +
                                body,
         240  +
                            )
         241  +
                        }) {
         242  +
                        ::std::result::Result::Ok(val) => val,
         243  +
                        ::std::result::Result::Err(e) => {
         244  +
                            return ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(
         245  +
                                ::aws_smithy_runtime_api::box_error::BoxError::from(e),
         246  +
                            ))
         247  +
                        }
         248  +
                    };
         249  +
                    tmp.meta = generic;
         250  +
                    if tmp.message.is_none() {
         251  +
                        tmp.message = _error_message;
         252  +
                    }
         253  +
                    tmp
         254  +
                }),
         255  +
                _ => crate::operation::get_log_events::GetLogEventsError::generic(generic),
         256  +
            };
         257  +
            ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::operation(
         258  +
                ::aws_smithy_runtime_api::client::interceptors::context::Error::erase(err),
         259  +
            ))
         260  +
        } else {
         261  +
            let protocol = _cfg
         262  +
                .load::<::aws_smithy_schema::protocol::SharedClientProtocol>()
         263  +
                .expect("a SharedClientProtocol is required");
         264  +
            let mut deser = protocol.deserialize_response(response, GetLogEvents::OUTPUT_SCHEMA, _cfg).map_err(|e| {
         265  +
                ::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(::aws_smithy_runtime_api::box_error::BoxError::from(e))
         266  +
            })?;
         267  +
            let body = response.body().bytes().expect("body loaded");
         268  +
            let output = crate::operation::get_log_events::GetLogEventsOutput::deserialize_with_response(
         269  +
                &mut *deser,
         270  +
                response.headers(),
         271  +
                response.status().into(),
         272  +
                body,
         273  +
            )
         274  +
            .map_err(|e| {
         275  +
                ::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(::aws_smithy_runtime_api::box_error::BoxError::from(e))
         276  +
            })?;
         277  +
            ::std::result::Result::Ok(::aws_smithy_runtime_api::client::interceptors::context::Output::erase(output))
         278  +
        }
  164    279   
    }
  165    280   
}
  166    281   
#[derive(Debug)]
  167    282   
struct GetLogEventsRequestSerializer;
  168    283   
impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for GetLogEventsRequestSerializer {
  169    284   
    #[allow(unused_mut, clippy::let_and_return, clippy::needless_borrow, clippy::useless_conversion)]
  170    285   
    fn serialize_input(
  171    286   
        &self,
  172    287   
        input: ::aws_smithy_runtime_api::client::interceptors::context::Input,
  173    288   
        _cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
  174    289   
    ) -> ::std::result::Result<::aws_smithy_runtime_api::client::orchestrator::HttpRequest, ::aws_smithy_runtime_api::box_error::BoxError> {
  175    290   
        let input = input
  176    291   
            .downcast::<crate::operation::get_log_events::GetLogEventsInput>()
  177    292   
            .expect("correct type");
  178         -
        let _header_serialization_settings = _cfg
  179         -
            .load::<crate::serialization_settings::HeaderSerializationSettings>()
  180         -
            .cloned()
  181         -
            .unwrap_or_default();
  182         -
        let mut request_builder = {
  183         -
            #[allow(clippy::uninlined_format_args)]
  184         -
            fn uri_base(
  185         -
                _input: &crate::operation::get_log_events::GetLogEventsInput,
  186         -
                output: &mut ::std::string::String,
  187         -
            ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
  188         -
                use ::std::fmt::Write as _;
  189         -
                ::std::write!(output, "/").expect("formatting should succeed");
  190         -
                ::std::result::Result::Ok(())
  191         -
            }
  192         -
            #[allow(clippy::unnecessary_wraps)]
  193         -
            fn update_http_builder(
  194         -
                input: &crate::operation::get_log_events::GetLogEventsInput,
  195         -
                builder: ::http_1x::request::Builder,
  196         -
            ) -> ::std::result::Result<::http_1x::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
  197         -
                let mut uri = ::std::string::String::new();
  198         -
                uri_base(input, &mut uri)?;
  199         -
                ::std::result::Result::Ok(builder.method("POST").uri(uri))
  200         -
            }
  201         -
            let mut builder = update_http_builder(&input, ::http_1x::request::Builder::new())?;
  202         -
            builder = _header_serialization_settings.set_default_header(builder, ::http_1x::header::CONTENT_TYPE, "application/x-amz-json-1.1");
  203         -
            builder = _header_serialization_settings.set_default_header(
  204         -
                builder,
  205         -
                ::http_1x::header::HeaderName::from_static("x-amz-target"),
  206         -
                "Logs_20140328.GetLogEvents",
  207         -
            );
  208         -
            builder
  209         -
        };
  210         -
        let body = ::aws_smithy_types::body::SdkBody::from(crate::protocol_serde::shape_get_log_events::ser_get_log_events_input(&input)?);
  211         -
        if let Some(content_length) = body.content_length() {
  212         -
            let content_length = content_length.to_string();
  213         -
            request_builder = _header_serialization_settings.set_default_header(request_builder, ::http_1x::header::CONTENT_LENGTH, &content_length);
  214         -
        }
  215         -
        ::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
         293  +
        let protocol = _cfg
         294  +
            .load::<::aws_smithy_schema::protocol::SharedClientProtocol>()
         295  +
            .expect("a SharedClientProtocol is required");
         296  +
        let mut request = protocol
         297  +
            .serialize_request(&input, GetLogEvents::INPUT_SCHEMA, "", _cfg)
         298  +
            .map_err(::aws_smithy_runtime_api::box_error::BoxError::from)?;
         299  +
         300  +
        return ::std::result::Result::Ok(request);
  216    301   
    }
  217    302   
}
  218    303   
#[derive(Debug)]
  219    304   
struct GetLogEventsEndpointParamsInterceptor;
  220    305   
  221    306   
impl ::aws_smithy_runtime_api::client::interceptors::Intercept for GetLogEventsEndpointParamsInterceptor {
  222    307   
    fn name(&self) -> &'static str {
  223    308   
        "GetLogEventsEndpointParamsInterceptor"
  224    309   
    }
  225    310   

tmp-codegen-diff/aws-sdk/sdk/cloudwatchlogs/src/operation/get_log_events/_get_log_events_input.rs

@@ -57,57 +187,187 @@
   77     77   
    "com.amazonaws.cloudwatchlogs.synthetic",
   78     78   
    "GetLogEventsInput",
   79     79   
);
   80     80   
static GETLOGEVENTSINPUT_MEMBER_LOG_GROUP_NAME: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   81     81   
    ::aws_smithy_schema::ShapeId::from_static(
   82     82   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogEventsInput$logGroupName",
   83     83   
        "com.amazonaws.cloudwatchlogs.synthetic",
   84     84   
        "GetLogEventsInput",
   85     85   
    ),
   86     86   
    ::aws_smithy_schema::ShapeType::String,
   87         -
    "log_group_name",
          87  +
    "logGroupName",
   88     88   
    0,
   89     89   
);
   90     90   
static GETLOGEVENTSINPUT_MEMBER_LOG_GROUP_IDENTIFIER: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   91     91   
    ::aws_smithy_schema::ShapeId::from_static(
   92     92   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogEventsInput$logGroupIdentifier",
   93     93   
        "com.amazonaws.cloudwatchlogs.synthetic",
   94     94   
        "GetLogEventsInput",
   95     95   
    ),
   96     96   
    ::aws_smithy_schema::ShapeType::String,
   97         -
    "log_group_identifier",
          97  +
    "logGroupIdentifier",
   98     98   
    1,
   99     99   
);
  100    100   
static GETLOGEVENTSINPUT_MEMBER_LOG_STREAM_NAME: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  101    101   
    ::aws_smithy_schema::ShapeId::from_static(
  102    102   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogEventsInput$logStreamName",
  103    103   
        "com.amazonaws.cloudwatchlogs.synthetic",
  104    104   
        "GetLogEventsInput",
  105    105   
    ),
  106    106   
    ::aws_smithy_schema::ShapeType::String,
  107         -
    "log_stream_name",
         107  +
    "logStreamName",
  108    108   
    2,
  109    109   
);
  110    110   
static GETLOGEVENTSINPUT_MEMBER_START_TIME: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  111    111   
    ::aws_smithy_schema::ShapeId::from_static(
  112    112   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogEventsInput$startTime",
  113    113   
        "com.amazonaws.cloudwatchlogs.synthetic",
  114    114   
        "GetLogEventsInput",
  115    115   
    ),
  116    116   
    ::aws_smithy_schema::ShapeType::Long,
  117         -
    "start_time",
         117  +
    "startTime",
  118    118   
    3,
  119    119   
);
  120    120   
static GETLOGEVENTSINPUT_MEMBER_END_TIME: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  121    121   
    ::aws_smithy_schema::ShapeId::from_static(
  122    122   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogEventsInput$endTime",
  123    123   
        "com.amazonaws.cloudwatchlogs.synthetic",
  124    124   
        "GetLogEventsInput",
  125    125   
    ),
  126    126   
    ::aws_smithy_schema::ShapeType::Long,
  127         -
    "end_time",
         127  +
    "endTime",
  128    128   
    4,
  129    129   
);
  130    130   
static GETLOGEVENTSINPUT_MEMBER_NEXT_TOKEN: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  131    131   
    ::aws_smithy_schema::ShapeId::from_static(
  132    132   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogEventsInput$nextToken",
  133    133   
        "com.amazonaws.cloudwatchlogs.synthetic",
  134    134   
        "GetLogEventsInput",
  135    135   
    ),
  136    136   
    ::aws_smithy_schema::ShapeType::String,
  137         -
    "next_token",
         137  +
    "nextToken",
  138    138   
    5,
  139    139   
);
  140    140   
static GETLOGEVENTSINPUT_MEMBER_LIMIT: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  141    141   
    ::aws_smithy_schema::ShapeId::from_static(
  142    142   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogEventsInput$limit",
  143    143   
        "com.amazonaws.cloudwatchlogs.synthetic",
  144    144   
        "GetLogEventsInput",
  145    145   
    ),
  146    146   
    ::aws_smithy_schema::ShapeType::Integer,
  147    147   
    "limit",
  148    148   
    6,
  149    149   
);
  150    150   
static GETLOGEVENTSINPUT_MEMBER_START_FROM_HEAD: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  151    151   
    ::aws_smithy_schema::ShapeId::from_static(
  152    152   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogEventsInput$startFromHead",
  153    153   
        "com.amazonaws.cloudwatchlogs.synthetic",
  154    154   
        "GetLogEventsInput",
  155    155   
    ),
  156    156   
    ::aws_smithy_schema::ShapeType::Boolean,
  157         -
    "start_from_head",
         157  +
    "startFromHead",
  158    158   
    7,
  159    159   
);
  160    160   
static GETLOGEVENTSINPUT_MEMBER_UNMASK: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  161    161   
    ::aws_smithy_schema::ShapeId::from_static(
  162    162   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogEventsInput$unmask",
  163    163   
        "com.amazonaws.cloudwatchlogs.synthetic",
  164    164   
        "GetLogEventsInput",
  165    165   
    ),
  166    166   
    ::aws_smithy_schema::ShapeType::Boolean,
  167    167   
    "unmask",
@@ -197,197 +306,318 @@
  217    217   
            ser.write_boolean(&GETLOGEVENTSINPUT_MEMBER_START_FROM_HEAD, *val)?;
  218    218   
        }
  219    219   
        if let Some(ref val) = self.unmask {
  220    220   
            ser.write_boolean(&GETLOGEVENTSINPUT_MEMBER_UNMASK, *val)?;
  221    221   
        }
  222    222   
        Ok(())
  223    223   
    }
  224    224   
}
  225    225   
impl GetLogEventsInput {
  226    226   
    /// Deserializes this structure from a [`ShapeDeserializer`].
  227         -
    pub fn deserialize<D: ::aws_smithy_schema::serde::ShapeDeserializer>(
  228         -
        deserializer: &mut D,
         227  +
    pub fn deserialize(
         228  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
  229    229   
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
  230    230   
        #[allow(unused_variables, unused_mut)]
  231    231   
        let mut builder = Self::builder();
  232    232   
        #[allow(
  233    233   
            unused_variables,
  234    234   
            unreachable_code,
  235    235   
            clippy::single_match,
  236    236   
            clippy::match_single_binding,
  237    237   
            clippy::diverging_sub_expression
  238    238   
        )]
  239         -
        deserializer.read_struct(&GETLOGEVENTSINPUT_SCHEMA, (), |_, member, deser| {
         239  +
        deserializer.read_struct(&GETLOGEVENTSINPUT_SCHEMA, &mut |member, deser| {
  240    240   
            match member.member_index() {
  241    241   
                Some(0) => {
  242    242   
                    builder.log_group_name = Some(deser.read_string(member)?);
  243    243   
                }
  244    244   
                Some(1) => {
  245    245   
                    builder.log_group_identifier = Some(deser.read_string(member)?);
  246    246   
                }
  247    247   
                Some(2) => {
  248    248   
                    builder.log_stream_name = Some(deser.read_string(member)?);
  249    249   
                }
  250    250   
                Some(3) => {
  251    251   
                    builder.start_time = Some(deser.read_long(member)?);
  252    252   
                }
  253    253   
                Some(4) => {
  254    254   
                    builder.end_time = Some(deser.read_long(member)?);
  255    255   
                }
  256    256   
                Some(5) => {
  257    257   
                    builder.next_token = Some(deser.read_string(member)?);
  258    258   
                }
  259    259   
                Some(6) => {
  260    260   
                    builder.limit = Some(deser.read_integer(member)?);
  261    261   
                }
  262    262   
                Some(7) => {
  263    263   
                    builder.start_from_head = Some(deser.read_boolean(member)?);
  264    264   
                }
  265    265   
                Some(8) => {
  266    266   
                    builder.unmask = Some(deser.read_boolean(member)?);
  267    267   
                }
  268    268   
                _ => {}
  269    269   
            }
  270    270   
            Ok(())
  271    271   
        })?;
         272  +
        builder.log_stream_name = builder.log_stream_name.or(Some(String::new()));
  272    273   
        builder
  273    274   
            .build()
  274    275   
            .map_err(|e| aws_smithy_schema::serde::SerdeError::Custom { message: e.to_string() })
  275    276   
    }
  276    277   
}
         278  +
impl GetLogEventsInput {
         279  +
    /// Deserializes this structure from a body deserializer and HTTP response.
         280  +
    pub fn deserialize_with_response(
         281  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
         282  +
        _headers: &::aws_smithy_runtime_api::http::Headers,
         283  +
        _status: u16,
         284  +
        _body: &[u8],
         285  +
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
         286  +
        Self::deserialize(deserializer)
         287  +
    }
         288  +
}
  277    289   
impl GetLogEventsInput {
  278    290   
    /// Creates a new builder-style object to manufacture [`GetLogEventsInput`](crate::operation::get_log_events::GetLogEventsInput).
  279    291   
    pub fn builder() -> crate::operation::get_log_events::builders::GetLogEventsInputBuilder {
  280    292   
        crate::operation::get_log_events::builders::GetLogEventsInputBuilder::default()
  281    293   
    }
  282    294   
}
  283    295   
  284    296   
/// A builder for [`GetLogEventsInput`](crate::operation::get_log_events::GetLogEventsInput).
  285    297   
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
  286    298   
#[non_exhaustive]

tmp-codegen-diff/aws-sdk/sdk/cloudwatchlogs/src/operation/get_log_events/_get_log_events_output.rs

@@ -22,22 +160,215 @@
   42     42   
    "events",
   43     43   
    0,
   44     44   
);
   45     45   
static GETLOGEVENTSOUTPUT_MEMBER_NEXT_FORWARD_TOKEN: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   46     46   
    ::aws_smithy_schema::ShapeId::from_static(
   47     47   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogEventsOutput$nextForwardToken",
   48     48   
        "com.amazonaws.cloudwatchlogs.synthetic",
   49     49   
        "GetLogEventsOutput",
   50     50   
    ),
   51     51   
    ::aws_smithy_schema::ShapeType::String,
   52         -
    "next_forward_token",
          52  +
    "nextForwardToken",
   53     53   
    1,
   54     54   
);
   55     55   
static GETLOGEVENTSOUTPUT_MEMBER_NEXT_BACKWARD_TOKEN: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   56     56   
    ::aws_smithy_schema::ShapeId::from_static(
   57     57   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogEventsOutput$nextBackwardToken",
   58     58   
        "com.amazonaws.cloudwatchlogs.synthetic",
   59     59   
        "GetLogEventsOutput",
   60     60   
    ),
   61     61   
    ::aws_smithy_schema::ShapeType::String,
   62         -
    "next_backward_token",
          62  +
    "nextBackwardToken",
   63     63   
    2,
   64     64   
);
          65  +
static GETLOGEVENTSOUTPUT_MEMBER__REQUEST_ID: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
          66  +
    ::aws_smithy_schema::ShapeId::from_static("synthetic#request_id", "synthetic", "request_id"),
          67  +
    ::aws_smithy_schema::ShapeType::String,
          68  +
    "request_id",
          69  +
    3,
          70  +
)
          71  +
.with_http_header("x-amzn-requestid");
   65     72   
static GETLOGEVENTSOUTPUT_SCHEMA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_struct(
   66     73   
    GETLOGEVENTSOUTPUT_SCHEMA_ID,
   67     74   
    ::aws_smithy_schema::ShapeType::Structure,
   68     75   
    &[
   69     76   
        &GETLOGEVENTSOUTPUT_MEMBER_EVENTS,
   70     77   
        &GETLOGEVENTSOUTPUT_MEMBER_NEXT_FORWARD_TOKEN,
   71     78   
        &GETLOGEVENTSOUTPUT_MEMBER_NEXT_BACKWARD_TOKEN,
          79  +
        &GETLOGEVENTSOUTPUT_MEMBER__REQUEST_ID,
   72     80   
    ],
   73     81   
);
   74     82   
impl GetLogEventsOutput {
   75     83   
    /// The schema for this shape.
   76     84   
    pub const SCHEMA: &'static ::aws_smithy_schema::Schema = &GETLOGEVENTSOUTPUT_SCHEMA;
   77     85   
}
   78     86   
impl ::aws_smithy_schema::serde::SerializableStruct for GetLogEventsOutput {
   79     87   
    #[allow(unused_variables, clippy::diverging_sub_expression)]
   80     88   
    fn serialize_members(
   81     89   
        &self,
   82     90   
        ser: &mut dyn ::aws_smithy_schema::serde::ShapeSerializer,
   83     91   
    ) -> ::std::result::Result<(), ::aws_smithy_schema::serde::SerdeError> {
   84     92   
        if let Some(ref val) = self.events {
   85     93   
            ser.write_list(
   86     94   
                &GETLOGEVENTSOUTPUT_MEMBER_EVENTS,
   87     95   
                &|ser: &mut dyn ::aws_smithy_schema::serde::ShapeSerializer| {
   88     96   
                    for item in val {
   89     97   
                        ser.write_struct(crate::types::OutputLogEvent::SCHEMA, item)?;
   90     98   
                    }
   91     99   
                    Ok(())
   92    100   
                },
   93    101   
            )?;
   94    102   
        }
   95    103   
        if let Some(ref val) = self.next_forward_token {
   96    104   
            ser.write_string(&GETLOGEVENTSOUTPUT_MEMBER_NEXT_FORWARD_TOKEN, val)?;
   97    105   
        }
   98    106   
        if let Some(ref val) = self.next_backward_token {
   99    107   
            ser.write_string(&GETLOGEVENTSOUTPUT_MEMBER_NEXT_BACKWARD_TOKEN, val)?;
  100    108   
        }
  101    109   
        Ok(())
  102    110   
    }
  103    111   
}
  104    112   
impl GetLogEventsOutput {
  105    113   
    /// Deserializes this structure from a [`ShapeDeserializer`].
  106         -
    pub fn deserialize<D: ::aws_smithy_schema::serde::ShapeDeserializer>(
  107         -
        deserializer: &mut D,
         114  +
    pub fn deserialize(
         115  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
         116  +
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
         117  +
        #[allow(unused_variables, unused_mut)]
         118  +
        let mut builder = Self::builder();
         119  +
        #[allow(
         120  +
            unused_variables,
         121  +
            unreachable_code,
         122  +
            clippy::single_match,
         123  +
            clippy::match_single_binding,
         124  +
            clippy::diverging_sub_expression
         125  +
        )]
         126  +
        deserializer.read_struct(&GETLOGEVENTSOUTPUT_SCHEMA, &mut |member, deser| {
         127  +
            match member.member_index() {
         128  +
                Some(0) => {
         129  +
                    builder.events = Some({
         130  +
                        let mut container = Vec::new();
         131  +
                        deser.read_list(member, &mut |deser| {
         132  +
                            container.push(crate::types::OutputLogEvent::deserialize(deser)?);
         133  +
                            Ok(())
         134  +
                        })?;
         135  +
                        container
         136  +
                    });
         137  +
                }
         138  +
                Some(1) => {
         139  +
                    builder.next_forward_token = Some(deser.read_string(member)?);
         140  +
                }
         141  +
                Some(2) => {
         142  +
                    builder.next_backward_token = Some(deser.read_string(member)?);
         143  +
                }
         144  +
                Some(3) => {
         145  +
                    builder._request_id = Some(deser.read_string(member)?);
         146  +
                }
         147  +
                _ => {}
         148  +
            }
         149  +
            Ok(())
         150  +
        })?;
         151  +
        Ok(builder.build())
         152  +
    }
         153  +
}
         154  +
impl GetLogEventsOutput {
         155  +
    /// Deserializes this structure from a body deserializer and HTTP response headers.
         156  +
    /// Header-bound members are read directly from headers, avoiding runtime
         157  +
    /// member iteration overhead. Body members are read via the deserializer.
         158  +
    pub fn deserialize_with_response(
         159  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
         160  +
        headers: &::aws_smithy_runtime_api::http::Headers,
         161  +
        _status: u16,
         162  +
        _body: &[u8],
  108    163   
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
  109    164   
        #[allow(unused_variables, unused_mut)]
  110    165   
        let mut builder = Self::builder();
         166  +
        if let Some(val) = headers.get("x-amzn-requestid") {
         167  +
            builder._request_id = Some(val.to_string());
         168  +
        }
  111    169   
        #[allow(
  112    170   
            unused_variables,
  113    171   
            unreachable_code,
  114    172   
            clippy::single_match,
  115    173   
            clippy::match_single_binding,
  116    174   
            clippy::diverging_sub_expression
  117    175   
        )]
  118         -
        deserializer.read_struct(&GETLOGEVENTSOUTPUT_SCHEMA, (), |_, member, deser| {
         176  +
        deserializer.read_struct(&GETLOGEVENTSOUTPUT_SCHEMA, &mut |member, deser| {
  119    177   
            match member.member_index() {
  120    178   
                Some(0) => {
  121    179   
                    builder.events = Some({
  122         -
                        let container = if let Some(cap) = deser.container_size() {
  123         -
                            Vec::with_capacity(cap)
  124         -
                        } else {
  125         -
                            Vec::new()
  126         -
                        };
  127         -
                        deser.read_list(member, container, |mut list, deser| {
  128         -
                            list.push(crate::types::OutputLogEvent::deserialize(deser)?);
  129         -
                            Ok(list)
  130         -
                        })?
         180  +
                        let mut container = Vec::new();
         181  +
                        deser.read_list(member, &mut |deser| {
         182  +
                            container.push(crate::types::OutputLogEvent::deserialize(deser)?);
         183  +
                            Ok(())
         184  +
                        })?;
         185  +
                        container
  131    186   
                    });
  132    187   
                }
  133    188   
                Some(1) => {
  134    189   
                    builder.next_forward_token = Some(deser.read_string(member)?);
  135    190   
                }
  136    191   
                Some(2) => {
  137    192   
                    builder.next_backward_token = Some(deser.read_string(member)?);
  138    193   
                }
  139    194   
                _ => {}
  140    195   
            }

tmp-codegen-diff/aws-sdk/sdk/cloudwatchlogs/src/operation/get_log_group_fields.rs

@@ -1,1 +40,44 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2      2   
/// Orchestration and serialization glue logic for `GetLogGroupFields`.
    3      3   
#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
    4      4   
#[non_exhaustive]
    5      5   
pub struct GetLogGroupFields;
    6      6   
impl GetLogGroupFields {
    7      7   
    /// Creates a new `GetLogGroupFields`
    8      8   
    pub fn new() -> Self {
    9      9   
        Self
   10     10   
    }
          11  +
    /// The schema for this operation's input shape.
          12  +
    pub const INPUT_SCHEMA: &'static ::aws_smithy_schema::Schema = crate::operation::get_log_group_fields::GetLogGroupFieldsInput::SCHEMA;
          13  +
    /// The schema for this operation's output shape.
          14  +
    pub const OUTPUT_SCHEMA: &'static ::aws_smithy_schema::Schema = crate::operation::get_log_group_fields::GetLogGroupFieldsOutput::SCHEMA;
   11     15   
    pub(crate) async fn orchestrate(
   12     16   
        runtime_plugins: &::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
   13     17   
        input: crate::operation::get_log_group_fields::GetLogGroupFieldsInput,
   14     18   
    ) -> ::std::result::Result<
   15     19   
        crate::operation::get_log_group_fields::GetLogGroupFieldsOutput,
   16     20   
        ::aws_smithy_runtime_api::client::result::SdkError<
   17     21   
            crate::operation::get_log_group_fields::GetLogGroupFieldsError,
   18     22   
            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
   19     23   
        >,
   20     24   
    > {
@@ -118,122 +246,358 @@
  138    142   
                crate::operation::get_log_group_fields::GetLogGroupFieldsError,
  139    143   
            >::new());
  140    144   
  141    145   
        ::std::borrow::Cow::Owned(rcb)
  142    146   
    }
  143    147   
}
  144    148   
  145    149   
#[derive(Debug)]
  146    150   
struct GetLogGroupFieldsResponseDeserializer;
  147    151   
impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for GetLogGroupFieldsResponseDeserializer {
  148         -
    fn deserialize_nonstreaming(
         152  +
    fn deserialize_nonstreaming_with_config(
  149    153   
        &self,
  150    154   
        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
         155  +
        _cfg: &::aws_smithy_types::config_bag::ConfigBag,
  151    156   
    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
  152    157   
        let (success, status) = (response.status().is_success(), response.status().as_u16());
  153         -
        let headers = response.headers();
  154         -
        let body = response.body().bytes().expect("body loaded");
  155    158   
        #[allow(unused_mut)]
  156    159   
        let mut force_error = false;
  157    160   
        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
  158         -
        let parse_result = if !success && status != 200 || force_error {
  159         -
            crate::protocol_serde::shape_get_log_group_fields::de_get_log_group_fields_http_error(status, headers, body)
  160         -
        } else {
  161         -
            crate::protocol_serde::shape_get_log_group_fields::de_get_log_group_fields_http_response(status, headers, body)
         161  +
        if !success && status != 200 || force_error {
         162  +
            let headers = response.headers();
         163  +
            let body = response.body().bytes().expect("body loaded");
         164  +
            #[allow(unused_mut)]
         165  +
            let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(status, headers, body).map_err(|e| {
         166  +
                ::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(::aws_smithy_runtime_api::box_error::BoxError::from(e))
         167  +
            })?;
         168  +
            generic_builder = ::aws_types::request_id::apply_request_id(generic_builder, headers);
         169  +
            let generic = generic_builder.build();
         170  +
            let error_code = match generic.code() {
         171  +
                ::std::option::Option::Some(code) => code,
         172  +
                ::std::option::Option::None => {
         173  +
                    return ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(
         174  +
                        ::aws_smithy_runtime_api::box_error::BoxError::from(
         175  +
                            crate::operation::get_log_group_fields::GetLogGroupFieldsError::unhandled(generic),
         176  +
                        ),
         177  +
                    ))
         178  +
                }
         179  +
            };
         180  +
            let _error_message = generic.message().map(|msg| msg.to_owned());
         181  +
            let protocol = _cfg
         182  +
                .load::<::aws_smithy_schema::protocol::SharedClientProtocol>()
         183  +
                .expect("a SharedClientProtocol is required");
         184  +
            let err = match error_code {
         185  +
                "InvalidParameterException" => crate::operation::get_log_group_fields::GetLogGroupFieldsError::InvalidParameterException({
         186  +
                    let mut tmp = match protocol
         187  +
                        .deserialize_response(response, crate::types::error::InvalidParameterException::SCHEMA, _cfg)
         188  +
                        .and_then(|mut deser| {
         189  +
                            crate::types::error::InvalidParameterException::deserialize_with_response(
         190  +
                                &mut *deser,
         191  +
                                response.headers(),
         192  +
                                response.status().into(),
         193  +
                                body,
         194  +
                            )
         195  +
                        }) {
         196  +
                        ::std::result::Result::Ok(val) => val,
         197  +
                        ::std::result::Result::Err(e) => {
         198  +
                            return ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(
         199  +
                                ::aws_smithy_runtime_api::box_error::BoxError::from(e),
         200  +
                            ))
         201  +
                        }
         202  +
                    };
         203  +
                    tmp.meta = generic;
         204  +
                    if tmp.message.is_none() {
         205  +
                        tmp.message = _error_message;
         206  +
                    }
         207  +
                    tmp
         208  +
                }),
         209  +
                "LimitExceededException" => crate::operation::get_log_group_fields::GetLogGroupFieldsError::LimitExceededException({
         210  +
                    let mut tmp = match protocol
         211  +
                        .deserialize_response(response, crate::types::error::LimitExceededException::SCHEMA, _cfg)
         212  +
                        .and_then(|mut deser| {
         213  +
                            crate::types::error::LimitExceededException::deserialize_with_response(
         214  +
                                &mut *deser,
         215  +
                                response.headers(),
         216  +
                                response.status().into(),
         217  +
                                body,
         218  +
                            )
         219  +
                        }) {
         220  +
                        ::std::result::Result::Ok(val) => val,
         221  +
                        ::std::result::Result::Err(e) => {
         222  +
                            return ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(
         223  +
                                ::aws_smithy_runtime_api::box_error::BoxError::from(e),
         224  +
                            ))
         225  +
                        }
  162    226   
                    };
  163         -
        crate::protocol_serde::type_erase_result(parse_result)
         227  +
                    tmp.meta = generic;
         228  +
                    if tmp.message.is_none() {
         229  +
                        tmp.message = _error_message;
         230  +
                    }
         231  +
                    tmp
         232  +
                }),
         233  +
                "ResourceNotFoundException" => crate::operation::get_log_group_fields::GetLogGroupFieldsError::ResourceNotFoundException({
         234  +
                    let mut tmp = match protocol
         235  +
                        .deserialize_response(response, crate::types::error::ResourceNotFoundException::SCHEMA, _cfg)
         236  +
                        .and_then(|mut deser| {
         237  +
                            crate::types::error::ResourceNotFoundException::deserialize_with_response(
         238  +
                                &mut *deser,
         239  +
                                response.headers(),
         240  +
                                response.status().into(),
         241  +
                                body,
         242  +
                            )
         243  +
                        }) {
         244  +
                        ::std::result::Result::Ok(val) => val,
         245  +
                        ::std::result::Result::Err(e) => {
         246  +
                            return ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(
         247  +
                                ::aws_smithy_runtime_api::box_error::BoxError::from(e),
         248  +
                            ))
         249  +
                        }
         250  +
                    };
         251  +
                    tmp.meta = generic;
         252  +
                    if tmp.message.is_none() {
         253  +
                        tmp.message = _error_message;
         254  +
                    }
         255  +
                    tmp
         256  +
                }),
         257  +
                "ServiceUnavailableException" => crate::operation::get_log_group_fields::GetLogGroupFieldsError::ServiceUnavailableException({
         258  +
                    let mut tmp = match protocol
         259  +
                        .deserialize_response(response, crate::types::error::ServiceUnavailableException::SCHEMA, _cfg)
         260  +
                        .and_then(|mut deser| {
         261  +
                            crate::types::error::ServiceUnavailableException::deserialize_with_response(
         262  +
                                &mut *deser,
         263  +
                                response.headers(),
         264  +
                                response.status().into(),
         265  +
                                body,
         266  +
                            )
         267  +
                        }) {
         268  +
                        ::std::result::Result::Ok(val) => val,
         269  +
                        ::std::result::Result::Err(e) => {
         270  +
                            return ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(
         271  +
                                ::aws_smithy_runtime_api::box_error::BoxError::from(e),
         272  +
                            ))
         273  +
                        }
         274  +
                    };
         275  +
                    tmp.meta = generic;
         276  +
                    if tmp.message.is_none() {
         277  +
                        tmp.message = _error_message;
         278  +
                    }
         279  +
                    tmp
         280  +
                }),
         281  +
                _ => crate::operation::get_log_group_fields::GetLogGroupFieldsError::generic(generic),
         282  +
            };
         283  +
            ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::operation(
         284  +
                ::aws_smithy_runtime_api::client::interceptors::context::Error::erase(err),
         285  +
            ))
         286  +
        } else {
         287  +
            let protocol = _cfg
         288  +
                .load::<::aws_smithy_schema::protocol::SharedClientProtocol>()
         289  +
                .expect("a SharedClientProtocol is required");
         290  +
            let mut deser = protocol
         291  +
                .deserialize_response(response, GetLogGroupFields::OUTPUT_SCHEMA, _cfg)
         292  +
                .map_err(|e| {
         293  +
                    ::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(::aws_smithy_runtime_api::box_error::BoxError::from(e))
         294  +
                })?;
         295  +
            let body = response.body().bytes().expect("body loaded");
         296  +
            let output = crate::operation::get_log_group_fields::GetLogGroupFieldsOutput::deserialize_with_response(
         297  +
                &mut *deser,
         298  +
                response.headers(),
         299  +
                response.status().into(),
         300  +
                body,
         301  +
            )
         302  +
            .map_err(|e| {
         303  +
                ::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(::aws_smithy_runtime_api::box_error::BoxError::from(e))
         304  +
            })?;
         305  +
            ::std::result::Result::Ok(::aws_smithy_runtime_api::client::interceptors::context::Output::erase(output))
         306  +
        }
  164    307   
    }
  165    308   
}
  166    309   
#[derive(Debug)]
  167    310   
struct GetLogGroupFieldsRequestSerializer;
  168    311   
impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for GetLogGroupFieldsRequestSerializer {
  169    312   
    #[allow(unused_mut, clippy::let_and_return, clippy::needless_borrow, clippy::useless_conversion)]
  170    313   
    fn serialize_input(
  171    314   
        &self,
  172    315   
        input: ::aws_smithy_runtime_api::client::interceptors::context::Input,
  173    316   
        _cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
  174    317   
    ) -> ::std::result::Result<::aws_smithy_runtime_api::client::orchestrator::HttpRequest, ::aws_smithy_runtime_api::box_error::BoxError> {
  175    318   
        let input = input
  176    319   
            .downcast::<crate::operation::get_log_group_fields::GetLogGroupFieldsInput>()
  177    320   
            .expect("correct type");
  178         -
        let _header_serialization_settings = _cfg
  179         -
            .load::<crate::serialization_settings::HeaderSerializationSettings>()
  180         -
            .cloned()
  181         -
            .unwrap_or_default();
  182         -
        let mut request_builder = {
  183         -
            #[allow(clippy::uninlined_format_args)]
  184         -
            fn uri_base(
  185         -
                _input: &crate::operation::get_log_group_fields::GetLogGroupFieldsInput,
  186         -
                output: &mut ::std::string::String,
  187         -
            ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
  188         -
                use ::std::fmt::Write as _;
  189         -
                ::std::write!(output, "/").expect("formatting should succeed");
  190         -
                ::std::result::Result::Ok(())
  191         -
            }
  192         -
            #[allow(clippy::unnecessary_wraps)]
  193         -
            fn update_http_builder(
  194         -
                input: &crate::operation::get_log_group_fields::GetLogGroupFieldsInput,
  195         -
                builder: ::http_1x::request::Builder,
  196         -
            ) -> ::std::result::Result<::http_1x::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
  197         -
                let mut uri = ::std::string::String::new();
  198         -
                uri_base(input, &mut uri)?;
  199         -
                ::std::result::Result::Ok(builder.method("POST").uri(uri))
  200         -
            }
  201         -
            let mut builder = update_http_builder(&input, ::http_1x::request::Builder::new())?;
  202         -
            builder = _header_serialization_settings.set_default_header(builder, ::http_1x::header::CONTENT_TYPE, "application/x-amz-json-1.1");
  203         -
            builder = _header_serialization_settings.set_default_header(
  204         -
                builder,
  205         -
                ::http_1x::header::HeaderName::from_static("x-amz-target"),
  206         -
                "Logs_20140328.GetLogGroupFields",
  207         -
            );
  208         -
            builder
  209         -
        };
  210         -
        let body =
  211         -
            ::aws_smithy_types::body::SdkBody::from(crate::protocol_serde::shape_get_log_group_fields::ser_get_log_group_fields_input(&input)?);
  212         -
        if let Some(content_length) = body.content_length() {
  213         -
            let content_length = content_length.to_string();
  214         -
            request_builder = _header_serialization_settings.set_default_header(request_builder, ::http_1x::header::CONTENT_LENGTH, &content_length);
  215         -
        }
  216         -
        ::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
         321  +
        let protocol = _cfg
         322  +
            .load::<::aws_smithy_schema::protocol::SharedClientProtocol>()
         323  +
            .expect("a SharedClientProtocol is required");
         324  +
        let mut request = protocol
         325  +
            .serialize_request(&input, GetLogGroupFields::INPUT_SCHEMA, "", _cfg)
         326  +
            .map_err(::aws_smithy_runtime_api::box_error::BoxError::from)?;
         327  +
         328  +
        return ::std::result::Result::Ok(request);
  217    329   
    }
  218    330   
}
  219    331   
#[derive(Debug)]
  220    332   
struct GetLogGroupFieldsEndpointParamsInterceptor;
  221    333   
  222    334   
impl ::aws_smithy_runtime_api::client::interceptors::Intercept for GetLogGroupFieldsEndpointParamsInterceptor {
  223    335   
    fn name(&self) -> &'static str {
  224    336   
        "GetLogGroupFieldsEndpointParamsInterceptor"
  225    337   
    }
  226    338   

tmp-codegen-diff/aws-sdk/sdk/cloudwatchlogs/src/operation/get_log_group_fields/_get_log_group_fields_input.rs

@@ -19,19 +166,177 @@
   39     39   
    "com.amazonaws.cloudwatchlogs.synthetic",
   40     40   
    "GetLogGroupFieldsInput",
   41     41   
);
   42     42   
static GETLOGGROUPFIELDSINPUT_MEMBER_LOG_GROUP_NAME: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   43     43   
    ::aws_smithy_schema::ShapeId::from_static(
   44     44   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogGroupFieldsInput$logGroupName",
   45     45   
        "com.amazonaws.cloudwatchlogs.synthetic",
   46     46   
        "GetLogGroupFieldsInput",
   47     47   
    ),
   48     48   
    ::aws_smithy_schema::ShapeType::String,
   49         -
    "log_group_name",
          49  +
    "logGroupName",
   50     50   
    0,
   51     51   
);
   52     52   
static GETLOGGROUPFIELDSINPUT_MEMBER_TIME: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   53     53   
    ::aws_smithy_schema::ShapeId::from_static(
   54     54   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogGroupFieldsInput$time",
   55     55   
        "com.amazonaws.cloudwatchlogs.synthetic",
   56     56   
        "GetLogGroupFieldsInput",
   57     57   
    ),
   58     58   
    ::aws_smithy_schema::ShapeType::Long,
   59     59   
    "time",
   60     60   
    1,
   61     61   
);
   62     62   
static GETLOGGROUPFIELDSINPUT_MEMBER_LOG_GROUP_IDENTIFIER: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   63     63   
    ::aws_smithy_schema::ShapeId::from_static(
   64     64   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogGroupFieldsInput$logGroupIdentifier",
   65     65   
        "com.amazonaws.cloudwatchlogs.synthetic",
   66     66   
        "GetLogGroupFieldsInput",
   67     67   
    ),
   68     68   
    ::aws_smithy_schema::ShapeType::String,
   69         -
    "log_group_identifier",
          69  +
    "logGroupIdentifier",
   70     70   
    2,
   71     71   
);
   72     72   
static GETLOGGROUPFIELDSINPUT_SCHEMA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_struct(
   73     73   
    GETLOGGROUPFIELDSINPUT_SCHEMA_ID,
   74     74   
    ::aws_smithy_schema::ShapeType::Structure,
   75     75   
    &[
   76     76   
        &GETLOGGROUPFIELDSINPUT_MEMBER_LOG_GROUP_NAME,
   77     77   
        &GETLOGGROUPFIELDSINPUT_MEMBER_TIME,
   78     78   
        &GETLOGGROUPFIELDSINPUT_MEMBER_LOG_GROUP_IDENTIFIER,
   79     79   
    ],
   80     80   
);
   81     81   
impl GetLogGroupFieldsInput {
   82     82   
    /// The schema for this shape.
   83     83   
    pub const SCHEMA: &'static ::aws_smithy_schema::Schema = &GETLOGGROUPFIELDSINPUT_SCHEMA;
   84     84   
}
   85     85   
impl ::aws_smithy_schema::serde::SerializableStruct for GetLogGroupFieldsInput {
   86     86   
    #[allow(unused_variables, clippy::diverging_sub_expression)]
   87     87   
    fn serialize_members(
   88     88   
        &self,
   89     89   
        ser: &mut dyn ::aws_smithy_schema::serde::ShapeSerializer,
   90     90   
    ) -> ::std::result::Result<(), ::aws_smithy_schema::serde::SerdeError> {
   91     91   
        if let Some(ref val) = self.log_group_name {
   92     92   
            ser.write_string(&GETLOGGROUPFIELDSINPUT_MEMBER_LOG_GROUP_NAME, val)?;
   93     93   
        }
   94     94   
        if let Some(ref val) = self.time {
   95     95   
            ser.write_long(&GETLOGGROUPFIELDSINPUT_MEMBER_TIME, *val)?;
   96     96   
        }
   97     97   
        if let Some(ref val) = self.log_group_identifier {
   98     98   
            ser.write_string(&GETLOGGROUPFIELDSINPUT_MEMBER_LOG_GROUP_IDENTIFIER, val)?;
   99     99   
        }
  100    100   
        Ok(())
  101    101   
    }
  102    102   
}
  103    103   
impl GetLogGroupFieldsInput {
  104    104   
    /// Deserializes this structure from a [`ShapeDeserializer`].
  105         -
    pub fn deserialize<D: ::aws_smithy_schema::serde::ShapeDeserializer>(
  106         -
        deserializer: &mut D,
         105  +
    pub fn deserialize(
         106  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
  107    107   
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
  108    108   
        #[allow(unused_variables, unused_mut)]
  109    109   
        let mut builder = Self::builder();
  110    110   
        #[allow(
  111    111   
            unused_variables,
  112    112   
            unreachable_code,
  113    113   
            clippy::single_match,
  114    114   
            clippy::match_single_binding,
  115    115   
            clippy::diverging_sub_expression
  116    116   
        )]
  117         -
        deserializer.read_struct(&GETLOGGROUPFIELDSINPUT_SCHEMA, (), |_, member, deser| {
         117  +
        deserializer.read_struct(&GETLOGGROUPFIELDSINPUT_SCHEMA, &mut |member, deser| {
  118    118   
            match member.member_index() {
  119    119   
                Some(0) => {
  120    120   
                    builder.log_group_name = Some(deser.read_string(member)?);
  121    121   
                }
  122    122   
                Some(1) => {
  123    123   
                    builder.time = Some(deser.read_long(member)?);
  124    124   
                }
  125    125   
                Some(2) => {
  126    126   
                    builder.log_group_identifier = Some(deser.read_string(member)?);
  127    127   
                }
  128    128   
                _ => {}
  129    129   
            }
  130    130   
            Ok(())
  131    131   
        })?;
  132    132   
        builder
  133    133   
            .build()
  134    134   
            .map_err(|e| aws_smithy_schema::serde::SerdeError::Custom { message: e.to_string() })
  135    135   
    }
  136    136   
}
         137  +
impl GetLogGroupFieldsInput {
         138  +
    /// Deserializes this structure from a body deserializer and HTTP response.
         139  +
    pub fn deserialize_with_response(
         140  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
         141  +
        _headers: &::aws_smithy_runtime_api::http::Headers,
         142  +
        _status: u16,
         143  +
        _body: &[u8],
         144  +
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
         145  +
        Self::deserialize(deserializer)
         146  +
    }
         147  +
}
  137    148   
impl GetLogGroupFieldsInput {
  138    149   
    /// Creates a new builder-style object to manufacture [`GetLogGroupFieldsInput`](crate::operation::get_log_group_fields::GetLogGroupFieldsInput).
  139    150   
    pub fn builder() -> crate::operation::get_log_group_fields::builders::GetLogGroupFieldsInputBuilder {
  140    151   
        crate::operation::get_log_group_fields::builders::GetLogGroupFieldsInputBuilder::default()
  141    152   
    }
  142    153   
}
  143    154   
  144    155   
/// A builder for [`GetLogGroupFieldsInput`](crate::operation::get_log_group_fields::GetLogGroupFieldsInput).
  145    156   
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
  146    157   
#[non_exhaustive]

tmp-codegen-diff/aws-sdk/sdk/cloudwatchlogs/src/operation/get_log_group_fields/_get_log_group_fields_output.rs

@@ -1,1 +118,169 @@
   20     20   
    "com.amazonaws.cloudwatchlogs.synthetic",
   21     21   
    "GetLogGroupFieldsOutput",
   22     22   
);
   23     23   
static GETLOGGROUPFIELDSOUTPUT_MEMBER_LOG_GROUP_FIELDS: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   24     24   
    ::aws_smithy_schema::ShapeId::from_static(
   25     25   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogGroupFieldsOutput$logGroupFields",
   26     26   
        "com.amazonaws.cloudwatchlogs.synthetic",
   27     27   
        "GetLogGroupFieldsOutput",
   28     28   
    ),
   29     29   
    ::aws_smithy_schema::ShapeType::List,
   30         -
    "log_group_fields",
          30  +
    "logGroupFields",
   31     31   
    0,
   32     32   
);
          33  +
static GETLOGGROUPFIELDSOUTPUT_MEMBER__REQUEST_ID: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
          34  +
    ::aws_smithy_schema::ShapeId::from_static("synthetic#request_id", "synthetic", "request_id"),
          35  +
    ::aws_smithy_schema::ShapeType::String,
          36  +
    "request_id",
          37  +
    1,
          38  +
)
          39  +
.with_http_header("x-amzn-requestid");
   33     40   
static GETLOGGROUPFIELDSOUTPUT_SCHEMA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_struct(
   34     41   
    GETLOGGROUPFIELDSOUTPUT_SCHEMA_ID,
   35     42   
    ::aws_smithy_schema::ShapeType::Structure,
   36         -
    &[&GETLOGGROUPFIELDSOUTPUT_MEMBER_LOG_GROUP_FIELDS],
          43  +
    &[
          44  +
        &GETLOGGROUPFIELDSOUTPUT_MEMBER_LOG_GROUP_FIELDS,
          45  +
        &GETLOGGROUPFIELDSOUTPUT_MEMBER__REQUEST_ID,
          46  +
    ],
   37     47   
);
   38     48   
impl GetLogGroupFieldsOutput {
   39     49   
    /// The schema for this shape.
   40     50   
    pub const SCHEMA: &'static ::aws_smithy_schema::Schema = &GETLOGGROUPFIELDSOUTPUT_SCHEMA;
   41     51   
}
   42     52   
impl ::aws_smithy_schema::serde::SerializableStruct for GetLogGroupFieldsOutput {
   43     53   
    #[allow(unused_variables, clippy::diverging_sub_expression)]
   44     54   
    fn serialize_members(
   45     55   
        &self,
   46     56   
        ser: &mut dyn ::aws_smithy_schema::serde::ShapeSerializer,
   47     57   
    ) -> ::std::result::Result<(), ::aws_smithy_schema::serde::SerdeError> {
   48     58   
        if let Some(ref val) = self.log_group_fields {
   49     59   
            ser.write_list(
   50     60   
                &GETLOGGROUPFIELDSOUTPUT_MEMBER_LOG_GROUP_FIELDS,
   51     61   
                &|ser: &mut dyn ::aws_smithy_schema::serde::ShapeSerializer| {
   52     62   
                    for item in val {
   53     63   
                        ser.write_struct(crate::types::LogGroupField::SCHEMA, item)?;
   54     64   
                    }
   55     65   
                    Ok(())
   56     66   
                },
   57     67   
            )?;
   58     68   
        }
   59     69   
        Ok(())
   60     70   
    }
   61     71   
}
   62     72   
impl GetLogGroupFieldsOutput {
   63     73   
    /// Deserializes this structure from a [`ShapeDeserializer`].
   64         -
    pub fn deserialize<D: ::aws_smithy_schema::serde::ShapeDeserializer>(
   65         -
        deserializer: &mut D,
          74  +
    pub fn deserialize(
          75  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
          76  +
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
          77  +
        #[allow(unused_variables, unused_mut)]
          78  +
        let mut builder = Self::builder();
          79  +
        #[allow(
          80  +
            unused_variables,
          81  +
            unreachable_code,
          82  +
            clippy::single_match,
          83  +
            clippy::match_single_binding,
          84  +
            clippy::diverging_sub_expression
          85  +
        )]
          86  +
        deserializer.read_struct(&GETLOGGROUPFIELDSOUTPUT_SCHEMA, &mut |member, deser| {
          87  +
            match member.member_index() {
          88  +
                Some(0) => {
          89  +
                    builder.log_group_fields = Some({
          90  +
                        let mut container = Vec::new();
          91  +
                        deser.read_list(member, &mut |deser| {
          92  +
                            container.push(crate::types::LogGroupField::deserialize(deser)?);
          93  +
                            Ok(())
          94  +
                        })?;
          95  +
                        container
          96  +
                    });
          97  +
                }
          98  +
                Some(1) => {
          99  +
                    builder._request_id = Some(deser.read_string(member)?);
         100  +
                }
         101  +
                _ => {}
         102  +
            }
         103  +
            Ok(())
         104  +
        })?;
         105  +
        Ok(builder.build())
         106  +
    }
         107  +
}
         108  +
impl GetLogGroupFieldsOutput {
         109  +
    /// Deserializes this structure from a body deserializer and HTTP response headers.
         110  +
    /// Header-bound members are read directly from headers, avoiding runtime
         111  +
    /// member iteration overhead. Body members are read via the deserializer.
         112  +
    pub fn deserialize_with_response(
         113  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
         114  +
        headers: &::aws_smithy_runtime_api::http::Headers,
         115  +
        _status: u16,
         116  +
        _body: &[u8],
   66    117   
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
   67    118   
        #[allow(unused_variables, unused_mut)]
   68    119   
        let mut builder = Self::builder();
         120  +
        if let Some(val) = headers.get("x-amzn-requestid") {
         121  +
            builder._request_id = Some(val.to_string());
         122  +
        }
   69    123   
        #[allow(
   70    124   
            unused_variables,
   71    125   
            unreachable_code,
   72    126   
            clippy::single_match,
   73    127   
            clippy::match_single_binding,
   74    128   
            clippy::diverging_sub_expression
   75    129   
        )]
   76         -
        deserializer.read_struct(&GETLOGGROUPFIELDSOUTPUT_SCHEMA, (), |_, member, deser| {
         130  +
        deserializer.read_struct(&GETLOGGROUPFIELDSOUTPUT_SCHEMA, &mut |member, deser| {
   77    131   
            match member.member_index() {
   78    132   
                Some(0) => {
   79    133   
                    builder.log_group_fields = Some({
   80         -
                        let container = if let Some(cap) = deser.container_size() {
   81         -
                            Vec::with_capacity(cap)
   82         -
                        } else {
   83         -
                            Vec::new()
   84         -
                        };
   85         -
                        deser.read_list(member, container, |mut list, deser| {
   86         -
                            list.push(crate::types::LogGroupField::deserialize(deser)?);
   87         -
                            Ok(list)
   88         -
                        })?
         134  +
                        let mut container = Vec::new();
         135  +
                        deser.read_list(member, &mut |deser| {
         136  +
                            container.push(crate::types::LogGroupField::deserialize(deser)?);
         137  +
                            Ok(())
         138  +
                        })?;
         139  +
                        container
   89    140   
                    });
   90    141   
                }
   91    142   
                _ => {}
   92    143   
            }
   93    144   
            Ok(())
   94    145   
        })?;
   95    146   
        Ok(builder.build())
   96    147   
    }
   97    148   
}
   98    149   
impl ::aws_types::request_id::RequestId for GetLogGroupFieldsOutput {

tmp-codegen-diff/aws-sdk/sdk/cloudwatchlogs/src/operation/get_log_object.rs

@@ -1,1 +40,44 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2      2   
/// Orchestration and serialization glue logic for `GetLogObject`.
    3      3   
#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
    4      4   
#[non_exhaustive]
    5      5   
pub struct GetLogObject;
    6      6   
impl GetLogObject {
    7      7   
    /// Creates a new `GetLogObject`
    8      8   
    pub fn new() -> Self {
    9      9   
        Self
   10     10   
    }
          11  +
    /// The schema for this operation's input shape.
          12  +
    pub const INPUT_SCHEMA: &'static ::aws_smithy_schema::Schema = crate::operation::get_log_object::GetLogObjectInput::SCHEMA;
          13  +
    /// The schema for this operation's output shape.
          14  +
    pub const OUTPUT_SCHEMA: &'static ::aws_smithy_schema::Schema = crate::operation::get_log_object::GetLogObjectOutput::SCHEMA;
   11     15   
    pub(crate) async fn orchestrate(
   12     16   
        runtime_plugins: &::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
   13     17   
        input: crate::operation::get_log_object::GetLogObjectInput,
   14     18   
    ) -> ::std::result::Result<
   15     19   
        crate::operation::get_log_object::GetLogObjectOutput,
   16     20   
        ::aws_smithy_runtime_api::client::result::SdkError<
   17     21   
            crate::operation::get_log_object::GetLogObjectError,
   18     22   
            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
   19     23   
        >,
   20     24   
    > {
@@ -134,138 +256,396 @@
  154    158   
  155    159   
        // If this is an error, defer to the non-streaming parser
  156    160   
        if (!response.status().is_success() && response.status().as_u16() != 200) || force_error {
  157    161   
            return ::std::option::Option::None;
  158    162   
        }
  159    163   
        ::std::option::Option::Some(crate::protocol_serde::type_erase_result(
  160    164   
            crate::protocol_serde::shape_get_log_object::de_get_log_object_http_response(response),
  161    165   
        ))
  162    166   
    }
  163    167   
  164         -
    fn deserialize_nonstreaming(
         168  +
    fn deserialize_nonstreaming_with_config(
  165    169   
        &self,
  166    170   
        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
         171  +
        _cfg: &::aws_smithy_types::config_bag::ConfigBag,
  167    172   
    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
  168    173   
        // For streaming operations, we only hit this case if its an error
  169    174   
        let body = response.body().bytes().expect("body loaded");
  170         -
        crate::protocol_serde::type_erase_result(crate::protocol_serde::shape_get_log_object::de_get_log_object_http_error(
  171         -
            response.status().as_u16(),
         175  +
        let status = response.status().as_u16();
         176  +
        let headers = response.headers();
         177  +
        #[allow(unused_mut)]
         178  +
        let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(status, headers, body).map_err(|e| {
         179  +
            ::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(::aws_smithy_runtime_api::box_error::BoxError::from(e))
         180  +
        })?;
         181  +
        generic_builder = ::aws_types::request_id::apply_request_id(generic_builder, headers);
         182  +
        let generic = generic_builder.build();
         183  +
        let error_code = match generic.code() {
         184  +
            ::std::option::Option::Some(code) => code,
         185  +
            ::std::option::Option::None => {
         186  +
                return ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(
         187  +
                    ::aws_smithy_runtime_api::box_error::BoxError::from(crate::operation::get_log_object::GetLogObjectError::unhandled(generic)),
         188  +
                ))
         189  +
            }
         190  +
        };
         191  +
        let _error_message = generic.message().map(|msg| msg.to_owned());
         192  +
        let protocol = _cfg
         193  +
            .load::<::aws_smithy_schema::protocol::SharedClientProtocol>()
         194  +
            .expect("a SharedClientProtocol is required");
         195  +
        let err = match error_code {
         196  +
            "AccessDeniedException" => crate::operation::get_log_object::GetLogObjectError::AccessDeniedException({
         197  +
                let mut tmp = match protocol
         198  +
                    .deserialize_response(response, crate::types::error::AccessDeniedException::SCHEMA, _cfg)
         199  +
                    .and_then(|mut deser| {
         200  +
                        crate::types::error::AccessDeniedException::deserialize_with_response(
         201  +
                            &mut *deser,
         202  +
                            response.headers(),
         203  +
                            response.status().into(),
         204  +
                            body,
         205  +
                        )
         206  +
                    }) {
         207  +
                    ::std::result::Result::Ok(val) => val,
         208  +
                    ::std::result::Result::Err(e) => {
         209  +
                        return ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(
         210  +
                            ::aws_smithy_runtime_api::box_error::BoxError::from(e),
         211  +
                        ))
         212  +
                    }
         213  +
                };
         214  +
                tmp.meta = generic;
         215  +
                if tmp.message.is_none() {
         216  +
                    tmp.message = _error_message;
         217  +
                }
         218  +
                tmp
         219  +
            }),
         220  +
            "InvalidOperationException" => crate::operation::get_log_object::GetLogObjectError::InvalidOperationException({
         221  +
                let mut tmp = match protocol
         222  +
                    .deserialize_response(response, crate::types::error::InvalidOperationException::SCHEMA, _cfg)
         223  +
                    .and_then(|mut deser| {
         224  +
                        crate::types::error::InvalidOperationException::deserialize_with_response(
         225  +
                            &mut *deser,
         226  +
                            response.headers(),
         227  +
                            response.status().into(),
         228  +
                            body,
         229  +
                        )
         230  +
                    }) {
         231  +
                    ::std::result::Result::Ok(val) => val,
         232  +
                    ::std::result::Result::Err(e) => {
         233  +
                        return ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(
         234  +
                            ::aws_smithy_runtime_api::box_error::BoxError::from(e),
         235  +
                        ))
         236  +
                    }
         237  +
                };
         238  +
                tmp.meta = generic;
         239  +
                if tmp.message.is_none() {
         240  +
                    tmp.message = _error_message;
         241  +
                }
         242  +
                tmp
         243  +
            }),
         244  +
            "InvalidParameterException" => crate::operation::get_log_object::GetLogObjectError::InvalidParameterException({
         245  +
                let mut tmp = match protocol
         246  +
                    .deserialize_response(response, crate::types::error::InvalidParameterException::SCHEMA, _cfg)
         247  +
                    .and_then(|mut deser| {
         248  +
                        crate::types::error::InvalidParameterException::deserialize_with_response(
         249  +
                            &mut *deser,
         250  +
                            response.headers(),
         251  +
                            response.status().into(),
         252  +
                            body,
         253  +
                        )
         254  +
                    }) {
         255  +
                    ::std::result::Result::Ok(val) => val,
         256  +
                    ::std::result::Result::Err(e) => {
         257  +
                        return ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(
         258  +
                            ::aws_smithy_runtime_api::box_error::BoxError::from(e),
         259  +
                        ))
         260  +
                    }
         261  +
                };
         262  +
                tmp.meta = generic;
         263  +
                if tmp.message.is_none() {
         264  +
                    tmp.message = _error_message;
         265  +
                }
         266  +
                tmp
         267  +
            }),
         268  +
            "LimitExceededException" => crate::operation::get_log_object::GetLogObjectError::LimitExceededException({
         269  +
                let mut tmp = match protocol
         270  +
                    .deserialize_response(response, crate::types::error::LimitExceededException::SCHEMA, _cfg)
         271  +
                    .and_then(|mut deser| {
         272  +
                        crate::types::error::LimitExceededException::deserialize_with_response(
         273  +
                            &mut *deser,
  172    274   
                            response.headers(),
         275  +
                            response.status().into(),
  173    276   
                            body,
         277  +
                        )
         278  +
                    }) {
         279  +
                    ::std::result::Result::Ok(val) => val,
         280  +
                    ::std::result::Result::Err(e) => {
         281  +
                        return ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(
         282  +
                            ::aws_smithy_runtime_api::box_error::BoxError::from(e),
         283  +
                        ))
         284  +
                    }
         285  +
                };
         286  +
                tmp.meta = generic;
         287  +
                if tmp.message.is_none() {
         288  +
                    tmp.message = _error_message;
         289  +
                }
         290  +
                tmp
         291  +
            }),
         292  +
            "ResourceNotFoundException" => crate::operation::get_log_object::GetLogObjectError::ResourceNotFoundException({
         293  +
                let mut tmp = match protocol
         294  +
                    .deserialize_response(response, crate::types::error::ResourceNotFoundException::SCHEMA, _cfg)
         295  +
                    .and_then(|mut deser| {
         296  +
                        crate::types::error::ResourceNotFoundException::deserialize_with_response(
         297  +
                            &mut *deser,
         298  +
                            response.headers(),
         299  +
                            response.status().into(),
         300  +
                            body,
         301  +
                        )
         302  +
                    }) {
         303  +
                    ::std::result::Result::Ok(val) => val,
         304  +
                    ::std::result::Result::Err(e) => {
         305  +
                        return ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(
         306  +
                            ::aws_smithy_runtime_api::box_error::BoxError::from(e),
         307  +
                        ))
         308  +
                    }
         309  +
                };
         310  +
                tmp.meta = generic;
         311  +
                if tmp.message.is_none() {
         312  +
                    tmp.message = _error_message;
         313  +
                }
         314  +
                tmp
         315  +
            }),
         316  +
            "InternalStreamingException" => crate::operation::get_log_object::GetLogObjectError::InternalStreamingException({
         317  +
                let mut tmp = match protocol
         318  +
                    .deserialize_response(response, crate::types::error::InternalStreamingException::SCHEMA, _cfg)
         319  +
                    .and_then(|mut deser| {
         320  +
                        crate::types::error::InternalStreamingException::deserialize_with_response(
         321  +
                            &mut *deser,
         322  +
                            response.headers(),
         323  +
                            response.status().into(),
         324  +
                            body,
         325  +
                        )
         326  +
                    }) {
         327  +
                    ::std::result::Result::Ok(val) => val,
         328  +
                    ::std::result::Result::Err(e) => {
         329  +
                        return ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(
         330  +
                            ::aws_smithy_runtime_api::box_error::BoxError::from(e),
         331  +
                        ))
         332  +
                    }
         333  +
                };
         334  +
                tmp.meta = generic;
         335  +
                if tmp.message.is_none() {
         336  +
                    tmp.message = _error_message;
         337  +
                }
         338  +
                tmp
         339  +
            }),
         340  +
            _ => crate::operation::get_log_object::GetLogObjectError::generic(generic),
         341  +
        };
         342  +
        ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::operation(
         343  +
            ::aws_smithy_runtime_api::client::interceptors::context::Error::erase(err),
  174    344   
        ))
  175    345   
    }
  176    346   
}
  177    347   
#[derive(Debug)]
  178    348   
struct GetLogObjectRequestSerializer;
  179    349   
impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for GetLogObjectRequestSerializer {
  180    350   
    #[allow(unused_mut, clippy::let_and_return, clippy::needless_borrow, clippy::useless_conversion)]
  181    351   
    fn serialize_input(
  182    352   
        &self,
  183    353   
        input: ::aws_smithy_runtime_api::client::interceptors::context::Input,
  184    354   
        _cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
  185    355   
    ) -> ::std::result::Result<::aws_smithy_runtime_api::client::orchestrator::HttpRequest, ::aws_smithy_runtime_api::box_error::BoxError> {
  186    356   
        let input = input
  187    357   
            .downcast::<crate::operation::get_log_object::GetLogObjectInput>()
  188    358   
            .expect("correct type");
  189         -
        let _header_serialization_settings = _cfg
  190         -
            .load::<crate::serialization_settings::HeaderSerializationSettings>()
  191         -
            .cloned()
  192         -
            .unwrap_or_default();
  193         -
        let mut request_builder = {
  194         -
            #[allow(clippy::uninlined_format_args)]
  195         -
            fn uri_base(
  196         -
                _input: &crate::operation::get_log_object::GetLogObjectInput,
  197         -
                output: &mut ::std::string::String,
  198         -
            ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
  199         -
                use ::std::fmt::Write as _;
  200         -
                ::std::write!(output, "/").expect("formatting should succeed");
  201         -
                ::std::result::Result::Ok(())
  202         -
            }
  203         -
            #[allow(clippy::unnecessary_wraps)]
  204         -
            fn update_http_builder(
  205         -
                input: &crate::operation::get_log_object::GetLogObjectInput,
  206         -
                builder: ::http_1x::request::Builder,
  207         -
            ) -> ::std::result::Result<::http_1x::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
  208         -
                let mut uri = ::std::string::String::new();
  209         -
                uri_base(input, &mut uri)?;
  210         -
                ::std::result::Result::Ok(builder.method("POST").uri(uri))
  211         -
            }
  212         -
            let mut builder = update_http_builder(&input, ::http_1x::request::Builder::new())?;
  213         -
            builder = _header_serialization_settings.set_default_header(builder, ::http_1x::header::CONTENT_TYPE, "application/x-amz-json-1.1");
  214         -
            builder = _header_serialization_settings.set_default_header(
  215         -
                builder,
  216         -
                ::http_1x::header::HeaderName::from_static("x-amz-target"),
  217         -
                "Logs_20140328.GetLogObject",
  218         -
            );
  219         -
            builder
  220         -
        };
  221         -
        let body = ::aws_smithy_types::body::SdkBody::from(crate::protocol_serde::shape_get_log_object::ser_get_log_object_input(&input)?);
  222         -
        if let Some(content_length) = body.content_length() {
  223         -
            let content_length = content_length.to_string();
  224         -
            request_builder = _header_serialization_settings.set_default_header(request_builder, ::http_1x::header::CONTENT_LENGTH, &content_length);
  225         -
        }
  226         -
        ::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
         359  +
        let protocol = _cfg
         360  +
            .load::<::aws_smithy_schema::protocol::SharedClientProtocol>()
         361  +
            .expect("a SharedClientProtocol is required");
         362  +
        let mut request = protocol
         363  +
            .serialize_request(&input, GetLogObject::INPUT_SCHEMA, "", _cfg)
         364  +
            .map_err(::aws_smithy_runtime_api::box_error::BoxError::from)?;
         365  +
         366  +
        return ::std::result::Result::Ok(request);
  227    367   
    }
  228    368   
}
  229    369   
#[derive(Debug)]
  230    370   
struct GetLogObjectEndpointParamsInterceptor;
  231    371   
  232    372   
impl ::aws_smithy_runtime_api::client::interceptors::Intercept for GetLogObjectEndpointParamsInterceptor {
  233    373   
    fn name(&self) -> &'static str {
  234    374   
        "GetLogObjectEndpointParamsInterceptor"
  235    375   
    }
  236    376   

tmp-codegen-diff/aws-sdk/sdk/cloudwatchlogs/src/operation/get_log_object/_get_log_object_input.rs

@@ -14,14 +131,143 @@
   34     34   
    "unmask",
   35     35   
    0,
   36     36   
);
   37     37   
static GETLOGOBJECTINPUT_MEMBER_LOG_OBJECT_POINTER: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   38     38   
    ::aws_smithy_schema::ShapeId::from_static(
   39     39   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogObjectInput$logObjectPointer",
   40     40   
        "com.amazonaws.cloudwatchlogs.synthetic",
   41     41   
        "GetLogObjectInput",
   42     42   
    ),
   43     43   
    ::aws_smithy_schema::ShapeType::String,
   44         -
    "log_object_pointer",
          44  +
    "logObjectPointer",
   45     45   
    1,
   46     46   
);
   47     47   
static GETLOGOBJECTINPUT_SCHEMA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_struct(
   48     48   
    GETLOGOBJECTINPUT_SCHEMA_ID,
   49     49   
    ::aws_smithy_schema::ShapeType::Structure,
   50     50   
    &[&GETLOGOBJECTINPUT_MEMBER_UNMASK, &GETLOGOBJECTINPUT_MEMBER_LOG_OBJECT_POINTER],
   51     51   
);
   52     52   
impl GetLogObjectInput {
   53     53   
    /// The schema for this shape.
   54     54   
    pub const SCHEMA: &'static ::aws_smithy_schema::Schema = &GETLOGOBJECTINPUT_SCHEMA;
   55     55   
}
   56     56   
impl ::aws_smithy_schema::serde::SerializableStruct for GetLogObjectInput {
   57     57   
    #[allow(unused_variables, clippy::diverging_sub_expression)]
   58     58   
    fn serialize_members(
   59     59   
        &self,
   60     60   
        ser: &mut dyn ::aws_smithy_schema::serde::ShapeSerializer,
   61     61   
    ) -> ::std::result::Result<(), ::aws_smithy_schema::serde::SerdeError> {
   62     62   
        if let Some(ref val) = self.unmask {
   63     63   
            ser.write_boolean(&GETLOGOBJECTINPUT_MEMBER_UNMASK, *val)?;
   64     64   
        }
   65     65   
        if let Some(ref val) = self.log_object_pointer {
   66     66   
            ser.write_string(&GETLOGOBJECTINPUT_MEMBER_LOG_OBJECT_POINTER, val)?;
   67     67   
        }
   68     68   
        Ok(())
   69     69   
    }
   70     70   
}
   71     71   
impl GetLogObjectInput {
   72     72   
    /// Deserializes this structure from a [`ShapeDeserializer`].
   73         -
    pub fn deserialize<D: ::aws_smithy_schema::serde::ShapeDeserializer>(
   74         -
        deserializer: &mut D,
          73  +
    pub fn deserialize(
          74  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
   75     75   
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
   76     76   
        #[allow(unused_variables, unused_mut)]
   77     77   
        let mut builder = Self::builder();
   78     78   
        #[allow(
   79     79   
            unused_variables,
   80     80   
            unreachable_code,
   81     81   
            clippy::single_match,
   82     82   
            clippy::match_single_binding,
   83     83   
            clippy::diverging_sub_expression
   84     84   
        )]
   85         -
        deserializer.read_struct(&GETLOGOBJECTINPUT_SCHEMA, (), |_, member, deser| {
          85  +
        deserializer.read_struct(&GETLOGOBJECTINPUT_SCHEMA, &mut |member, deser| {
   86     86   
            match member.member_index() {
   87     87   
                Some(0) => {
   88     88   
                    builder.unmask = Some(deser.read_boolean(member)?);
   89     89   
                }
   90     90   
                Some(1) => {
   91     91   
                    builder.log_object_pointer = Some(deser.read_string(member)?);
   92     92   
                }
   93     93   
                _ => {}
   94     94   
            }
   95     95   
            Ok(())
   96     96   
        })?;
          97  +
        builder.log_object_pointer = builder.log_object_pointer.or(Some(String::new()));
   97     98   
        builder
   98     99   
            .build()
   99    100   
            .map_err(|e| aws_smithy_schema::serde::SerdeError::Custom { message: e.to_string() })
  100    101   
    }
  101    102   
}
         103  +
impl GetLogObjectInput {
         104  +
    /// Deserializes this structure from a body deserializer and HTTP response.
         105  +
    pub fn deserialize_with_response(
         106  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
         107  +
        _headers: &::aws_smithy_runtime_api::http::Headers,
         108  +
        _status: u16,
         109  +
        _body: &[u8],
         110  +
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
         111  +
        Self::deserialize(deserializer)
         112  +
    }
         113  +
}
  102    114   
impl GetLogObjectInput {
  103    115   
    /// Creates a new builder-style object to manufacture [`GetLogObjectInput`](crate::operation::get_log_object::GetLogObjectInput).
  104    116   
    pub fn builder() -> crate::operation::get_log_object::builders::GetLogObjectInputBuilder {
  105    117   
        crate::operation::get_log_object::builders::GetLogObjectInputBuilder::default()
  106    118   
    }
  107    119   
}
  108    120   
  109    121   
/// A builder for [`GetLogObjectInput`](crate::operation::get_log_object::GetLogObjectInput).
  110    122   
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
  111    123   
#[non_exhaustive]

tmp-codegen-diff/aws-sdk/sdk/cloudwatchlogs/src/operation/get_log_object/_get_log_object_output.rs

@@ -2,2 +106,151 @@
   22     22   
    "com.amazonaws.cloudwatchlogs.synthetic",
   23     23   
    "GetLogObjectOutput",
   24     24   
);
   25     25   
static GETLOGOBJECTOUTPUT_MEMBER_FIELD_STREAM: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   26     26   
    ::aws_smithy_schema::ShapeId::from_static(
   27     27   
        "com.amazonaws.cloudwatchlogs.synthetic#GetLogObjectOutput$fieldStream",
   28     28   
        "com.amazonaws.cloudwatchlogs.synthetic",
   29     29   
        "GetLogObjectOutput",
   30     30   
    ),
   31     31   
    ::aws_smithy_schema::ShapeType::Union,
   32         -
    "field_stream",
          32  +
    "fieldStream",
   33     33   
    0,
   34     34   
);
          35  +
static GETLOGOBJECTOUTPUT_MEMBER__REQUEST_ID: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
          36  +
    ::aws_smithy_schema::ShapeId::from_static("synthetic#request_id", "synthetic", "request_id"),
          37  +
    ::aws_smithy_schema::ShapeType::String,
          38  +
    "request_id",
          39  +
    1,
          40  +
)
          41  +
.with_http_header("x-amzn-requestid");
   35     42   
static GETLOGOBJECTOUTPUT_SCHEMA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_struct(
   36     43   
    GETLOGOBJECTOUTPUT_SCHEMA_ID,
   37     44   
    ::aws_smithy_schema::ShapeType::Structure,
   38         -
    &[&GETLOGOBJECTOUTPUT_MEMBER_FIELD_STREAM],
          45  +
    &[&GETLOGOBJECTOUTPUT_MEMBER_FIELD_STREAM, &GETLOGOBJECTOUTPUT_MEMBER__REQUEST_ID],
   39     46   
);
   40     47   
impl GetLogObjectOutput {
   41     48   
    /// The schema for this shape.
   42     49   
    pub const SCHEMA: &'static ::aws_smithy_schema::Schema = &GETLOGOBJECTOUTPUT_SCHEMA;
   43     50   
}
   44     51   
impl ::aws_smithy_schema::serde::SerializableStruct for GetLogObjectOutput {
   45     52   
    #[allow(unused_variables, clippy::diverging_sub_expression)]
   46     53   
    fn serialize_members(
   47     54   
        &self,
   48     55   
        ser: &mut dyn ::aws_smithy_schema::serde::ShapeSerializer,
   49     56   
    ) -> ::std::result::Result<(), ::aws_smithy_schema::serde::SerdeError> {
   50         -
        {
   51         -
            let val = &self.field_stream;
   52         -
            ser.write_null(&GETLOGOBJECTOUTPUT_MEMBER_FIELD_STREAM)?;
   53         -
        }
   54     57   
        Ok(())
   55     58   
    }
   56     59   
}
   57     60   
impl GetLogObjectOutput {
   58     61   
    /// Deserializes this structure from a [`ShapeDeserializer`].
   59         -
    pub fn deserialize<D: ::aws_smithy_schema::serde::ShapeDeserializer>(
   60         -
        deserializer: &mut D,
          62  +
    pub fn deserialize(
          63  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
          64  +
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
          65  +
        #[allow(unused_variables, unused_mut)]
          66  +
        let mut builder = Self::builder();
          67  +
        #[allow(
          68  +
            unused_variables,
          69  +
            unreachable_code,
          70  +
            clippy::single_match,
          71  +
            clippy::match_single_binding,
          72  +
            clippy::diverging_sub_expression
          73  +
        )]
          74  +
        deserializer.read_struct(&GETLOGOBJECTOUTPUT_SCHEMA, &mut |member, deser| {
          75  +
            match member.member_index() {
          76  +
                Some(0) => {
          77  +
                    builder.field_stream = Some({
          78  +
                        let _ = member;
          79  +
                        todo!("deserialize streaming union")
          80  +
                    });
          81  +
                }
          82  +
                Some(1) => {
          83  +
                    builder._request_id = Some(deser.read_string(member)?);
          84  +
                }
          85  +
                _ => {}
          86  +
            }
          87  +
            Ok(())
          88  +
        })?;
          89  +
        builder
          90  +
            .build()
          91  +
            .map_err(|e| aws_smithy_schema::serde::SerdeError::Custom { message: e.to_string() })
          92  +
    }
          93  +
}
          94  +
impl GetLogObjectOutput {
          95  +
    /// Deserializes this structure from a body deserializer and HTTP response headers.
          96  +
    /// Header-bound members are read directly from headers, avoiding runtime
          97  +
    /// member iteration overhead. Body members are read via the deserializer.
          98  +
    pub fn deserialize_with_response(
          99  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
         100  +
        headers: &::aws_smithy_runtime_api::http::Headers,
         101  +
        _status: u16,
         102  +
        _body: &[u8],
   61    103   
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
   62    104   
        #[allow(unused_variables, unused_mut)]
   63    105   
        let mut builder = Self::builder();
         106  +
        if let Some(val) = headers.get("x-amzn-requestid") {
         107  +
            builder._request_id = Some(val.to_string());
         108  +
        }
   64    109   
        #[allow(
   65    110   
            unused_variables,
   66    111   
            unreachable_code,
   67    112   
            clippy::single_match,
   68    113   
            clippy::match_single_binding,
   69    114   
            clippy::diverging_sub_expression
   70    115   
        )]
   71         -
        deserializer.read_struct(&GETLOGOBJECTOUTPUT_SCHEMA, (), |_, member, deser| {
         116  +
        deserializer.read_struct(&GETLOGOBJECTOUTPUT_SCHEMA, &mut |member, deser| {
   72    117   
            match member.member_index() {
   73    118   
                Some(0) => {
   74    119   
                    builder.field_stream = Some({
   75    120   
                        let _ = member;
   76         -
                        todo!("deserialize aggregate")
         121  +
                        todo!("deserialize streaming union")
   77    122   
                    });
   78    123   
                }
   79    124   
                _ => {}
   80    125   
            }
   81    126   
            Ok(())
   82    127   
        })?;
   83    128   
        builder
   84    129   
            .build()
   85    130   
            .map_err(|e| aws_smithy_schema::serde::SerdeError::Custom { message: e.to_string() })
   86    131   
    }