com.amazonaws.services.elasticache.model.transform.ModifyReplicationGroupShardConfigurationRequestMarshaller Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aws-java-sdk-elasticache Show documentation
Show all versions of aws-java-sdk-elasticache Show documentation
The AWS Java SDK for Amazon ElastiCache module holds the client classes that are used for communicating with Amazon ElastiCache Service
/*
* Copyright 2014-2019 Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
* the License. A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
* CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
* and limitations under the License.
*/
package com.amazonaws.services.elasticache.model.transform;
import javax.annotation.Generated;
import com.amazonaws.SdkClientException;
import com.amazonaws.Request;
import com.amazonaws.DefaultRequest;
import com.amazonaws.http.HttpMethodName;
import com.amazonaws.services.elasticache.model.*;
import com.amazonaws.transform.Marshaller;
import com.amazonaws.util.StringUtils;
/**
* ModifyReplicationGroupShardConfigurationRequest Marshaller
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class ModifyReplicationGroupShardConfigurationRequestMarshaller implements
Marshaller, ModifyReplicationGroupShardConfigurationRequest> {
public Request marshall(
ModifyReplicationGroupShardConfigurationRequest modifyReplicationGroupShardConfigurationRequest) {
if (modifyReplicationGroupShardConfigurationRequest == null) {
throw new SdkClientException("Invalid argument passed to marshall(...)");
}
Request request = new DefaultRequest(
modifyReplicationGroupShardConfigurationRequest, "AmazonElastiCache");
request.addParameter("Action", "ModifyReplicationGroupShardConfiguration");
request.addParameter("Version", "2015-02-02");
request.setHttpMethod(HttpMethodName.POST);
if (modifyReplicationGroupShardConfigurationRequest.getReplicationGroupId() != null) {
request.addParameter("ReplicationGroupId", StringUtils.fromString(modifyReplicationGroupShardConfigurationRequest.getReplicationGroupId()));
}
if (modifyReplicationGroupShardConfigurationRequest.getNodeGroupCount() != null) {
request.addParameter("NodeGroupCount", StringUtils.fromInteger(modifyReplicationGroupShardConfigurationRequest.getNodeGroupCount()));
}
if (modifyReplicationGroupShardConfigurationRequest.getApplyImmediately() != null) {
request.addParameter("ApplyImmediately", StringUtils.fromBoolean(modifyReplicationGroupShardConfigurationRequest.getApplyImmediately()));
}
if (!modifyReplicationGroupShardConfigurationRequest.getReshardingConfiguration().isEmpty()
|| !((com.amazonaws.internal.SdkInternalList) modifyReplicationGroupShardConfigurationRequest
.getReshardingConfiguration()).isAutoConstruct()) {
com.amazonaws.internal.SdkInternalList reshardingConfigurationList = (com.amazonaws.internal.SdkInternalList) modifyReplicationGroupShardConfigurationRequest
.getReshardingConfiguration();
int reshardingConfigurationListIndex = 1;
for (ReshardingConfiguration reshardingConfigurationListValue : reshardingConfigurationList) {
if (reshardingConfigurationListValue.getNodeGroupId() != null) {
request.addParameter("ReshardingConfiguration.ReshardingConfiguration." + reshardingConfigurationListIndex + ".NodeGroupId",
StringUtils.fromString(reshardingConfigurationListValue.getNodeGroupId()));
}
if (!reshardingConfigurationListValue.getPreferredAvailabilityZones().isEmpty()
|| !((com.amazonaws.internal.SdkInternalList) reshardingConfigurationListValue.getPreferredAvailabilityZones())
.isAutoConstruct()) {
com.amazonaws.internal.SdkInternalList preferredAvailabilityZonesList = (com.amazonaws.internal.SdkInternalList) reshardingConfigurationListValue
.getPreferredAvailabilityZones();
int preferredAvailabilityZonesListIndex = 1;
for (String preferredAvailabilityZonesListValue : preferredAvailabilityZonesList) {
if (preferredAvailabilityZonesListValue != null) {
request.addParameter("ReshardingConfiguration.ReshardingConfiguration." + reshardingConfigurationListIndex
+ ".PreferredAvailabilityZones.AvailabilityZone." + preferredAvailabilityZonesListIndex,
StringUtils.fromString(preferredAvailabilityZonesListValue));
}
preferredAvailabilityZonesListIndex++;
}
}
reshardingConfigurationListIndex++;
}
}
if (!modifyReplicationGroupShardConfigurationRequest.getNodeGroupsToRemove().isEmpty()
|| !((com.amazonaws.internal.SdkInternalList) modifyReplicationGroupShardConfigurationRequest.getNodeGroupsToRemove())
.isAutoConstruct()) {
com.amazonaws.internal.SdkInternalList nodeGroupsToRemoveList = (com.amazonaws.internal.SdkInternalList) modifyReplicationGroupShardConfigurationRequest
.getNodeGroupsToRemove();
int nodeGroupsToRemoveListIndex = 1;
for (String nodeGroupsToRemoveListValue : nodeGroupsToRemoveList) {
if (nodeGroupsToRemoveListValue != null) {
request.addParameter("NodeGroupsToRemove.NodeGroupToRemove." + nodeGroupsToRemoveListIndex,
StringUtils.fromString(nodeGroupsToRemoveListValue));
}
nodeGroupsToRemoveListIndex++;
}
}
if (!modifyReplicationGroupShardConfigurationRequest.getNodeGroupsToRetain().isEmpty()
|| !((com.amazonaws.internal.SdkInternalList) modifyReplicationGroupShardConfigurationRequest.getNodeGroupsToRetain())
.isAutoConstruct()) {
com.amazonaws.internal.SdkInternalList nodeGroupsToRetainList = (com.amazonaws.internal.SdkInternalList) modifyReplicationGroupShardConfigurationRequest
.getNodeGroupsToRetain();
int nodeGroupsToRetainListIndex = 1;
for (String nodeGroupsToRetainListValue : nodeGroupsToRetainList) {
if (nodeGroupsToRetainListValue != null) {
request.addParameter("NodeGroupsToRetain.NodeGroupToRetain." + nodeGroupsToRetainListIndex,
StringUtils.fromString(nodeGroupsToRetainListValue));
}
nodeGroupsToRetainListIndex++;
}
}
return request;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy