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

software.amazon.awssdk.services.s3control.model.UpdateJobStatusResponse Maven / Gradle / Ivy

Go to download

The AWS Java SDK for Amazon S3 Control module holds the client classes that are used for communicating with Amazon Simple Storage Service Control Plane

There is a newer version: 2.29.39
Show newest version
/*
 * 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.s3control.model;

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;

/**
 */
@Generated("software.amazon.awssdk:codegen")
public final class UpdateJobStatusResponse extends S3ControlResponse implements
        ToCopyableBuilder {
    private static final SdkField JOB_ID_FIELD = SdkField
            . builder(MarshallingType.STRING)
            .memberName("JobId")
            .getter(getter(UpdateJobStatusResponse::jobId))
            .setter(setter(Builder::jobId))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("JobId")
                    .unmarshallLocationName("JobId").build()).build();

    private static final SdkField STATUS_FIELD = SdkField
            . builder(MarshallingType.STRING)
            .memberName("Status")
            .getter(getter(UpdateJobStatusResponse::statusAsString))
            .setter(setter(Builder::status))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Status")
                    .unmarshallLocationName("Status").build()).build();

    private static final SdkField STATUS_UPDATE_REASON_FIELD = SdkField
            . builder(MarshallingType.STRING)
            .memberName("StatusUpdateReason")
            .getter(getter(UpdateJobStatusResponse::statusUpdateReason))
            .setter(setter(Builder::statusUpdateReason))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("StatusUpdateReason")
                    .unmarshallLocationName("StatusUpdateReason").build()).build();

    private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(JOB_ID_FIELD, STATUS_FIELD,
            STATUS_UPDATE_REASON_FIELD));

    private final String jobId;

    private final String status;

    private final String statusUpdateReason;

    private UpdateJobStatusResponse(BuilderImpl builder) {
        super(builder);
        this.jobId = builder.jobId;
        this.status = builder.status;
        this.statusUpdateReason = builder.statusUpdateReason;
    }

    /**
     * 

* The ID for the job whose status was updated. *

* * @return The ID for the job whose status was updated. */ public final String jobId() { return jobId; } /** *

* The current status for the specified job. *

*

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

* * @return The current status for the specified job. * @see JobStatus */ public final JobStatus status() { return JobStatus.fromValue(status); } /** *

* The current status for the specified job. *

*

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

* * @return The current status for the specified job. * @see JobStatus */ public final String statusAsString() { return status; } /** *

* The reason that the specified job's status was updated. *

* * @return The reason that the specified job's status was updated. */ public final String statusUpdateReason() { return statusUpdateReason; } @Override public Builder toBuilder() { return new BuilderImpl(this); } public static Builder builder() { return new BuilderImpl(); } public static Class serializableBuilderClass() { return BuilderImpl.class; } @Override public final int hashCode() { int hashCode = 1; hashCode = 31 * hashCode + super.hashCode(); hashCode = 31 * hashCode + Objects.hashCode(jobId()); hashCode = 31 * hashCode + Objects.hashCode(statusAsString()); hashCode = 31 * hashCode + Objects.hashCode(statusUpdateReason()); return hashCode; } @Override public final boolean equals(Object obj) { return super.equals(obj) && equalsBySdkFields(obj); } @Override public final boolean equalsBySdkFields(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (!(obj instanceof UpdateJobStatusResponse)) { return false; } UpdateJobStatusResponse other = (UpdateJobStatusResponse) obj; return Objects.equals(jobId(), other.jobId()) && Objects.equals(statusAsString(), other.statusAsString()) && Objects.equals(statusUpdateReason(), other.statusUpdateReason()); } /** * 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("UpdateJobStatusResponse").add("JobId", jobId()).add("Status", statusAsString()) .add("StatusUpdateReason", statusUpdateReason()).build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "JobId": return Optional.ofNullable(clazz.cast(jobId())); case "Status": return Optional.ofNullable(clazz.cast(statusAsString())); case "StatusUpdateReason": return Optional.ofNullable(clazz.cast(statusUpdateReason())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((UpdateJobStatusResponse) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends S3ControlResponse.Builder, SdkPojo, CopyableBuilder { /** *

* The ID for the job whose status was updated. *

* * @param jobId * The ID for the job whose status was updated. * @return Returns a reference to this object so that method calls can be chained together. */ Builder jobId(String jobId); /** *

* The current status for the specified job. *

* * @param status * The current status for the specified job. * @see JobStatus * @return Returns a reference to this object so that method calls can be chained together. * @see JobStatus */ Builder status(String status); /** *

* The current status for the specified job. *

* * @param status * The current status for the specified job. * @see JobStatus * @return Returns a reference to this object so that method calls can be chained together. * @see JobStatus */ Builder status(JobStatus status); /** *

* The reason that the specified job's status was updated. *

* * @param statusUpdateReason * The reason that the specified job's status was updated. * @return Returns a reference to this object so that method calls can be chained together. */ Builder statusUpdateReason(String statusUpdateReason); } static final class BuilderImpl extends S3ControlResponse.BuilderImpl implements Builder { private String jobId; private String status; private String statusUpdateReason; private BuilderImpl() { } private BuilderImpl(UpdateJobStatusResponse model) { super(model); jobId(model.jobId); status(model.status); statusUpdateReason(model.statusUpdateReason); } public final String getJobId() { return jobId; } @Override public final Builder jobId(String jobId) { this.jobId = jobId; return this; } public final void setJobId(String jobId) { this.jobId = jobId; } public final String getStatus() { return status; } @Override public final Builder status(String status) { this.status = status; return this; } @Override public final Builder status(JobStatus status) { this.status(status == null ? null : status.toString()); return this; } public final void setStatus(String status) { this.status = status; } public final String getStatusUpdateReason() { return statusUpdateReason; } @Override public final Builder statusUpdateReason(String statusUpdateReason) { this.statusUpdateReason = statusUpdateReason; return this; } public final void setStatusUpdateReason(String statusUpdateReason) { this.statusUpdateReason = statusUpdateReason; } @Override public UpdateJobStatusResponse build() { return new UpdateJobStatusResponse(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy