software.amazon.awssdk.services.health.model.DateTimeRange Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of health Show documentation
Show all versions of health Show documentation
The AWS Java SDK for AWS Health APIs and Notifications module holds the client classes that are used
for communicating with AWS Health APIs and Notifications 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.health.model;
import java.io.Serializable;
import java.time.Instant;
import java.util.Arrays;
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.Function;
import software.amazon.awssdk.annotations.Generated;
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.LocationTrait;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;
/**
*
* A range of dates and times that is used by the EventFilter and EntityFilter objects. If
* from
is set and to
is set: match items where the timestamp (startTime
,
* endTime
, or lastUpdatedTime
) is between from
and to
inclusive. If
* from
is set and to
is not set: match items where the timestamp value is equal to or after
* from
. If from
is not set and to
is set: match items where the timestamp value
* is equal to or before to
.
*
*/
@Generated("software.amazon.awssdk:codegen")
public final class DateTimeRange implements SdkPojo, Serializable, ToCopyableBuilder {
private static final SdkField FROM_FIELD = SdkField. builder(MarshallingType.INSTANT).memberName("from")
.getter(getter(DateTimeRange::from)).setter(setter(Builder::from))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("from").build()).build();
private static final SdkField TO_FIELD = SdkField. builder(MarshallingType.INSTANT).memberName("to")
.getter(getter(DateTimeRange::to)).setter(setter(Builder::to))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("to").build()).build();
private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(FROM_FIELD, TO_FIELD));
private static final long serialVersionUID = 1L;
private final Instant from;
private final Instant to;
private DateTimeRange(BuilderImpl builder) {
this.from = builder.from;
this.to = builder.to;
}
/**
*
* The starting date and time of a time range.
*
*
* @return The starting date and time of a time range.
*/
public final Instant from() {
return from;
}
/**
*
* The ending date and time of a time range.
*
*
* @return The ending date and time of a time range.
*/
public final Instant to() {
return to;
}
@Override
public Builder toBuilder() {
return new BuilderImpl(this);
}
public static Builder builder() {
return new BuilderImpl();
}
public static Class extends Builder> serializableBuilderClass() {
return BuilderImpl.class;
}
@Override
public final int hashCode() {
int hashCode = 1;
hashCode = 31 * hashCode + Objects.hashCode(from());
hashCode = 31 * hashCode + Objects.hashCode(to());
return hashCode;
}
@Override
public final boolean equals(Object obj) {
return equalsBySdkFields(obj);
}
@Override
public final boolean equalsBySdkFields(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (!(obj instanceof DateTimeRange)) {
return false;
}
DateTimeRange other = (DateTimeRange) obj;
return Objects.equals(from(), other.from()) && Objects.equals(to(), other.to());
}
/**
* 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 final String toString() {
return ToString.builder("DateTimeRange").add("From", from()).add("To", to()).build();
}
public final Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "from":
return Optional.ofNullable(clazz.cast(from()));
case "to":
return Optional.ofNullable(clazz.cast(to()));
default:
return Optional.empty();
}
}
@Override
public final List> sdkFields() {
return SDK_FIELDS;
}
private static Function