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

software.amazon.awssdk.services.swf.model.DecisionTaskCompletedEventAttributes Maven / Gradle / Ivy

/*
 * 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.swf.model;

import java.io.Serializable;
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;

/**
 * 

* Provides the details of the DecisionTaskCompleted event. *

*/ @Generated("software.amazon.awssdk:codegen") public final class DecisionTaskCompletedEventAttributes implements SdkPojo, Serializable, ToCopyableBuilder { private static final SdkField EXECUTION_CONTEXT_FIELD = SdkField. builder(MarshallingType.STRING) .getter(getter(DecisionTaskCompletedEventAttributes::executionContext)).setter(setter(Builder::executionContext)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("executionContext").build()).build(); private static final SdkField SCHEDULED_EVENT_ID_FIELD = SdkField. builder(MarshallingType.LONG) .getter(getter(DecisionTaskCompletedEventAttributes::scheduledEventId)).setter(setter(Builder::scheduledEventId)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("scheduledEventId").build()).build(); private static final SdkField STARTED_EVENT_ID_FIELD = SdkField. builder(MarshallingType.LONG) .getter(getter(DecisionTaskCompletedEventAttributes::startedEventId)).setter(setter(Builder::startedEventId)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("startedEventId").build()).build(); private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(EXECUTION_CONTEXT_FIELD, SCHEDULED_EVENT_ID_FIELD, STARTED_EVENT_ID_FIELD)); private static final long serialVersionUID = 1L; private final String executionContext; private final Long scheduledEventId; private final Long startedEventId; private DecisionTaskCompletedEventAttributes(BuilderImpl builder) { this.executionContext = builder.executionContext; this.scheduledEventId = builder.scheduledEventId; this.startedEventId = builder.startedEventId; } /** *

* User defined context for the workflow execution. *

* * @return User defined context for the workflow execution. */ public String executionContext() { return executionContext; } /** *

* The ID of the DecisionTaskScheduled event that was recorded when this decision task was scheduled. * This information can be useful for diagnosing problems by tracing back the chain of events leading up to this * event. *

* * @return The ID of the DecisionTaskScheduled event that was recorded when this decision task was * scheduled. This information can be useful for diagnosing problems by tracing back the chain of events * leading up to this event. */ public Long scheduledEventId() { return scheduledEventId; } /** *

* The ID of the DecisionTaskStarted event recorded when this decision task was started. This * information can be useful for diagnosing problems by tracing back the chain of events leading up to this event. *

* * @return The ID of the DecisionTaskStarted event recorded when this decision task was started. This * information can be useful for diagnosing problems by tracing back the chain of events leading up to this * event. */ public Long startedEventId() { return startedEventId; } @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(executionContext()); hashCode = 31 * hashCode + Objects.hashCode(scheduledEventId()); hashCode = 31 * hashCode + Objects.hashCode(startedEventId()); return hashCode; } @Override public boolean equals(Object obj) { return equalsBySdkFields(obj); } @Override public boolean equalsBySdkFields(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (!(obj instanceof DecisionTaskCompletedEventAttributes)) { return false; } DecisionTaskCompletedEventAttributes other = (DecisionTaskCompletedEventAttributes) obj; return Objects.equals(executionContext(), other.executionContext()) && Objects.equals(scheduledEventId(), other.scheduledEventId()) && Objects.equals(startedEventId(), other.startedEventId()); } /** * 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("DecisionTaskCompletedEventAttributes").add("ExecutionContext", executionContext()) .add("ScheduledEventId", scheduledEventId()).add("StartedEventId", startedEventId()).build(); } public Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "executionContext": return Optional.ofNullable(clazz.cast(executionContext())); case "scheduledEventId": return Optional.ofNullable(clazz.cast(scheduledEventId())); case "startedEventId": return Optional.ofNullable(clazz.cast(startedEventId())); default: return Optional.empty(); } } @Override public List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((DecisionTaskCompletedEventAttributes) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends SdkPojo, CopyableBuilder { /** *

* User defined context for the workflow execution. *

* * @param executionContext * User defined context for the workflow execution. * @return Returns a reference to this object so that method calls can be chained together. */ Builder executionContext(String executionContext); /** *

* The ID of the DecisionTaskScheduled event that was recorded when this decision task was * scheduled. This information can be useful for diagnosing problems by tracing back the chain of events leading * up to this event. *

* * @param scheduledEventId * The ID of the DecisionTaskScheduled event that was recorded when this decision task was * scheduled. This information can be useful for diagnosing problems by tracing back the chain of events * leading up to this event. * @return Returns a reference to this object so that method calls can be chained together. */ Builder scheduledEventId(Long scheduledEventId); /** *

* The ID of the DecisionTaskStarted event recorded when this decision task was started. This * information can be useful for diagnosing problems by tracing back the chain of events leading up to this * event. *

* * @param startedEventId * The ID of the DecisionTaskStarted event recorded when this decision task was started. * This information can be useful for diagnosing problems by tracing back the chain of events leading up * to this event. * @return Returns a reference to this object so that method calls can be chained together. */ Builder startedEventId(Long startedEventId); } static final class BuilderImpl implements Builder { private String executionContext; private Long scheduledEventId; private Long startedEventId; private BuilderImpl() { } private BuilderImpl(DecisionTaskCompletedEventAttributes model) { executionContext(model.executionContext); scheduledEventId(model.scheduledEventId); startedEventId(model.startedEventId); } public final String getExecutionContext() { return executionContext; } @Override public final Builder executionContext(String executionContext) { this.executionContext = executionContext; return this; } public final void setExecutionContext(String executionContext) { this.executionContext = executionContext; } public final Long getScheduledEventId() { return scheduledEventId; } @Override public final Builder scheduledEventId(Long scheduledEventId) { this.scheduledEventId = scheduledEventId; return this; } public final void setScheduledEventId(Long scheduledEventId) { this.scheduledEventId = scheduledEventId; } public final Long getStartedEventId() { return startedEventId; } @Override public final Builder startedEventId(Long startedEventId) { this.startedEventId = startedEventId; return this; } public final void setStartedEventId(Long startedEventId) { this.startedEventId = startedEventId; } @Override public DecisionTaskCompletedEventAttributes build() { return new DecisionTaskCompletedEventAttributes(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy