software.amazon.awssdk.services.applicationdiscovery.model.StartDataCollectionByAgentIdsRequest Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of applicationdiscovery Show documentation
Show all versions of applicationdiscovery Show documentation
The AWS Java SDK for AWS Application Discovery Service module holds the client classes that are used
for communicating with AWS Application Discovery 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 software.amazon.awssdk.services.applicationdiscovery.model;
import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.function.BiConsumer;
import java.util.function.Consumer;
import java.util.function.Function;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.awscore.AwsRequestOverrideConfiguration;
import software.amazon.awssdk.core.SdkField;
import software.amazon.awssdk.core.SdkPojo;
import software.amazon.awssdk.core.protocol.MarshallLocation;
import software.amazon.awssdk.core.protocol.MarshallingType;
import software.amazon.awssdk.core.traits.ListTrait;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.core.util.DefaultSdkAutoConstructList;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;
/**
*/
@Generated("software.amazon.awssdk:codegen")
public final class StartDataCollectionByAgentIdsRequest extends ApplicationDiscoveryRequest implements
ToCopyableBuilder {
private static final SdkField> AGENT_IDS_FIELD = SdkField
.> builder(MarshallingType.LIST)
.getter(getter(StartDataCollectionByAgentIdsRequest::agentIds))
.setter(setter(Builder::agentIds))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("agentIds").build(),
ListTrait
.builder()
.memberLocationName(null)
.memberFieldInfo(
SdkField. builder(MarshallingType.STRING)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD)
.locationName("member").build()).build()).build()).build();
private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(AGENT_IDS_FIELD));
private final List agentIds;
private StartDataCollectionByAgentIdsRequest(BuilderImpl builder) {
super(builder);
this.agentIds = builder.agentIds;
}
/**
*
* The IDs of the agents or connectors from which to start collecting data. If you send a request to an
* agent/connector ID that you do not have permission to contact, according to your AWS account, the service does
* not throw an exception. Instead, it returns the error in the Description field. If you send a request to
* multiple agents/connectors and you do not have permission to contact some of those agents/connectors, the system
* does not throw an exception. Instead, the system shows Failed
in the Description field.
*
*
* Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
*
*
* @return The IDs of the agents or connectors from which to start collecting data. If you send a request to an
* agent/connector ID that you do not have permission to contact, according to your AWS account, the service
* does not throw an exception. Instead, it returns the error in the Description field. If you send a
* request to multiple agents/connectors and you do not have permission to contact some of those
* agents/connectors, the system does not throw an exception. Instead, the system shows Failed
* in the Description field.
*/
public List agentIds() {
return agentIds;
}
@Override
public Builder toBuilder() {
return new BuilderImpl(this);
}
public static Builder builder() {
return new BuilderImpl();
}
public static Class serializableBuilderClass() {
return BuilderImpl.class;
}
@Override
public int hashCode() {
int hashCode = 1;
hashCode = 31 * hashCode + super.hashCode();
hashCode = 31 * hashCode + Objects.hashCode(agentIds());
return hashCode;
}
@Override
public boolean equals(Object obj) {
return super.equals(obj) && equalsBySdkFields(obj);
}
@Override
public boolean equalsBySdkFields(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (!(obj instanceof StartDataCollectionByAgentIdsRequest)) {
return false;
}
StartDataCollectionByAgentIdsRequest other = (StartDataCollectionByAgentIdsRequest) obj;
return Objects.equals(agentIds(), other.agentIds());
}
/**
* Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be
* redacted from this string using a placeholder value.
*/
@Override
public String toString() {
return ToString.builder("StartDataCollectionByAgentIdsRequest").add("AgentIds", agentIds()).build();
}
public Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "agentIds":
return Optional.ofNullable(clazz.cast(agentIds()));
default:
return Optional.empty();
}
}
@Override
public List> sdkFields() {
return SDK_FIELDS;
}
private static Function