aws-sdk-costoptimizationhub 1.6.0 → 1.7.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +5 -0
- data/VERSION +1 -1
- data/lib/aws-sdk-costoptimizationhub/client.rb +437 -379
- data/lib/aws-sdk-costoptimizationhub/client_api.rb +152 -121
- data/lib/aws-sdk-costoptimizationhub/errors.rb +5 -5
- data/lib/aws-sdk-costoptimizationhub/types.rb +644 -530
- data/lib/aws-sdk-costoptimizationhub/waiters.rb +15 -0
- data/lib/aws-sdk-costoptimizationhub.rb +2 -1
- data/sig/client.rbs +50 -50
- data/sig/errors.rbs +1 -1
- data/sig/types.rbs +163 -127
- metadata +3 -2
@@ -26,6 +26,7 @@ module Aws::CostOptimizationHub
|
|
26
26
|
ComputeSavingsPlans = Shapes::StructureShape.new(name: 'ComputeSavingsPlans')
|
27
27
|
ComputeSavingsPlansConfiguration = Shapes::StructureShape.new(name: 'ComputeSavingsPlansConfiguration')
|
28
28
|
Datetime = Shapes::TimestampShape.new(name: 'Datetime')
|
29
|
+
DbInstanceConfiguration = Shapes::StructureShape.new(name: 'DbInstanceConfiguration')
|
29
30
|
Double = Shapes::FloatShape.new(name: 'Double')
|
30
31
|
EbsVolume = Shapes::StructureShape.new(name: 'EbsVolume')
|
31
32
|
EbsVolumeConfiguration = Shapes::StructureShape.new(name: 'EbsVolumeConfiguration')
|
@@ -70,6 +71,10 @@ module Aws::CostOptimizationHub
|
|
70
71
|
Order = Shapes::StringShape.new(name: 'Order')
|
71
72
|
OrderBy = Shapes::StructureShape.new(name: 'OrderBy')
|
72
73
|
PrimitiveBoolean = Shapes::BooleanShape.new(name: 'PrimitiveBoolean')
|
74
|
+
RdsDbInstance = Shapes::StructureShape.new(name: 'RdsDbInstance')
|
75
|
+
RdsDbInstanceConfiguration = Shapes::StructureShape.new(name: 'RdsDbInstanceConfiguration')
|
76
|
+
RdsDbInstanceStorage = Shapes::StructureShape.new(name: 'RdsDbInstanceStorage')
|
77
|
+
RdsDbInstanceStorageConfiguration = Shapes::StructureShape.new(name: 'RdsDbInstanceStorageConfiguration')
|
73
78
|
RdsReservedInstances = Shapes::StructureShape.new(name: 'RdsReservedInstances')
|
74
79
|
RdsReservedInstancesConfiguration = Shapes::StructureShape.new(name: 'RdsReservedInstancesConfiguration')
|
75
80
|
Recommendation = Shapes::StructureShape.new(name: 'Recommendation')
|
@@ -117,9 +122,9 @@ module Aws::CostOptimizationHub
|
|
117
122
|
AccessDeniedException.struct_class = Types::AccessDeniedException
|
118
123
|
|
119
124
|
AccountEnrollmentStatus.add_member(:account_id, Shapes::ShapeRef.new(shape: AccountId, location_name: "accountId"))
|
120
|
-
AccountEnrollmentStatus.add_member(:created_timestamp, Shapes::ShapeRef.new(shape: Timestamp, location_name: "createdTimestamp"))
|
121
|
-
AccountEnrollmentStatus.add_member(:last_updated_timestamp, Shapes::ShapeRef.new(shape: Timestamp, location_name: "lastUpdatedTimestamp"))
|
122
125
|
AccountEnrollmentStatus.add_member(:status, Shapes::ShapeRef.new(shape: EnrollmentStatus, location_name: "status"))
|
126
|
+
AccountEnrollmentStatus.add_member(:last_updated_timestamp, Shapes::ShapeRef.new(shape: Timestamp, location_name: "lastUpdatedTimestamp"))
|
127
|
+
AccountEnrollmentStatus.add_member(:created_timestamp, Shapes::ShapeRef.new(shape: Timestamp, location_name: "createdTimestamp"))
|
123
128
|
AccountEnrollmentStatus.struct_class = Types::AccountEnrollmentStatus
|
124
129
|
|
125
130
|
AccountEnrollmentStatuses.member = Shapes::ShapeRef.new(shape: AccountEnrollmentStatus)
|
@@ -132,10 +137,10 @@ module Aws::CostOptimizationHub
|
|
132
137
|
BlockStoragePerformanceConfiguration.add_member(:throughput, Shapes::ShapeRef.new(shape: Double, location_name: "throughput"))
|
133
138
|
BlockStoragePerformanceConfiguration.struct_class = Types::BlockStoragePerformanceConfiguration
|
134
139
|
|
135
|
-
ComputeConfiguration.add_member(:
|
140
|
+
ComputeConfiguration.add_member(:v_cpu, Shapes::ShapeRef.new(shape: Double, location_name: "vCpu"))
|
136
141
|
ComputeConfiguration.add_member(:memory_size_in_mb, Shapes::ShapeRef.new(shape: Integer, location_name: "memorySizeInMB"))
|
142
|
+
ComputeConfiguration.add_member(:architecture, Shapes::ShapeRef.new(shape: String, location_name: "architecture"))
|
137
143
|
ComputeConfiguration.add_member(:platform, Shapes::ShapeRef.new(shape: String, location_name: "platform"))
|
138
|
-
ComputeConfiguration.add_member(:v_cpu, Shapes::ShapeRef.new(shape: Double, location_name: "vCpu"))
|
139
144
|
ComputeConfiguration.struct_class = Types::ComputeConfiguration
|
140
145
|
|
141
146
|
ComputeSavingsPlans.add_member(:configuration, Shapes::ShapeRef.new(shape: ComputeSavingsPlansConfiguration, location_name: "configuration"))
|
@@ -143,18 +148,21 @@ module Aws::CostOptimizationHub
|
|
143
148
|
ComputeSavingsPlans.struct_class = Types::ComputeSavingsPlans
|
144
149
|
|
145
150
|
ComputeSavingsPlansConfiguration.add_member(:account_scope, Shapes::ShapeRef.new(shape: String, location_name: "accountScope"))
|
146
|
-
ComputeSavingsPlansConfiguration.add_member(:hourly_commitment, Shapes::ShapeRef.new(shape: String, location_name: "hourlyCommitment"))
|
147
|
-
ComputeSavingsPlansConfiguration.add_member(:payment_option, Shapes::ShapeRef.new(shape: String, location_name: "paymentOption"))
|
148
151
|
ComputeSavingsPlansConfiguration.add_member(:term, Shapes::ShapeRef.new(shape: String, location_name: "term"))
|
152
|
+
ComputeSavingsPlansConfiguration.add_member(:payment_option, Shapes::ShapeRef.new(shape: String, location_name: "paymentOption"))
|
153
|
+
ComputeSavingsPlansConfiguration.add_member(:hourly_commitment, Shapes::ShapeRef.new(shape: String, location_name: "hourlyCommitment"))
|
149
154
|
ComputeSavingsPlansConfiguration.struct_class = Types::ComputeSavingsPlansConfiguration
|
150
155
|
|
156
|
+
DbInstanceConfiguration.add_member(:db_instance_class, Shapes::ShapeRef.new(shape: String, location_name: "dbInstanceClass"))
|
157
|
+
DbInstanceConfiguration.struct_class = Types::DbInstanceConfiguration
|
158
|
+
|
151
159
|
EbsVolume.add_member(:configuration, Shapes::ShapeRef.new(shape: EbsVolumeConfiguration, location_name: "configuration"))
|
152
160
|
EbsVolume.add_member(:cost_calculation, Shapes::ShapeRef.new(shape: ResourceCostCalculation, location_name: "costCalculation"))
|
153
161
|
EbsVolume.struct_class = Types::EbsVolume
|
154
162
|
|
155
|
-
EbsVolumeConfiguration.add_member(:attachment_state, Shapes::ShapeRef.new(shape: String, location_name: "attachmentState"))
|
156
|
-
EbsVolumeConfiguration.add_member(:performance, Shapes::ShapeRef.new(shape: BlockStoragePerformanceConfiguration, location_name: "performance"))
|
157
163
|
EbsVolumeConfiguration.add_member(:storage, Shapes::ShapeRef.new(shape: StorageConfiguration, location_name: "storage"))
|
164
|
+
EbsVolumeConfiguration.add_member(:performance, Shapes::ShapeRef.new(shape: BlockStoragePerformanceConfiguration, location_name: "performance"))
|
165
|
+
EbsVolumeConfiguration.add_member(:attachment_state, Shapes::ShapeRef.new(shape: String, location_name: "attachmentState"))
|
158
166
|
EbsVolumeConfiguration.struct_class = Types::EbsVolumeConfiguration
|
159
167
|
|
160
168
|
Ec2AutoScalingGroup.add_member(:configuration, Shapes::ShapeRef.new(shape: Ec2AutoScalingGroupConfiguration, location_name: "configuration"))
|
@@ -176,11 +184,11 @@ module Aws::CostOptimizationHub
|
|
176
184
|
Ec2InstanceSavingsPlans.struct_class = Types::Ec2InstanceSavingsPlans
|
177
185
|
|
178
186
|
Ec2InstanceSavingsPlansConfiguration.add_member(:account_scope, Shapes::ShapeRef.new(shape: String, location_name: "accountScope"))
|
187
|
+
Ec2InstanceSavingsPlansConfiguration.add_member(:term, Shapes::ShapeRef.new(shape: String, location_name: "term"))
|
188
|
+
Ec2InstanceSavingsPlansConfiguration.add_member(:payment_option, Shapes::ShapeRef.new(shape: String, location_name: "paymentOption"))
|
179
189
|
Ec2InstanceSavingsPlansConfiguration.add_member(:hourly_commitment, Shapes::ShapeRef.new(shape: String, location_name: "hourlyCommitment"))
|
180
190
|
Ec2InstanceSavingsPlansConfiguration.add_member(:instance_family, Shapes::ShapeRef.new(shape: String, location_name: "instanceFamily"))
|
181
|
-
Ec2InstanceSavingsPlansConfiguration.add_member(:payment_option, Shapes::ShapeRef.new(shape: String, location_name: "paymentOption"))
|
182
191
|
Ec2InstanceSavingsPlansConfiguration.add_member(:savings_plans_region, Shapes::ShapeRef.new(shape: String, location_name: "savingsPlansRegion"))
|
183
|
-
Ec2InstanceSavingsPlansConfiguration.add_member(:term, Shapes::ShapeRef.new(shape: String, location_name: "term"))
|
184
192
|
Ec2InstanceSavingsPlansConfiguration.struct_class = Types::Ec2InstanceSavingsPlansConfiguration
|
185
193
|
|
186
194
|
Ec2ReservedInstances.add_member(:configuration, Shapes::ShapeRef.new(shape: Ec2ReservedInstancesConfiguration, location_name: "configuration"))
|
@@ -188,21 +196,21 @@ module Aws::CostOptimizationHub
|
|
188
196
|
Ec2ReservedInstances.struct_class = Types::Ec2ReservedInstances
|
189
197
|
|
190
198
|
Ec2ReservedInstancesConfiguration.add_member(:account_scope, Shapes::ShapeRef.new(shape: String, location_name: "accountScope"))
|
191
|
-
Ec2ReservedInstancesConfiguration.add_member(:
|
192
|
-
Ec2ReservedInstancesConfiguration.add_member(:instance_family, Shapes::ShapeRef.new(shape: String, location_name: "instanceFamily"))
|
193
|
-
Ec2ReservedInstancesConfiguration.add_member(:instance_type, Shapes::ShapeRef.new(shape: String, location_name: "instanceType"))
|
194
|
-
Ec2ReservedInstancesConfiguration.add_member(:monthly_recurring_cost, Shapes::ShapeRef.new(shape: String, location_name: "monthlyRecurringCost"))
|
199
|
+
Ec2ReservedInstancesConfiguration.add_member(:service, Shapes::ShapeRef.new(shape: String, location_name: "service"))
|
195
200
|
Ec2ReservedInstancesConfiguration.add_member(:normalized_units_to_purchase, Shapes::ShapeRef.new(shape: String, location_name: "normalizedUnitsToPurchase"))
|
201
|
+
Ec2ReservedInstancesConfiguration.add_member(:term, Shapes::ShapeRef.new(shape: String, location_name: "term"))
|
202
|
+
Ec2ReservedInstancesConfiguration.add_member(:payment_option, Shapes::ShapeRef.new(shape: String, location_name: "paymentOption"))
|
196
203
|
Ec2ReservedInstancesConfiguration.add_member(:number_of_instances_to_purchase, Shapes::ShapeRef.new(shape: String, location_name: "numberOfInstancesToPurchase"))
|
197
204
|
Ec2ReservedInstancesConfiguration.add_member(:offering_class, Shapes::ShapeRef.new(shape: String, location_name: "offeringClass"))
|
198
|
-
Ec2ReservedInstancesConfiguration.add_member(:
|
199
|
-
Ec2ReservedInstancesConfiguration.add_member(:
|
205
|
+
Ec2ReservedInstancesConfiguration.add_member(:instance_family, Shapes::ShapeRef.new(shape: String, location_name: "instanceFamily"))
|
206
|
+
Ec2ReservedInstancesConfiguration.add_member(:instance_type, Shapes::ShapeRef.new(shape: String, location_name: "instanceType"))
|
200
207
|
Ec2ReservedInstancesConfiguration.add_member(:reserved_instances_region, Shapes::ShapeRef.new(shape: String, location_name: "reservedInstancesRegion"))
|
201
|
-
Ec2ReservedInstancesConfiguration.add_member(:
|
202
|
-
Ec2ReservedInstancesConfiguration.add_member(:
|
208
|
+
Ec2ReservedInstancesConfiguration.add_member(:current_generation, Shapes::ShapeRef.new(shape: String, location_name: "currentGeneration"))
|
209
|
+
Ec2ReservedInstancesConfiguration.add_member(:platform, Shapes::ShapeRef.new(shape: String, location_name: "platform"))
|
203
210
|
Ec2ReservedInstancesConfiguration.add_member(:tenancy, Shapes::ShapeRef.new(shape: String, location_name: "tenancy"))
|
204
|
-
Ec2ReservedInstancesConfiguration.add_member(:
|
211
|
+
Ec2ReservedInstancesConfiguration.add_member(:size_flex_eligible, Shapes::ShapeRef.new(shape: Boolean, location_name: "sizeFlexEligible"))
|
205
212
|
Ec2ReservedInstancesConfiguration.add_member(:upfront_cost, Shapes::ShapeRef.new(shape: String, location_name: "upfrontCost"))
|
213
|
+
Ec2ReservedInstancesConfiguration.add_member(:monthly_recurring_cost, Shapes::ShapeRef.new(shape: String, location_name: "monthlyRecurringCost"))
|
206
214
|
Ec2ReservedInstancesConfiguration.struct_class = Types::Ec2ReservedInstancesConfiguration
|
207
215
|
|
208
216
|
EcsService.add_member(:configuration, Shapes::ShapeRef.new(shape: EcsServiceConfiguration, location_name: "configuration"))
|
@@ -217,69 +225,69 @@ module Aws::CostOptimizationHub
|
|
217
225
|
ElastiCacheReservedInstances.struct_class = Types::ElastiCacheReservedInstances
|
218
226
|
|
219
227
|
ElastiCacheReservedInstancesConfiguration.add_member(:account_scope, Shapes::ShapeRef.new(shape: String, location_name: "accountScope"))
|
220
|
-
ElastiCacheReservedInstancesConfiguration.add_member(:
|
221
|
-
ElastiCacheReservedInstancesConfiguration.add_member(:instance_family, Shapes::ShapeRef.new(shape: String, location_name: "instanceFamily"))
|
222
|
-
ElastiCacheReservedInstancesConfiguration.add_member(:instance_type, Shapes::ShapeRef.new(shape: String, location_name: "instanceType"))
|
223
|
-
ElastiCacheReservedInstancesConfiguration.add_member(:monthly_recurring_cost, Shapes::ShapeRef.new(shape: String, location_name: "monthlyRecurringCost"))
|
228
|
+
ElastiCacheReservedInstancesConfiguration.add_member(:service, Shapes::ShapeRef.new(shape: String, location_name: "service"))
|
224
229
|
ElastiCacheReservedInstancesConfiguration.add_member(:normalized_units_to_purchase, Shapes::ShapeRef.new(shape: String, location_name: "normalizedUnitsToPurchase"))
|
225
|
-
ElastiCacheReservedInstancesConfiguration.add_member(:
|
230
|
+
ElastiCacheReservedInstancesConfiguration.add_member(:term, Shapes::ShapeRef.new(shape: String, location_name: "term"))
|
226
231
|
ElastiCacheReservedInstancesConfiguration.add_member(:payment_option, Shapes::ShapeRef.new(shape: String, location_name: "paymentOption"))
|
232
|
+
ElastiCacheReservedInstancesConfiguration.add_member(:number_of_instances_to_purchase, Shapes::ShapeRef.new(shape: String, location_name: "numberOfInstancesToPurchase"))
|
233
|
+
ElastiCacheReservedInstancesConfiguration.add_member(:instance_family, Shapes::ShapeRef.new(shape: String, location_name: "instanceFamily"))
|
234
|
+
ElastiCacheReservedInstancesConfiguration.add_member(:instance_type, Shapes::ShapeRef.new(shape: String, location_name: "instanceType"))
|
227
235
|
ElastiCacheReservedInstancesConfiguration.add_member(:reserved_instances_region, Shapes::ShapeRef.new(shape: String, location_name: "reservedInstancesRegion"))
|
228
|
-
ElastiCacheReservedInstancesConfiguration.add_member(:
|
236
|
+
ElastiCacheReservedInstancesConfiguration.add_member(:current_generation, Shapes::ShapeRef.new(shape: String, location_name: "currentGeneration"))
|
229
237
|
ElastiCacheReservedInstancesConfiguration.add_member(:size_flex_eligible, Shapes::ShapeRef.new(shape: Boolean, location_name: "sizeFlexEligible"))
|
230
|
-
ElastiCacheReservedInstancesConfiguration.add_member(:term, Shapes::ShapeRef.new(shape: String, location_name: "term"))
|
231
238
|
ElastiCacheReservedInstancesConfiguration.add_member(:upfront_cost, Shapes::ShapeRef.new(shape: String, location_name: "upfrontCost"))
|
239
|
+
ElastiCacheReservedInstancesConfiguration.add_member(:monthly_recurring_cost, Shapes::ShapeRef.new(shape: String, location_name: "monthlyRecurringCost"))
|
232
240
|
ElastiCacheReservedInstancesConfiguration.struct_class = Types::ElastiCacheReservedInstancesConfiguration
|
233
241
|
|
234
|
-
EstimatedDiscounts.add_member(:other_discount, Shapes::ShapeRef.new(shape: Double, location_name: "otherDiscount"))
|
235
|
-
EstimatedDiscounts.add_member(:reserved_instances_discount, Shapes::ShapeRef.new(shape: Double, location_name: "reservedInstancesDiscount"))
|
236
242
|
EstimatedDiscounts.add_member(:savings_plans_discount, Shapes::ShapeRef.new(shape: Double, location_name: "savingsPlansDiscount"))
|
243
|
+
EstimatedDiscounts.add_member(:reserved_instances_discount, Shapes::ShapeRef.new(shape: Double, location_name: "reservedInstancesDiscount"))
|
244
|
+
EstimatedDiscounts.add_member(:other_discount, Shapes::ShapeRef.new(shape: Double, location_name: "otherDiscount"))
|
237
245
|
EstimatedDiscounts.struct_class = Types::EstimatedDiscounts
|
238
246
|
|
239
|
-
Filter.add_member(:
|
240
|
-
Filter.add_member(:
|
247
|
+
Filter.add_member(:restart_needed, Shapes::ShapeRef.new(shape: Boolean, location_name: "restartNeeded"))
|
248
|
+
Filter.add_member(:rollback_possible, Shapes::ShapeRef.new(shape: Boolean, location_name: "rollbackPossible"))
|
241
249
|
Filter.add_member(:implementation_efforts, Shapes::ShapeRef.new(shape: ImplementationEffortList, location_name: "implementationEfforts"))
|
242
|
-
Filter.add_member(:
|
250
|
+
Filter.add_member(:account_ids, Shapes::ShapeRef.new(shape: AccountIdList, location_name: "accountIds"))
|
243
251
|
Filter.add_member(:regions, Shapes::ShapeRef.new(shape: RegionList, location_name: "regions"))
|
244
|
-
Filter.add_member(:resource_arns, Shapes::ShapeRef.new(shape: ResourceArnList, location_name: "resourceArns"))
|
245
|
-
Filter.add_member(:resource_ids, Shapes::ShapeRef.new(shape: ResourceIdList, location_name: "resourceIds"))
|
246
252
|
Filter.add_member(:resource_types, Shapes::ShapeRef.new(shape: ResourceTypeList, location_name: "resourceTypes"))
|
247
|
-
Filter.add_member(:
|
248
|
-
Filter.add_member(:rollback_possible, Shapes::ShapeRef.new(shape: Boolean, location_name: "rollbackPossible"))
|
253
|
+
Filter.add_member(:action_types, Shapes::ShapeRef.new(shape: ActionTypeList, location_name: "actionTypes"))
|
249
254
|
Filter.add_member(:tags, Shapes::ShapeRef.new(shape: TagList, location_name: "tags"))
|
255
|
+
Filter.add_member(:resource_ids, Shapes::ShapeRef.new(shape: ResourceIdList, location_name: "resourceIds"))
|
256
|
+
Filter.add_member(:resource_arns, Shapes::ShapeRef.new(shape: ResourceArnList, location_name: "resourceArns"))
|
257
|
+
Filter.add_member(:recommendation_ids, Shapes::ShapeRef.new(shape: RecommendationIdList, location_name: "recommendationIds"))
|
250
258
|
Filter.struct_class = Types::Filter
|
251
259
|
|
252
260
|
GetPreferencesRequest.struct_class = Types::GetPreferencesRequest
|
253
261
|
|
254
|
-
GetPreferencesResponse.add_member(:member_account_discount_visibility, Shapes::ShapeRef.new(shape: MemberAccountDiscountVisibility, location_name: "memberAccountDiscountVisibility"))
|
255
262
|
GetPreferencesResponse.add_member(:savings_estimation_mode, Shapes::ShapeRef.new(shape: SavingsEstimationMode, location_name: "savingsEstimationMode"))
|
263
|
+
GetPreferencesResponse.add_member(:member_account_discount_visibility, Shapes::ShapeRef.new(shape: MemberAccountDiscountVisibility, location_name: "memberAccountDiscountVisibility"))
|
256
264
|
GetPreferencesResponse.struct_class = Types::GetPreferencesResponse
|
257
265
|
|
258
266
|
GetRecommendationRequest.add_member(:recommendation_id, Shapes::ShapeRef.new(shape: String, required: true, location_name: "recommendationId"))
|
259
267
|
GetRecommendationRequest.struct_class = Types::GetRecommendationRequest
|
260
268
|
|
269
|
+
GetRecommendationResponse.add_member(:recommendation_id, Shapes::ShapeRef.new(shape: String, location_name: "recommendationId"))
|
270
|
+
GetRecommendationResponse.add_member(:resource_id, Shapes::ShapeRef.new(shape: String, location_name: "resourceId"))
|
271
|
+
GetRecommendationResponse.add_member(:resource_arn, Shapes::ShapeRef.new(shape: String, location_name: "resourceArn"))
|
261
272
|
GetRecommendationResponse.add_member(:account_id, Shapes::ShapeRef.new(shape: String, location_name: "accountId"))
|
262
|
-
GetRecommendationResponse.add_member(:action_type, Shapes::ShapeRef.new(shape: ActionType, location_name: "actionType"))
|
263
|
-
GetRecommendationResponse.add_member(:cost_calculation_lookback_period_in_days, Shapes::ShapeRef.new(shape: Integer, location_name: "costCalculationLookbackPeriodInDays"))
|
264
273
|
GetRecommendationResponse.add_member(:currency_code, Shapes::ShapeRef.new(shape: String, location_name: "currencyCode"))
|
265
|
-
GetRecommendationResponse.add_member(:current_resource_details, Shapes::ShapeRef.new(shape: ResourceDetails, location_name: "currentResourceDetails"))
|
266
|
-
GetRecommendationResponse.add_member(:current_resource_type, Shapes::ShapeRef.new(shape: ResourceType, location_name: "currentResourceType"))
|
267
|
-
GetRecommendationResponse.add_member(:estimated_monthly_cost, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedMonthlyCost"))
|
268
|
-
GetRecommendationResponse.add_member(:estimated_monthly_savings, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedMonthlySavings"))
|
269
|
-
GetRecommendationResponse.add_member(:estimated_savings_over_cost_calculation_lookback_period, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedSavingsOverCostCalculationLookbackPeriod"))
|
270
|
-
GetRecommendationResponse.add_member(:estimated_savings_percentage, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedSavingsPercentage"))
|
271
|
-
GetRecommendationResponse.add_member(:implementation_effort, Shapes::ShapeRef.new(shape: ImplementationEffort, location_name: "implementationEffort"))
|
272
|
-
GetRecommendationResponse.add_member(:last_refresh_timestamp, Shapes::ShapeRef.new(shape: Datetime, location_name: "lastRefreshTimestamp"))
|
273
|
-
GetRecommendationResponse.add_member(:recommendation_id, Shapes::ShapeRef.new(shape: String, location_name: "recommendationId"))
|
274
274
|
GetRecommendationResponse.add_member(:recommendation_lookback_period_in_days, Shapes::ShapeRef.new(shape: Integer, location_name: "recommendationLookbackPeriodInDays"))
|
275
|
-
GetRecommendationResponse.add_member(:
|
275
|
+
GetRecommendationResponse.add_member(:cost_calculation_lookback_period_in_days, Shapes::ShapeRef.new(shape: Integer, location_name: "costCalculationLookbackPeriodInDays"))
|
276
|
+
GetRecommendationResponse.add_member(:estimated_savings_percentage, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedSavingsPercentage"))
|
277
|
+
GetRecommendationResponse.add_member(:estimated_savings_over_cost_calculation_lookback_period, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedSavingsOverCostCalculationLookbackPeriod"))
|
278
|
+
GetRecommendationResponse.add_member(:current_resource_type, Shapes::ShapeRef.new(shape: ResourceType, location_name: "currentResourceType"))
|
276
279
|
GetRecommendationResponse.add_member(:recommended_resource_type, Shapes::ShapeRef.new(shape: ResourceType, location_name: "recommendedResourceType"))
|
277
280
|
GetRecommendationResponse.add_member(:region, Shapes::ShapeRef.new(shape: String, location_name: "region"))
|
278
|
-
GetRecommendationResponse.add_member(:
|
279
|
-
GetRecommendationResponse.add_member(:
|
281
|
+
GetRecommendationResponse.add_member(:source, Shapes::ShapeRef.new(shape: Source, location_name: "source"))
|
282
|
+
GetRecommendationResponse.add_member(:last_refresh_timestamp, Shapes::ShapeRef.new(shape: Datetime, location_name: "lastRefreshTimestamp"))
|
283
|
+
GetRecommendationResponse.add_member(:estimated_monthly_savings, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedMonthlySavings"))
|
284
|
+
GetRecommendationResponse.add_member(:estimated_monthly_cost, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedMonthlyCost"))
|
285
|
+
GetRecommendationResponse.add_member(:implementation_effort, Shapes::ShapeRef.new(shape: ImplementationEffort, location_name: "implementationEffort"))
|
280
286
|
GetRecommendationResponse.add_member(:restart_needed, Shapes::ShapeRef.new(shape: Boolean, location_name: "restartNeeded"))
|
287
|
+
GetRecommendationResponse.add_member(:action_type, Shapes::ShapeRef.new(shape: ActionType, location_name: "actionType"))
|
281
288
|
GetRecommendationResponse.add_member(:rollback_possible, Shapes::ShapeRef.new(shape: Boolean, location_name: "rollbackPossible"))
|
282
|
-
GetRecommendationResponse.add_member(:
|
289
|
+
GetRecommendationResponse.add_member(:current_resource_details, Shapes::ShapeRef.new(shape: ResourceDetails, location_name: "currentResourceDetails"))
|
290
|
+
GetRecommendationResponse.add_member(:recommended_resource_details, Shapes::ShapeRef.new(shape: ResourceDetails, location_name: "recommendedResourceDetails"))
|
283
291
|
GetRecommendationResponse.add_member(:tags, Shapes::ShapeRef.new(shape: TagList, location_name: "tags"))
|
284
292
|
GetRecommendationResponse.struct_class = Types::GetRecommendationResponse
|
285
293
|
|
@@ -298,14 +306,14 @@ module Aws::CostOptimizationHub
|
|
298
306
|
LambdaFunctionConfiguration.add_member(:compute, Shapes::ShapeRef.new(shape: ComputeConfiguration, location_name: "compute"))
|
299
307
|
LambdaFunctionConfiguration.struct_class = Types::LambdaFunctionConfiguration
|
300
308
|
|
301
|
-
ListEnrollmentStatusesRequest.add_member(:account_id, Shapes::ShapeRef.new(shape: AccountId, location_name: "accountId"))
|
302
309
|
ListEnrollmentStatusesRequest.add_member(:include_organization_info, Shapes::ShapeRef.new(shape: PrimitiveBoolean, location_name: "includeOrganizationInfo"))
|
303
|
-
ListEnrollmentStatusesRequest.add_member(:
|
310
|
+
ListEnrollmentStatusesRequest.add_member(:account_id, Shapes::ShapeRef.new(shape: AccountId, location_name: "accountId"))
|
304
311
|
ListEnrollmentStatusesRequest.add_member(:next_token, Shapes::ShapeRef.new(shape: String, location_name: "nextToken"))
|
312
|
+
ListEnrollmentStatusesRequest.add_member(:max_results, Shapes::ShapeRef.new(shape: MaxResults, location_name: "maxResults"))
|
305
313
|
ListEnrollmentStatusesRequest.struct_class = Types::ListEnrollmentStatusesRequest
|
306
314
|
|
307
|
-
ListEnrollmentStatusesResponse.add_member(:include_member_accounts, Shapes::ShapeRef.new(shape: Boolean, location_name: "includeMemberAccounts"))
|
308
315
|
ListEnrollmentStatusesResponse.add_member(:items, Shapes::ShapeRef.new(shape: AccountEnrollmentStatuses, location_name: "items"))
|
316
|
+
ListEnrollmentStatusesResponse.add_member(:include_member_accounts, Shapes::ShapeRef.new(shape: Boolean, location_name: "includeMemberAccounts"))
|
309
317
|
ListEnrollmentStatusesResponse.add_member(:next_token, Shapes::ShapeRef.new(shape: String, location_name: "nextToken"))
|
310
318
|
ListEnrollmentStatusesResponse.struct_class = Types::ListEnrollmentStatusesResponse
|
311
319
|
|
@@ -315,18 +323,18 @@ module Aws::CostOptimizationHub
|
|
315
323
|
ListRecommendationSummariesRequest.add_member(:next_token, Shapes::ShapeRef.new(shape: String, location_name: "nextToken"))
|
316
324
|
ListRecommendationSummariesRequest.struct_class = Types::ListRecommendationSummariesRequest
|
317
325
|
|
318
|
-
ListRecommendationSummariesResponse.add_member(:currency_code, Shapes::ShapeRef.new(shape: String, location_name: "currencyCode"))
|
319
326
|
ListRecommendationSummariesResponse.add_member(:estimated_total_deduped_savings, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedTotalDedupedSavings"))
|
320
|
-
ListRecommendationSummariesResponse.add_member(:group_by, Shapes::ShapeRef.new(shape: String, location_name: "groupBy"))
|
321
327
|
ListRecommendationSummariesResponse.add_member(:items, Shapes::ShapeRef.new(shape: RecommendationSummariesList, location_name: "items"))
|
328
|
+
ListRecommendationSummariesResponse.add_member(:group_by, Shapes::ShapeRef.new(shape: String, location_name: "groupBy"))
|
329
|
+
ListRecommendationSummariesResponse.add_member(:currency_code, Shapes::ShapeRef.new(shape: String, location_name: "currencyCode"))
|
322
330
|
ListRecommendationSummariesResponse.add_member(:next_token, Shapes::ShapeRef.new(shape: String, location_name: "nextToken"))
|
323
331
|
ListRecommendationSummariesResponse.struct_class = Types::ListRecommendationSummariesResponse
|
324
332
|
|
325
333
|
ListRecommendationsRequest.add_member(:filter, Shapes::ShapeRef.new(shape: Filter, location_name: "filter"))
|
334
|
+
ListRecommendationsRequest.add_member(:order_by, Shapes::ShapeRef.new(shape: OrderBy, location_name: "orderBy"))
|
326
335
|
ListRecommendationsRequest.add_member(:include_all_recommendations, Shapes::ShapeRef.new(shape: PrimitiveBoolean, location_name: "includeAllRecommendations"))
|
327
336
|
ListRecommendationsRequest.add_member(:max_results, Shapes::ShapeRef.new(shape: ListRecommendationsRequestMaxResultsInteger, location_name: "maxResults"))
|
328
337
|
ListRecommendationsRequest.add_member(:next_token, Shapes::ShapeRef.new(shape: String, location_name: "nextToken"))
|
329
|
-
ListRecommendationsRequest.add_member(:order_by, Shapes::ShapeRef.new(shape: OrderBy, location_name: "orderBy"))
|
330
338
|
ListRecommendationsRequest.struct_class = Types::ListRecommendationsRequest
|
331
339
|
|
332
340
|
ListRecommendationsResponse.add_member(:items, Shapes::ShapeRef.new(shape: RecommendationList, location_name: "items"))
|
@@ -338,65 +346,82 @@ module Aws::CostOptimizationHub
|
|
338
346
|
OpenSearchReservedInstances.struct_class = Types::OpenSearchReservedInstances
|
339
347
|
|
340
348
|
OpenSearchReservedInstancesConfiguration.add_member(:account_scope, Shapes::ShapeRef.new(shape: String, location_name: "accountScope"))
|
341
|
-
OpenSearchReservedInstancesConfiguration.add_member(:
|
342
|
-
OpenSearchReservedInstancesConfiguration.add_member(:instance_type, Shapes::ShapeRef.new(shape: String, location_name: "instanceType"))
|
343
|
-
OpenSearchReservedInstancesConfiguration.add_member(:monthly_recurring_cost, Shapes::ShapeRef.new(shape: String, location_name: "monthlyRecurringCost"))
|
349
|
+
OpenSearchReservedInstancesConfiguration.add_member(:service, Shapes::ShapeRef.new(shape: String, location_name: "service"))
|
344
350
|
OpenSearchReservedInstancesConfiguration.add_member(:normalized_units_to_purchase, Shapes::ShapeRef.new(shape: String, location_name: "normalizedUnitsToPurchase"))
|
345
|
-
OpenSearchReservedInstancesConfiguration.add_member(:
|
351
|
+
OpenSearchReservedInstancesConfiguration.add_member(:term, Shapes::ShapeRef.new(shape: String, location_name: "term"))
|
346
352
|
OpenSearchReservedInstancesConfiguration.add_member(:payment_option, Shapes::ShapeRef.new(shape: String, location_name: "paymentOption"))
|
353
|
+
OpenSearchReservedInstancesConfiguration.add_member(:number_of_instances_to_purchase, Shapes::ShapeRef.new(shape: String, location_name: "numberOfInstancesToPurchase"))
|
354
|
+
OpenSearchReservedInstancesConfiguration.add_member(:instance_type, Shapes::ShapeRef.new(shape: String, location_name: "instanceType"))
|
347
355
|
OpenSearchReservedInstancesConfiguration.add_member(:reserved_instances_region, Shapes::ShapeRef.new(shape: String, location_name: "reservedInstancesRegion"))
|
348
|
-
OpenSearchReservedInstancesConfiguration.add_member(:
|
356
|
+
OpenSearchReservedInstancesConfiguration.add_member(:current_generation, Shapes::ShapeRef.new(shape: String, location_name: "currentGeneration"))
|
349
357
|
OpenSearchReservedInstancesConfiguration.add_member(:size_flex_eligible, Shapes::ShapeRef.new(shape: Boolean, location_name: "sizeFlexEligible"))
|
350
|
-
OpenSearchReservedInstancesConfiguration.add_member(:term, Shapes::ShapeRef.new(shape: String, location_name: "term"))
|
351
358
|
OpenSearchReservedInstancesConfiguration.add_member(:upfront_cost, Shapes::ShapeRef.new(shape: String, location_name: "upfrontCost"))
|
359
|
+
OpenSearchReservedInstancesConfiguration.add_member(:monthly_recurring_cost, Shapes::ShapeRef.new(shape: String, location_name: "monthlyRecurringCost"))
|
352
360
|
OpenSearchReservedInstancesConfiguration.struct_class = Types::OpenSearchReservedInstancesConfiguration
|
353
361
|
|
354
362
|
OrderBy.add_member(:dimension, Shapes::ShapeRef.new(shape: String, location_name: "dimension"))
|
355
363
|
OrderBy.add_member(:order, Shapes::ShapeRef.new(shape: Order, location_name: "order"))
|
356
364
|
OrderBy.struct_class = Types::OrderBy
|
357
365
|
|
366
|
+
RdsDbInstance.add_member(:configuration, Shapes::ShapeRef.new(shape: RdsDbInstanceConfiguration, location_name: "configuration"))
|
367
|
+
RdsDbInstance.add_member(:cost_calculation, Shapes::ShapeRef.new(shape: ResourceCostCalculation, location_name: "costCalculation"))
|
368
|
+
RdsDbInstance.struct_class = Types::RdsDbInstance
|
369
|
+
|
370
|
+
RdsDbInstanceConfiguration.add_member(:instance, Shapes::ShapeRef.new(shape: DbInstanceConfiguration, location_name: "instance"))
|
371
|
+
RdsDbInstanceConfiguration.struct_class = Types::RdsDbInstanceConfiguration
|
372
|
+
|
373
|
+
RdsDbInstanceStorage.add_member(:configuration, Shapes::ShapeRef.new(shape: RdsDbInstanceStorageConfiguration, location_name: "configuration"))
|
374
|
+
RdsDbInstanceStorage.add_member(:cost_calculation, Shapes::ShapeRef.new(shape: ResourceCostCalculation, location_name: "costCalculation"))
|
375
|
+
RdsDbInstanceStorage.struct_class = Types::RdsDbInstanceStorage
|
376
|
+
|
377
|
+
RdsDbInstanceStorageConfiguration.add_member(:storage_type, Shapes::ShapeRef.new(shape: String, location_name: "storageType"))
|
378
|
+
RdsDbInstanceStorageConfiguration.add_member(:allocated_storage_in_gb, Shapes::ShapeRef.new(shape: Double, location_name: "allocatedStorageInGb"))
|
379
|
+
RdsDbInstanceStorageConfiguration.add_member(:iops, Shapes::ShapeRef.new(shape: Double, location_name: "iops"))
|
380
|
+
RdsDbInstanceStorageConfiguration.add_member(:storage_throughput, Shapes::ShapeRef.new(shape: Double, location_name: "storageThroughput"))
|
381
|
+
RdsDbInstanceStorageConfiguration.struct_class = Types::RdsDbInstanceStorageConfiguration
|
382
|
+
|
358
383
|
RdsReservedInstances.add_member(:configuration, Shapes::ShapeRef.new(shape: RdsReservedInstancesConfiguration, location_name: "configuration"))
|
359
384
|
RdsReservedInstances.add_member(:cost_calculation, Shapes::ShapeRef.new(shape: ReservedInstancesCostCalculation, location_name: "costCalculation"))
|
360
385
|
RdsReservedInstances.struct_class = Types::RdsReservedInstances
|
361
386
|
|
362
387
|
RdsReservedInstancesConfiguration.add_member(:account_scope, Shapes::ShapeRef.new(shape: String, location_name: "accountScope"))
|
363
|
-
RdsReservedInstancesConfiguration.add_member(:
|
364
|
-
RdsReservedInstancesConfiguration.add_member(:database_edition, Shapes::ShapeRef.new(shape: String, location_name: "databaseEdition"))
|
365
|
-
RdsReservedInstancesConfiguration.add_member(:database_engine, Shapes::ShapeRef.new(shape: String, location_name: "databaseEngine"))
|
366
|
-
RdsReservedInstancesConfiguration.add_member(:deployment_option, Shapes::ShapeRef.new(shape: String, location_name: "deploymentOption"))
|
367
|
-
RdsReservedInstancesConfiguration.add_member(:instance_family, Shapes::ShapeRef.new(shape: String, location_name: "instanceFamily"))
|
368
|
-
RdsReservedInstancesConfiguration.add_member(:instance_type, Shapes::ShapeRef.new(shape: String, location_name: "instanceType"))
|
369
|
-
RdsReservedInstancesConfiguration.add_member(:license_model, Shapes::ShapeRef.new(shape: String, location_name: "licenseModel"))
|
370
|
-
RdsReservedInstancesConfiguration.add_member(:monthly_recurring_cost, Shapes::ShapeRef.new(shape: String, location_name: "monthlyRecurringCost"))
|
388
|
+
RdsReservedInstancesConfiguration.add_member(:service, Shapes::ShapeRef.new(shape: String, location_name: "service"))
|
371
389
|
RdsReservedInstancesConfiguration.add_member(:normalized_units_to_purchase, Shapes::ShapeRef.new(shape: String, location_name: "normalizedUnitsToPurchase"))
|
372
|
-
RdsReservedInstancesConfiguration.add_member(:
|
390
|
+
RdsReservedInstancesConfiguration.add_member(:term, Shapes::ShapeRef.new(shape: String, location_name: "term"))
|
373
391
|
RdsReservedInstancesConfiguration.add_member(:payment_option, Shapes::ShapeRef.new(shape: String, location_name: "paymentOption"))
|
392
|
+
RdsReservedInstancesConfiguration.add_member(:number_of_instances_to_purchase, Shapes::ShapeRef.new(shape: String, location_name: "numberOfInstancesToPurchase"))
|
393
|
+
RdsReservedInstancesConfiguration.add_member(:instance_family, Shapes::ShapeRef.new(shape: String, location_name: "instanceFamily"))
|
394
|
+
RdsReservedInstancesConfiguration.add_member(:instance_type, Shapes::ShapeRef.new(shape: String, location_name: "instanceType"))
|
374
395
|
RdsReservedInstancesConfiguration.add_member(:reserved_instances_region, Shapes::ShapeRef.new(shape: String, location_name: "reservedInstancesRegion"))
|
375
|
-
RdsReservedInstancesConfiguration.add_member(:service, Shapes::ShapeRef.new(shape: String, location_name: "service"))
|
376
396
|
RdsReservedInstancesConfiguration.add_member(:size_flex_eligible, Shapes::ShapeRef.new(shape: Boolean, location_name: "sizeFlexEligible"))
|
377
|
-
RdsReservedInstancesConfiguration.add_member(:
|
397
|
+
RdsReservedInstancesConfiguration.add_member(:current_generation, Shapes::ShapeRef.new(shape: String, location_name: "currentGeneration"))
|
378
398
|
RdsReservedInstancesConfiguration.add_member(:upfront_cost, Shapes::ShapeRef.new(shape: String, location_name: "upfrontCost"))
|
399
|
+
RdsReservedInstancesConfiguration.add_member(:monthly_recurring_cost, Shapes::ShapeRef.new(shape: String, location_name: "monthlyRecurringCost"))
|
400
|
+
RdsReservedInstancesConfiguration.add_member(:license_model, Shapes::ShapeRef.new(shape: String, location_name: "licenseModel"))
|
401
|
+
RdsReservedInstancesConfiguration.add_member(:database_edition, Shapes::ShapeRef.new(shape: String, location_name: "databaseEdition"))
|
402
|
+
RdsReservedInstancesConfiguration.add_member(:database_engine, Shapes::ShapeRef.new(shape: String, location_name: "databaseEngine"))
|
403
|
+
RdsReservedInstancesConfiguration.add_member(:deployment_option, Shapes::ShapeRef.new(shape: String, location_name: "deploymentOption"))
|
379
404
|
RdsReservedInstancesConfiguration.struct_class = Types::RdsReservedInstancesConfiguration
|
380
405
|
|
406
|
+
Recommendation.add_member(:recommendation_id, Shapes::ShapeRef.new(shape: String, location_name: "recommendationId"))
|
381
407
|
Recommendation.add_member(:account_id, Shapes::ShapeRef.new(shape: String, location_name: "accountId"))
|
382
|
-
Recommendation.add_member(:
|
383
|
-
Recommendation.add_member(:
|
384
|
-
Recommendation.add_member(:
|
408
|
+
Recommendation.add_member(:region, Shapes::ShapeRef.new(shape: String, location_name: "region"))
|
409
|
+
Recommendation.add_member(:resource_id, Shapes::ShapeRef.new(shape: String, location_name: "resourceId"))
|
410
|
+
Recommendation.add_member(:resource_arn, Shapes::ShapeRef.new(shape: String, location_name: "resourceArn"))
|
385
411
|
Recommendation.add_member(:current_resource_type, Shapes::ShapeRef.new(shape: String, location_name: "currentResourceType"))
|
386
|
-
Recommendation.add_member(:
|
412
|
+
Recommendation.add_member(:recommended_resource_type, Shapes::ShapeRef.new(shape: String, location_name: "recommendedResourceType"))
|
387
413
|
Recommendation.add_member(:estimated_monthly_savings, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedMonthlySavings"))
|
388
414
|
Recommendation.add_member(:estimated_savings_percentage, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedSavingsPercentage"))
|
415
|
+
Recommendation.add_member(:estimated_monthly_cost, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedMonthlyCost"))
|
416
|
+
Recommendation.add_member(:currency_code, Shapes::ShapeRef.new(shape: String, location_name: "currencyCode"))
|
389
417
|
Recommendation.add_member(:implementation_effort, Shapes::ShapeRef.new(shape: String, location_name: "implementationEffort"))
|
390
|
-
Recommendation.add_member(:last_refresh_timestamp, Shapes::ShapeRef.new(shape: Datetime, location_name: "lastRefreshTimestamp"))
|
391
|
-
Recommendation.add_member(:recommendation_id, Shapes::ShapeRef.new(shape: String, location_name: "recommendationId"))
|
392
|
-
Recommendation.add_member(:recommendation_lookback_period_in_days, Shapes::ShapeRef.new(shape: Integer, location_name: "recommendationLookbackPeriodInDays"))
|
393
|
-
Recommendation.add_member(:recommended_resource_summary, Shapes::ShapeRef.new(shape: String, location_name: "recommendedResourceSummary"))
|
394
|
-
Recommendation.add_member(:recommended_resource_type, Shapes::ShapeRef.new(shape: String, location_name: "recommendedResourceType"))
|
395
|
-
Recommendation.add_member(:region, Shapes::ShapeRef.new(shape: String, location_name: "region"))
|
396
|
-
Recommendation.add_member(:resource_arn, Shapes::ShapeRef.new(shape: String, location_name: "resourceArn"))
|
397
|
-
Recommendation.add_member(:resource_id, Shapes::ShapeRef.new(shape: String, location_name: "resourceId"))
|
398
418
|
Recommendation.add_member(:restart_needed, Shapes::ShapeRef.new(shape: Boolean, location_name: "restartNeeded"))
|
419
|
+
Recommendation.add_member(:action_type, Shapes::ShapeRef.new(shape: String, location_name: "actionType"))
|
399
420
|
Recommendation.add_member(:rollback_possible, Shapes::ShapeRef.new(shape: Boolean, location_name: "rollbackPossible"))
|
421
|
+
Recommendation.add_member(:current_resource_summary, Shapes::ShapeRef.new(shape: String, location_name: "currentResourceSummary"))
|
422
|
+
Recommendation.add_member(:recommended_resource_summary, Shapes::ShapeRef.new(shape: String, location_name: "recommendedResourceSummary"))
|
423
|
+
Recommendation.add_member(:last_refresh_timestamp, Shapes::ShapeRef.new(shape: Datetime, location_name: "lastRefreshTimestamp"))
|
424
|
+
Recommendation.add_member(:recommendation_lookback_period_in_days, Shapes::ShapeRef.new(shape: Integer, location_name: "recommendationLookbackPeriodInDays"))
|
400
425
|
Recommendation.add_member(:source, Shapes::ShapeRef.new(shape: Source, location_name: "source"))
|
401
426
|
Recommendation.add_member(:tags, Shapes::ShapeRef.new(shape: TagList, location_name: "tags"))
|
402
427
|
Recommendation.struct_class = Types::Recommendation
|
@@ -407,8 +432,8 @@ module Aws::CostOptimizationHub
|
|
407
432
|
|
408
433
|
RecommendationSummariesList.member = Shapes::ShapeRef.new(shape: RecommendationSummary)
|
409
434
|
|
410
|
-
RecommendationSummary.add_member(:estimated_monthly_savings, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedMonthlySavings"))
|
411
435
|
RecommendationSummary.add_member(:group, Shapes::ShapeRef.new(shape: String, location_name: "group"))
|
436
|
+
RecommendationSummary.add_member(:estimated_monthly_savings, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedMonthlySavings"))
|
412
437
|
RecommendationSummary.add_member(:recommendation_count, Shapes::ShapeRef.new(shape: Integer, location_name: "recommendationCount"))
|
413
438
|
RecommendationSummary.struct_class = Types::RecommendationSummary
|
414
439
|
|
@@ -417,18 +442,18 @@ module Aws::CostOptimizationHub
|
|
417
442
|
RedshiftReservedInstances.struct_class = Types::RedshiftReservedInstances
|
418
443
|
|
419
444
|
RedshiftReservedInstancesConfiguration.add_member(:account_scope, Shapes::ShapeRef.new(shape: String, location_name: "accountScope"))
|
420
|
-
RedshiftReservedInstancesConfiguration.add_member(:
|
421
|
-
RedshiftReservedInstancesConfiguration.add_member(:instance_family, Shapes::ShapeRef.new(shape: String, location_name: "instanceFamily"))
|
422
|
-
RedshiftReservedInstancesConfiguration.add_member(:instance_type, Shapes::ShapeRef.new(shape: String, location_name: "instanceType"))
|
423
|
-
RedshiftReservedInstancesConfiguration.add_member(:monthly_recurring_cost, Shapes::ShapeRef.new(shape: String, location_name: "monthlyRecurringCost"))
|
445
|
+
RedshiftReservedInstancesConfiguration.add_member(:service, Shapes::ShapeRef.new(shape: String, location_name: "service"))
|
424
446
|
RedshiftReservedInstancesConfiguration.add_member(:normalized_units_to_purchase, Shapes::ShapeRef.new(shape: String, location_name: "normalizedUnitsToPurchase"))
|
425
|
-
RedshiftReservedInstancesConfiguration.add_member(:
|
447
|
+
RedshiftReservedInstancesConfiguration.add_member(:term, Shapes::ShapeRef.new(shape: String, location_name: "term"))
|
426
448
|
RedshiftReservedInstancesConfiguration.add_member(:payment_option, Shapes::ShapeRef.new(shape: String, location_name: "paymentOption"))
|
449
|
+
RedshiftReservedInstancesConfiguration.add_member(:number_of_instances_to_purchase, Shapes::ShapeRef.new(shape: String, location_name: "numberOfInstancesToPurchase"))
|
450
|
+
RedshiftReservedInstancesConfiguration.add_member(:instance_family, Shapes::ShapeRef.new(shape: String, location_name: "instanceFamily"))
|
451
|
+
RedshiftReservedInstancesConfiguration.add_member(:instance_type, Shapes::ShapeRef.new(shape: String, location_name: "instanceType"))
|
427
452
|
RedshiftReservedInstancesConfiguration.add_member(:reserved_instances_region, Shapes::ShapeRef.new(shape: String, location_name: "reservedInstancesRegion"))
|
428
|
-
RedshiftReservedInstancesConfiguration.add_member(:service, Shapes::ShapeRef.new(shape: String, location_name: "service"))
|
429
453
|
RedshiftReservedInstancesConfiguration.add_member(:size_flex_eligible, Shapes::ShapeRef.new(shape: Boolean, location_name: "sizeFlexEligible"))
|
430
|
-
RedshiftReservedInstancesConfiguration.add_member(:
|
454
|
+
RedshiftReservedInstancesConfiguration.add_member(:current_generation, Shapes::ShapeRef.new(shape: String, location_name: "currentGeneration"))
|
431
455
|
RedshiftReservedInstancesConfiguration.add_member(:upfront_cost, Shapes::ShapeRef.new(shape: String, location_name: "upfrontCost"))
|
456
|
+
RedshiftReservedInstancesConfiguration.add_member(:monthly_recurring_cost, Shapes::ShapeRef.new(shape: String, location_name: "monthlyRecurringCost"))
|
432
457
|
RedshiftReservedInstancesConfiguration.struct_class = Types::RedshiftReservedInstancesConfiguration
|
433
458
|
|
434
459
|
RegionList.member = Shapes::ShapeRef.new(shape: String)
|
@@ -436,45 +461,49 @@ module Aws::CostOptimizationHub
|
|
436
461
|
ReservedInstancesCostCalculation.add_member(:pricing, Shapes::ShapeRef.new(shape: ReservedInstancesPricing, location_name: "pricing"))
|
437
462
|
ReservedInstancesCostCalculation.struct_class = Types::ReservedInstancesCostCalculation
|
438
463
|
|
439
|
-
ReservedInstancesPricing.add_member(:estimated_monthly_amortized_reservation_cost, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedMonthlyAmortizedReservationCost"))
|
440
464
|
ReservedInstancesPricing.add_member(:estimated_on_demand_cost, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedOnDemandCost"))
|
441
465
|
ReservedInstancesPricing.add_member(:monthly_reservation_eligible_cost, Shapes::ShapeRef.new(shape: Double, location_name: "monthlyReservationEligibleCost"))
|
442
466
|
ReservedInstancesPricing.add_member(:savings_percentage, Shapes::ShapeRef.new(shape: Double, location_name: "savingsPercentage"))
|
467
|
+
ReservedInstancesPricing.add_member(:estimated_monthly_amortized_reservation_cost, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedMonthlyAmortizedReservationCost"))
|
443
468
|
ReservedInstancesPricing.struct_class = Types::ReservedInstancesPricing
|
444
469
|
|
445
470
|
ResourceArnList.member = Shapes::ShapeRef.new(shape: String)
|
446
471
|
|
447
|
-
ResourceCostCalculation.add_member(:pricing, Shapes::ShapeRef.new(shape: ResourcePricing, location_name: "pricing"))
|
448
472
|
ResourceCostCalculation.add_member(:usages, Shapes::ShapeRef.new(shape: UsageList, location_name: "usages"))
|
473
|
+
ResourceCostCalculation.add_member(:pricing, Shapes::ShapeRef.new(shape: ResourcePricing, location_name: "pricing"))
|
449
474
|
ResourceCostCalculation.struct_class = Types::ResourceCostCalculation
|
450
475
|
|
451
|
-
ResourceDetails.add_member(:
|
476
|
+
ResourceDetails.add_member(:lambda_function, Shapes::ShapeRef.new(shape: LambdaFunction, location_name: "lambdaFunction"))
|
477
|
+
ResourceDetails.add_member(:ecs_service, Shapes::ShapeRef.new(shape: EcsService, location_name: "ecsService"))
|
478
|
+
ResourceDetails.add_member(:ec2_instance, Shapes::ShapeRef.new(shape: Ec2Instance, location_name: "ec2Instance"))
|
452
479
|
ResourceDetails.add_member(:ebs_volume, Shapes::ShapeRef.new(shape: EbsVolume, location_name: "ebsVolume"))
|
453
480
|
ResourceDetails.add_member(:ec2_auto_scaling_group, Shapes::ShapeRef.new(shape: Ec2AutoScalingGroup, location_name: "ec2AutoScalingGroup"))
|
454
|
-
ResourceDetails.add_member(:ec2_instance, Shapes::ShapeRef.new(shape: Ec2Instance, location_name: "ec2Instance"))
|
455
|
-
ResourceDetails.add_member(:ec2_instance_savings_plans, Shapes::ShapeRef.new(shape: Ec2InstanceSavingsPlans, location_name: "ec2InstanceSavingsPlans"))
|
456
481
|
ResourceDetails.add_member(:ec2_reserved_instances, Shapes::ShapeRef.new(shape: Ec2ReservedInstances, location_name: "ec2ReservedInstances"))
|
457
|
-
ResourceDetails.add_member(:
|
482
|
+
ResourceDetails.add_member(:rds_reserved_instances, Shapes::ShapeRef.new(shape: RdsReservedInstances, location_name: "rdsReservedInstances"))
|
458
483
|
ResourceDetails.add_member(:elasti_cache_reserved_instances, Shapes::ShapeRef.new(shape: ElastiCacheReservedInstances, location_name: "elastiCacheReservedInstances"))
|
459
|
-
ResourceDetails.add_member(:lambda_function, Shapes::ShapeRef.new(shape: LambdaFunction, location_name: "lambdaFunction"))
|
460
484
|
ResourceDetails.add_member(:open_search_reserved_instances, Shapes::ShapeRef.new(shape: OpenSearchReservedInstances, location_name: "openSearchReservedInstances"))
|
461
|
-
ResourceDetails.add_member(:rds_reserved_instances, Shapes::ShapeRef.new(shape: RdsReservedInstances, location_name: "rdsReservedInstances"))
|
462
485
|
ResourceDetails.add_member(:redshift_reserved_instances, Shapes::ShapeRef.new(shape: RedshiftReservedInstances, location_name: "redshiftReservedInstances"))
|
486
|
+
ResourceDetails.add_member(:ec2_instance_savings_plans, Shapes::ShapeRef.new(shape: Ec2InstanceSavingsPlans, location_name: "ec2InstanceSavingsPlans"))
|
487
|
+
ResourceDetails.add_member(:compute_savings_plans, Shapes::ShapeRef.new(shape: ComputeSavingsPlans, location_name: "computeSavingsPlans"))
|
463
488
|
ResourceDetails.add_member(:sage_maker_savings_plans, Shapes::ShapeRef.new(shape: SageMakerSavingsPlans, location_name: "sageMakerSavingsPlans"))
|
489
|
+
ResourceDetails.add_member(:rds_db_instance, Shapes::ShapeRef.new(shape: RdsDbInstance, location_name: "rdsDbInstance"))
|
490
|
+
ResourceDetails.add_member(:rds_db_instance_storage, Shapes::ShapeRef.new(shape: RdsDbInstanceStorage, location_name: "rdsDbInstanceStorage"))
|
464
491
|
ResourceDetails.add_member(:unknown, Shapes::ShapeRef.new(shape: nil, location_name: 'unknown'))
|
465
|
-
ResourceDetails.add_member_subclass(:
|
492
|
+
ResourceDetails.add_member_subclass(:lambda_function, Types::ResourceDetails::LambdaFunction)
|
493
|
+
ResourceDetails.add_member_subclass(:ecs_service, Types::ResourceDetails::EcsService)
|
494
|
+
ResourceDetails.add_member_subclass(:ec2_instance, Types::ResourceDetails::Ec2Instance)
|
466
495
|
ResourceDetails.add_member_subclass(:ebs_volume, Types::ResourceDetails::EbsVolume)
|
467
496
|
ResourceDetails.add_member_subclass(:ec2_auto_scaling_group, Types::ResourceDetails::Ec2AutoScalingGroup)
|
468
|
-
ResourceDetails.add_member_subclass(:ec2_instance, Types::ResourceDetails::Ec2Instance)
|
469
|
-
ResourceDetails.add_member_subclass(:ec2_instance_savings_plans, Types::ResourceDetails::Ec2InstanceSavingsPlans)
|
470
497
|
ResourceDetails.add_member_subclass(:ec2_reserved_instances, Types::ResourceDetails::Ec2ReservedInstances)
|
471
|
-
ResourceDetails.add_member_subclass(:
|
498
|
+
ResourceDetails.add_member_subclass(:rds_reserved_instances, Types::ResourceDetails::RdsReservedInstances)
|
472
499
|
ResourceDetails.add_member_subclass(:elasti_cache_reserved_instances, Types::ResourceDetails::ElastiCacheReservedInstances)
|
473
|
-
ResourceDetails.add_member_subclass(:lambda_function, Types::ResourceDetails::LambdaFunction)
|
474
500
|
ResourceDetails.add_member_subclass(:open_search_reserved_instances, Types::ResourceDetails::OpenSearchReservedInstances)
|
475
|
-
ResourceDetails.add_member_subclass(:rds_reserved_instances, Types::ResourceDetails::RdsReservedInstances)
|
476
501
|
ResourceDetails.add_member_subclass(:redshift_reserved_instances, Types::ResourceDetails::RedshiftReservedInstances)
|
502
|
+
ResourceDetails.add_member_subclass(:ec2_instance_savings_plans, Types::ResourceDetails::Ec2InstanceSavingsPlans)
|
503
|
+
ResourceDetails.add_member_subclass(:compute_savings_plans, Types::ResourceDetails::ComputeSavingsPlans)
|
477
504
|
ResourceDetails.add_member_subclass(:sage_maker_savings_plans, Types::ResourceDetails::SageMakerSavingsPlans)
|
505
|
+
ResourceDetails.add_member_subclass(:rds_db_instance, Types::ResourceDetails::RdsDbInstance)
|
506
|
+
ResourceDetails.add_member_subclass(:rds_db_instance_storage, Types::ResourceDetails::RdsDbInstanceStorage)
|
478
507
|
ResourceDetails.add_member_subclass(:unknown, Types::ResourceDetails::Unknown)
|
479
508
|
ResourceDetails.struct_class = Types::ResourceDetails
|
480
509
|
|
@@ -484,10 +513,10 @@ module Aws::CostOptimizationHub
|
|
484
513
|
ResourceNotFoundException.add_member(:resource_id, Shapes::ShapeRef.new(shape: String, required: true, location_name: "resourceId"))
|
485
514
|
ResourceNotFoundException.struct_class = Types::ResourceNotFoundException
|
486
515
|
|
487
|
-
ResourcePricing.add_member(:estimated_cost_after_discounts, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedCostAfterDiscounts"))
|
488
516
|
ResourcePricing.add_member(:estimated_cost_before_discounts, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedCostBeforeDiscounts"))
|
489
|
-
ResourcePricing.add_member(:estimated_discounts, Shapes::ShapeRef.new(shape: EstimatedDiscounts, location_name: "estimatedDiscounts"))
|
490
517
|
ResourcePricing.add_member(:estimated_net_unused_amortized_commitments, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedNetUnusedAmortizedCommitments"))
|
518
|
+
ResourcePricing.add_member(:estimated_discounts, Shapes::ShapeRef.new(shape: EstimatedDiscounts, location_name: "estimatedDiscounts"))
|
519
|
+
ResourcePricing.add_member(:estimated_cost_after_discounts, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedCostAfterDiscounts"))
|
491
520
|
ResourcePricing.struct_class = Types::ResourcePricing
|
492
521
|
|
493
522
|
ResourceTypeList.member = Shapes::ShapeRef.new(shape: ResourceType)
|
@@ -497,22 +526,22 @@ module Aws::CostOptimizationHub
|
|
497
526
|
SageMakerSavingsPlans.struct_class = Types::SageMakerSavingsPlans
|
498
527
|
|
499
528
|
SageMakerSavingsPlansConfiguration.add_member(:account_scope, Shapes::ShapeRef.new(shape: String, location_name: "accountScope"))
|
500
|
-
SageMakerSavingsPlansConfiguration.add_member(:hourly_commitment, Shapes::ShapeRef.new(shape: String, location_name: "hourlyCommitment"))
|
501
|
-
SageMakerSavingsPlansConfiguration.add_member(:payment_option, Shapes::ShapeRef.new(shape: String, location_name: "paymentOption"))
|
502
529
|
SageMakerSavingsPlansConfiguration.add_member(:term, Shapes::ShapeRef.new(shape: String, location_name: "term"))
|
530
|
+
SageMakerSavingsPlansConfiguration.add_member(:payment_option, Shapes::ShapeRef.new(shape: String, location_name: "paymentOption"))
|
531
|
+
SageMakerSavingsPlansConfiguration.add_member(:hourly_commitment, Shapes::ShapeRef.new(shape: String, location_name: "hourlyCommitment"))
|
503
532
|
SageMakerSavingsPlansConfiguration.struct_class = Types::SageMakerSavingsPlansConfiguration
|
504
533
|
|
505
534
|
SavingsPlansCostCalculation.add_member(:pricing, Shapes::ShapeRef.new(shape: SavingsPlansPricing, location_name: "pricing"))
|
506
535
|
SavingsPlansCostCalculation.struct_class = Types::SavingsPlansCostCalculation
|
507
536
|
|
508
|
-
SavingsPlansPricing.add_member(:estimated_monthly_commitment, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedMonthlyCommitment"))
|
509
|
-
SavingsPlansPricing.add_member(:estimated_on_demand_cost, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedOnDemandCost"))
|
510
537
|
SavingsPlansPricing.add_member(:monthly_savings_plans_eligible_cost, Shapes::ShapeRef.new(shape: Double, location_name: "monthlySavingsPlansEligibleCost"))
|
538
|
+
SavingsPlansPricing.add_member(:estimated_monthly_commitment, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedMonthlyCommitment"))
|
511
539
|
SavingsPlansPricing.add_member(:savings_percentage, Shapes::ShapeRef.new(shape: Double, location_name: "savingsPercentage"))
|
540
|
+
SavingsPlansPricing.add_member(:estimated_on_demand_cost, Shapes::ShapeRef.new(shape: Double, location_name: "estimatedOnDemandCost"))
|
512
541
|
SavingsPlansPricing.struct_class = Types::SavingsPlansPricing
|
513
542
|
|
514
|
-
StorageConfiguration.add_member(:size_in_gb, Shapes::ShapeRef.new(shape: Double, location_name: "sizeInGb"))
|
515
543
|
StorageConfiguration.add_member(:type, Shapes::ShapeRef.new(shape: String, location_name: "type"))
|
544
|
+
StorageConfiguration.add_member(:size_in_gb, Shapes::ShapeRef.new(shape: Double, location_name: "sizeInGb"))
|
516
545
|
StorageConfiguration.struct_class = Types::StorageConfiguration
|
517
546
|
|
518
547
|
Tag.add_member(:key, Shapes::ShapeRef.new(shape: String, location_name: "key"))
|
@@ -524,33 +553,33 @@ module Aws::CostOptimizationHub
|
|
524
553
|
ThrottlingException.add_member(:message, Shapes::ShapeRef.new(shape: String, location_name: "message"))
|
525
554
|
ThrottlingException.struct_class = Types::ThrottlingException
|
526
555
|
|
527
|
-
UpdateEnrollmentStatusRequest.add_member(:include_member_accounts, Shapes::ShapeRef.new(shape: Boolean, location_name: "includeMemberAccounts"))
|
528
556
|
UpdateEnrollmentStatusRequest.add_member(:status, Shapes::ShapeRef.new(shape: EnrollmentStatus, required: true, location_name: "status"))
|
557
|
+
UpdateEnrollmentStatusRequest.add_member(:include_member_accounts, Shapes::ShapeRef.new(shape: Boolean, location_name: "includeMemberAccounts"))
|
529
558
|
UpdateEnrollmentStatusRequest.struct_class = Types::UpdateEnrollmentStatusRequest
|
530
559
|
|
531
560
|
UpdateEnrollmentStatusResponse.add_member(:status, Shapes::ShapeRef.new(shape: String, location_name: "status"))
|
532
561
|
UpdateEnrollmentStatusResponse.struct_class = Types::UpdateEnrollmentStatusResponse
|
533
562
|
|
534
|
-
UpdatePreferencesRequest.add_member(:member_account_discount_visibility, Shapes::ShapeRef.new(shape: MemberAccountDiscountVisibility, location_name: "memberAccountDiscountVisibility"))
|
535
563
|
UpdatePreferencesRequest.add_member(:savings_estimation_mode, Shapes::ShapeRef.new(shape: SavingsEstimationMode, location_name: "savingsEstimationMode"))
|
564
|
+
UpdatePreferencesRequest.add_member(:member_account_discount_visibility, Shapes::ShapeRef.new(shape: MemberAccountDiscountVisibility, location_name: "memberAccountDiscountVisibility"))
|
536
565
|
UpdatePreferencesRequest.struct_class = Types::UpdatePreferencesRequest
|
537
566
|
|
538
|
-
UpdatePreferencesResponse.add_member(:member_account_discount_visibility, Shapes::ShapeRef.new(shape: MemberAccountDiscountVisibility, location_name: "memberAccountDiscountVisibility"))
|
539
567
|
UpdatePreferencesResponse.add_member(:savings_estimation_mode, Shapes::ShapeRef.new(shape: SavingsEstimationMode, location_name: "savingsEstimationMode"))
|
568
|
+
UpdatePreferencesResponse.add_member(:member_account_discount_visibility, Shapes::ShapeRef.new(shape: MemberAccountDiscountVisibility, location_name: "memberAccountDiscountVisibility"))
|
540
569
|
UpdatePreferencesResponse.struct_class = Types::UpdatePreferencesResponse
|
541
570
|
|
571
|
+
Usage.add_member(:usage_type, Shapes::ShapeRef.new(shape: String, location_name: "usageType"))
|
572
|
+
Usage.add_member(:usage_amount, Shapes::ShapeRef.new(shape: Double, location_name: "usageAmount"))
|
542
573
|
Usage.add_member(:operation, Shapes::ShapeRef.new(shape: String, location_name: "operation"))
|
543
574
|
Usage.add_member(:product_code, Shapes::ShapeRef.new(shape: String, location_name: "productCode"))
|
544
575
|
Usage.add_member(:unit, Shapes::ShapeRef.new(shape: String, location_name: "unit"))
|
545
|
-
Usage.add_member(:usage_amount, Shapes::ShapeRef.new(shape: Double, location_name: "usageAmount"))
|
546
|
-
Usage.add_member(:usage_type, Shapes::ShapeRef.new(shape: String, location_name: "usageType"))
|
547
576
|
Usage.struct_class = Types::Usage
|
548
577
|
|
549
578
|
UsageList.member = Shapes::ShapeRef.new(shape: Usage)
|
550
579
|
|
551
|
-
ValidationException.add_member(:fields, Shapes::ShapeRef.new(shape: ValidationExceptionDetails, location_name: "fields"))
|
552
580
|
ValidationException.add_member(:message, Shapes::ShapeRef.new(shape: String, required: true, location_name: "message"))
|
553
581
|
ValidationException.add_member(:reason, Shapes::ShapeRef.new(shape: ValidationExceptionReason, location_name: "reason"))
|
582
|
+
ValidationException.add_member(:fields, Shapes::ShapeRef.new(shape: ValidationExceptionDetails, location_name: "fields"))
|
554
583
|
ValidationException.struct_class = Types::ValidationException
|
555
584
|
|
556
585
|
ValidationExceptionDetail.add_member(:field_name, Shapes::ShapeRef.new(shape: String, required: true, location_name: "fieldName"))
|
@@ -567,9 +596,11 @@ module Aws::CostOptimizationHub
|
|
567
596
|
|
568
597
|
api.metadata = {
|
569
598
|
"apiVersion" => "2022-07-26",
|
599
|
+
"auth" => ["aws.auth#sigv4"],
|
570
600
|
"endpointPrefix" => "cost-optimization-hub",
|
571
601
|
"jsonVersion" => "1.0",
|
572
602
|
"protocol" => "json",
|
603
|
+
"protocols" => ["json"],
|
573
604
|
"serviceFullName" => "Cost Optimization Hub",
|
574
605
|
"serviceId" => "Cost Optimization Hub",
|
575
606
|
"signatureVersion" => "v4",
|
@@ -113,11 +113,6 @@ module Aws::CostOptimizationHub
|
|
113
113
|
super(context, message, data)
|
114
114
|
end
|
115
115
|
|
116
|
-
# @return [String]
|
117
|
-
def fields
|
118
|
-
@data[:fields]
|
119
|
-
end
|
120
|
-
|
121
116
|
# @return [String]
|
122
117
|
def message
|
123
118
|
@message || @data[:message]
|
@@ -127,6 +122,11 @@ module Aws::CostOptimizationHub
|
|
127
122
|
def reason
|
128
123
|
@data[:reason]
|
129
124
|
end
|
125
|
+
|
126
|
+
# @return [String]
|
127
|
+
def fields
|
128
|
+
@data[:fields]
|
129
|
+
end
|
130
130
|
end
|
131
131
|
|
132
132
|
end
|