software.amazon.awssdk.services.lexruntime.endpoints.internal.Partitions Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of lexruntime Show documentation
Show all versions of lexruntime Show documentation
The AWS Java SDK for Amazon Lex Runtime module holds the client classes that are used for
communicating with Amazon Lex Runtime Service
/*
* Copyright 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.lexruntime.endpoints.internal;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import software.amazon.awssdk.annotations.SdkInternalApi;
import software.amazon.awssdk.protocols.jsoncore.JsonNode;
@SdkInternalApi
public final class Partitions {
private static final String VERSION = "version";
private static final String PARTITIONS = "partitions";
private final String version;
private final List partitions;
private Partitions(Builder builder) {
this.version = builder.version;
this.partitions = new ArrayList<>(builder.partitions);
}
public String version() {
return version;
}
public List partitions() {
return partitions;
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
Partitions that = (Partitions) o;
if (version != null ? !version.equals(that.version) : that.version != null) {
return false;
}
return partitions != null ? partitions.equals(that.partitions) : that.partitions == null;
}
@Override
public int hashCode() {
int result = version != null ? version.hashCode() : 0;
result = 31 * result + (partitions != null ? partitions.hashCode() : 0);
return result;
}
@Override
public String toString() {
return "Partitions{" + "version='" + version + '\'' + ", partitions=" + partitions + '}';
}
public static Partitions fromNode(JsonNode node) {
Map objNode = node.asObject();
Builder b = builder();
JsonNode version = objNode.get(VERSION);
if (version != null) {
b.version(version.asString());
}
JsonNode partitions = objNode.get(PARTITIONS);
if (partitions != null) {
partitions.asArray().forEach(partNode -> b.addPartition(Partition.fromNode(partNode)));
}
return b.build();
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private String version;
private List partitions = new ArrayList<>();
public Builder version(String version) {
this.version = version;
return this;
}
public Builder partitions(List partitions) {
this.partitions.clear();
if (partitions != null) {
this.partitions.addAll(partitions);
}
return this;
}
public Builder addPartition(Partition p) {
this.partitions.add(p);
return this;
}
public Partitions build() {
return new Partitions(this);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy