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

software.amazon.awssdk.core.Response 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.core;

import software.amazon.awssdk.annotations.SdkProtectedApi;
import software.amazon.awssdk.core.exception.SdkException;
import software.amazon.awssdk.http.SdkHttpFullResponse;

/**
 * Response wrapper that indicates success or failure with the associated unmarshalled response object or exception
 * object. This object is used by the core request/response pipeline to pass response metadata alongside the actual
 * deserialized response object through different stages of the pipeline.
 *
 * @param  the modelled SDK response type.
 */
@SdkProtectedApi
public final class Response {
    private final Boolean isSuccess;
    private final T response;
    private final SdkException exception;
    private final SdkHttpFullResponse httpResponse;

    private Response(Builder builder) {
        this.isSuccess = builder.isSuccess;
        this.response = builder.response;
        this.exception = builder.exception;
        this.httpResponse = builder.httpResponse;
    }

    /**
     * Returns a newly initialized builder object for a {@link Response}
     * @param  Modelled response type.
     */
    public static  Builder builder() {
        return new Builder<>();
    }

    /**
     * Creates a new builder with initial values pulled from the current object.
     */
    public Builder toBuilder() {
        return new Builder().isSuccess(this.isSuccess)
                               .response(this.response)
                               .exception(this.exception)
                               .httpResponse(this.httpResponse);
    }

    /**
     * The modelled response object returned by the service. If the response was a failure, this value is likely to
     * be null.
     */
    public T response() {
        return response;
    }

    /**
     * The modelled exception returned by the service. If the response was not a failure, this value is likely to
     * be null.
     */
    public SdkException exception() {
        return exception;
    }

    /**
     * The HTTP response that was received by the SDK prior to determining the result.
     */
    public SdkHttpFullResponse httpResponse() {
        return httpResponse;
    }

    /**
     * Indicates whether the result indicates success or failure of the original request. A true value indicates
     * success; a false value indicates failure.
     */
    public Boolean isSuccess() {
        return isSuccess;
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) {
            return true;
        }
        if (o == null || getClass() != o.getClass()) {
            return false;
        }

        Response response1 = (Response) o;

        if (isSuccess != null ? ! isSuccess.equals(response1.isSuccess) : response1.isSuccess != null) {
            return false;
        }
        if (response != null ? ! response.equals(response1.response) : response1.response != null) {
            return false;
        }
        if (exception != null ? ! exception.equals(response1.exception) : response1.exception != null) {
            return false;
        }
        return httpResponse != null ? httpResponse.equals(response1.httpResponse) : response1.httpResponse == null;
    }

    @Override
    public int hashCode() {
        int result = isSuccess != null ? isSuccess.hashCode() : 0;
        result = 31 * result + (response != null ? response.hashCode() : 0);
        result = 31 * result + (exception != null ? exception.hashCode() : 0);
        result = 31 * result + (httpResponse != null ? httpResponse.hashCode() : 0);
        return result;
    }

    public static final class Builder {
        private Boolean isSuccess;
        private T response;
        private SdkException exception;
        private SdkHttpFullResponse httpResponse;

        private Builder() {
        }

        /**
         * Indicates whether the result indicates success or failure of the original request. A true value indicates
         * success; a false value indicates failure.
         */
        public Builder isSuccess(Boolean success) {
            isSuccess = success;
            return this;
        }

        /**
         * The modelled response object returned by the service. If the response was a failure, this value is likely to
         * be null.
         */
        public Builder response(T response) {
            this.response = response;
            return this;
        }

        /**
         * The modelled exception returned by the service. If the response was not a failure, this value is likely to
         * be null.
         */
        public Builder exception(SdkException exception) {
            this.exception = exception;
            return this;
        }

        /**
         * The HTTP response that was received by the SDK prior to determining the result.
         */
        public Builder httpResponse(SdkHttpFullResponse httpResponse) {
            this.httpResponse = httpResponse;
            return this;
        }

        /**
         * Builds a {@link Response} object based on the values held by this builder.
         */
        public Response build() {
            return new Response<>(this);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy