in dax/internal/client/response.go [278:333]
func decodeUpdateItemOutput(ctx context.Context, reader *cbor.Reader, input *dynamodb.UpdateItemInput, keySchemaCache *lru.Lru, attrListIdToNames *lru.Lru, output *dynamodb.UpdateItemOutput) (*dynamodb.UpdateItemOutput, error) {
if consumed, err := consumeNil(reader); err != nil {
return output, err
} else if consumed {
return output, nil
}
tableName := *input.TableName
if output == nil {
output = &dynamodb.UpdateItemOutput{}
}
var err error
err = consumeMap(reader, func(key int, reader *cbor.Reader) error {
switch key {
case responseParamConsumedCapacity:
if output.ConsumedCapacity, err = decodeConsumedCapacity(reader); err != nil {
return err
}
case responseParamItemCollectionMetrics:
keys, err := getKeySchema(ctx, keySchemaCache, tableName)
if err != nil {
return err
}
if output.ItemCollectionMetrics, err = decodeItemCollectionMetrics(reader, *keys[0].AttributeName); err != nil {
return err
}
case responseParamAttributes:
rv := input.ReturnValues
switch rv {
case types.ReturnValueAllNew, types.ReturnValueAllOld:
attrs, err := decodeNonKeyAttributes(ctx, reader, attrListIdToNames, nil)
if err != nil {
return err
}
for k, v := range input.Key {
attrs[k] = v
}
output.Attributes = attrs
case types.ReturnValueUpdatedNew, types.ReturnValueUpdatedOld:
if output.Attributes, err = decodeAttributeProjection(ctx, reader, attrListIdToNames); err != nil {
return err
}
default:
return &smithy.SerializationError{Err: fmt.Errorf("unexpected return value %s", rv)}
}
default:
return &smithy.SerializationError{Err: fmt.Errorf("unknown response param key %d", key)}
}
return nil
})
if err != nil {
return output, err
}
return output, nil
}