All Downloads are FREE. Search and download functionalities are using the official Maven repository.

software.amazon.awssdk.services.databasemigration.model.Event Maven / Gradle / Ivy

Go to download

The AWS Java SDK for AWS Database Migration Service module holds the client classes that are used for communicating with AWS Database Migration Service.

The newest version!
/*
 * Copyright 2013-2018 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.databasemigration.model;

import java.time.Instant;
import java.util.Arrays;
import java.util.Collection;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.annotations.SdkInternalApi;
import software.amazon.awssdk.core.protocol.ProtocolMarshaller;
import software.amazon.awssdk.core.protocol.StructuredPojo;
import software.amazon.awssdk.core.util.DefaultSdkAutoConstructList;
import software.amazon.awssdk.services.databasemigration.transform.EventMarshaller;
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 Event implements StructuredPojo, ToCopyableBuilder { private final String sourceIdentifier; private final String sourceType; private final String message; private final List eventCategories; private final Instant date; private Event(BuilderImpl builder) { this.sourceIdentifier = builder.sourceIdentifier; this.sourceType = builder.sourceType; this.message = builder.message; this.eventCategories = builder.eventCategories; this.date = builder.date; } /** *

* The identifier of the event source. An identifier must begin with a letter and must contain only ASCII letters, * digits, and hyphens; it cannot end with a hyphen or contain two consecutive hyphens. *

*

* Constraints:replication instance, endpoint, migration task *

* * @return The identifier of the event source. An identifier must begin with a letter and must contain only ASCII * letters, digits, and hyphens; it cannot end with a hyphen or contain two consecutive hyphens.

*

* Constraints:replication instance, endpoint, migration task */ public String sourceIdentifier() { return sourceIdentifier; } /** *

* The type of AWS DMS resource that generates events. *

*

* Valid values: replication-instance | endpoint | migration-task *

*

* If the service returns an enum value that is not available in the current SDK version, {@link #sourceType} will * return {@link SourceType#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from * {@link #sourceTypeAsString}. *

* * @return The type of AWS DMS resource that generates events.

*

* Valid values: replication-instance | endpoint | migration-task * @see SourceType */ public SourceType sourceType() { return SourceType.fromValue(sourceType); } /** *

* The type of AWS DMS resource that generates events. *

*

* Valid values: replication-instance | endpoint | migration-task *

*

* If the service returns an enum value that is not available in the current SDK version, {@link #sourceType} will * return {@link SourceType#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from * {@link #sourceTypeAsString}. *

* * @return The type of AWS DMS resource that generates events.

*

* Valid values: replication-instance | endpoint | migration-task * @see SourceType */ public String sourceTypeAsString() { return sourceType; } /** *

* The event message. *

* * @return The event message. */ public String message() { return message; } /** *

* The event categories available for the specified source type. *

*

* Attempts to modify the collection returned by this method will result in an UnsupportedOperationException. *

* * @return The event categories available for the specified source type. */ public List eventCategories() { return eventCategories; } /** *

* The date of the event. *

* * @return The date of the event. */ public Instant date() { return date; } @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 + Objects.hashCode(sourceIdentifier()); hashCode = 31 * hashCode + Objects.hashCode(sourceTypeAsString()); hashCode = 31 * hashCode + Objects.hashCode(message()); hashCode = 31 * hashCode + Objects.hashCode(eventCategories()); hashCode = 31 * hashCode + Objects.hashCode(date()); return hashCode; } @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (!(obj instanceof Event)) { return false; } Event other = (Event) obj; return Objects.equals(sourceIdentifier(), other.sourceIdentifier()) && Objects.equals(sourceTypeAsString(), other.sourceTypeAsString()) && Objects.equals(message(), other.message()) && Objects.equals(eventCategories(), other.eventCategories()) && Objects.equals(date(), other.date()); } @Override public String toString() { return ToString.builder("Event").add("SourceIdentifier", sourceIdentifier()).add("SourceType", sourceTypeAsString()) .add("Message", message()).add("EventCategories", eventCategories()).add("Date", date()).build(); } public Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "SourceIdentifier": return Optional.ofNullable(clazz.cast(sourceIdentifier())); case "SourceType": return Optional.ofNullable(clazz.cast(sourceTypeAsString())); case "Message": return Optional.ofNullable(clazz.cast(message())); case "EventCategories": return Optional.ofNullable(clazz.cast(eventCategories())); case "Date": return Optional.ofNullable(clazz.cast(date())); default: return Optional.empty(); } } @SdkInternalApi @Override public void marshall(ProtocolMarshaller protocolMarshaller) { EventMarshaller.getInstance().marshall(this, protocolMarshaller); } public interface Builder extends CopyableBuilder { /** *

* The identifier of the event source. An identifier must begin with a letter and must contain only ASCII * letters, digits, and hyphens; it cannot end with a hyphen or contain two consecutive hyphens. *

*

* Constraints:replication instance, endpoint, migration task *

* * @param sourceIdentifier * The identifier of the event source. An identifier must begin with a letter and must contain only ASCII * letters, digits, and hyphens; it cannot end with a hyphen or contain two consecutive hyphens.

*

* Constraints:replication instance, endpoint, migration task * @return Returns a reference to this object so that method calls can be chained together. */ Builder sourceIdentifier(String sourceIdentifier); /** *

* The type of AWS DMS resource that generates events. *

*

* Valid values: replication-instance | endpoint | migration-task *

* * @param sourceType * The type of AWS DMS resource that generates events.

*

* Valid values: replication-instance | endpoint | migration-task * @see SourceType * @return Returns a reference to this object so that method calls can be chained together. * @see SourceType */ Builder sourceType(String sourceType); /** *

* The type of AWS DMS resource that generates events. *

*

* Valid values: replication-instance | endpoint | migration-task *

* * @param sourceType * The type of AWS DMS resource that generates events.

*

* Valid values: replication-instance | endpoint | migration-task * @see SourceType * @return Returns a reference to this object so that method calls can be chained together. * @see SourceType */ Builder sourceType(SourceType sourceType); /** *

* The event message. *

* * @param message * The event message. * @return Returns a reference to this object so that method calls can be chained together. */ Builder message(String message); /** *

* The event categories available for the specified source type. *

* * @param eventCategories * The event categories available for the specified source type. * @return Returns a reference to this object so that method calls can be chained together. */ Builder eventCategories(Collection eventCategories); /** *

* The event categories available for the specified source type. *

* * @param eventCategories * The event categories available for the specified source type. * @return Returns a reference to this object so that method calls can be chained together. */ Builder eventCategories(String... eventCategories); /** *

* The date of the event. *

* * @param date * The date of the event. * @return Returns a reference to this object so that method calls can be chained together. */ Builder date(Instant date); } static final class BuilderImpl implements Builder { private String sourceIdentifier; private String sourceType; private String message; private List eventCategories = DefaultSdkAutoConstructList.getInstance(); private Instant date; private BuilderImpl() { } private BuilderImpl(Event model) { sourceIdentifier(model.sourceIdentifier); sourceType(model.sourceType); message(model.message); eventCategories(model.eventCategories); date(model.date); } public final String getSourceIdentifier() { return sourceIdentifier; } @Override public final Builder sourceIdentifier(String sourceIdentifier) { this.sourceIdentifier = sourceIdentifier; return this; } public final void setSourceIdentifier(String sourceIdentifier) { this.sourceIdentifier = sourceIdentifier; } public final String getSourceType() { return sourceType; } @Override public final Builder sourceType(String sourceType) { this.sourceType = sourceType; return this; } @Override public final Builder sourceType(SourceType sourceType) { this.sourceType(sourceType.toString()); return this; } public final void setSourceType(String sourceType) { this.sourceType = sourceType; } public final String getMessage() { return message; } @Override public final Builder message(String message) { this.message = message; return this; } public final void setMessage(String message) { this.message = message; } public final Collection getEventCategories() { return eventCategories; } @Override public final Builder eventCategories(Collection eventCategories) { this.eventCategories = EventCategoriesListCopier.copy(eventCategories); return this; } @Override @SafeVarargs public final Builder eventCategories(String... eventCategories) { eventCategories(Arrays.asList(eventCategories)); return this; } public final void setEventCategories(Collection eventCategories) { this.eventCategories = EventCategoriesListCopier.copy(eventCategories); } public final Instant getDate() { return date; } @Override public final Builder date(Instant date) { this.date = date; return this; } public final void setDate(Instant date) { this.date = date; } @Override public Event build() { return new Event(this); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy