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

com.authlete.common.api.AuthleteApiException Maven / Gradle / Ivy

/*
 * Copyright (C) 2014-2015 Authlete, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License 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 com.authlete.common.api;


import java.util.List;
import java.util.Map;


/**
 * Authlete API exception.
 *
 * @author Takahiko Kawasaki
 */
public class AuthleteApiException extends RuntimeException
{
    private static final long serialVersionUID = 1L;


    /**
     * HTTP status code. May be 0.
     */
    private int mStatusCode;


    /**
     * HTTP status message. May be {@code null}.
     */
    private String mStatusMessage;


    /**
     * HTTP response body. May be {@code null}.
     */
    private String mResponseBody;


    /**
     * HTTP response headers. May be {@code null}.
     */
    private Map> mResponseHeaders;


    /**
     * Constructor.
     */
    public AuthleteApiException()
    {
    }


    /**
     * Constructor with HTTP response information.
     *
     * @param statusCode
     *         HTTP status code.
     *
     * @param statusMessage
     *         HTTP status message.
     *
     * @param responseBody
     *         HTTP response body.
     */
    public AuthleteApiException(int statusCode, String statusMessage, String responseBody)
    {
        setResponse(statusCode, statusMessage, responseBody, null);
    }


    /**
     * Constructor with an error message.
     *
     * @param message
     *         Error message.
     */
    public AuthleteApiException(String message)
    {
        super(message);
    }


    /**
     * Constructor with an error message and HTTP response information.
     *
     * @param message
     *         Error message.
     *
     * @param statusCode
     *         HTTP status code.
     *
     * @param statusMessage
     *         HTTP status message.
     *
     * @param responseBody
     *         HTTP response body.
     */
    public AuthleteApiException(String message, int statusCode, String statusMessage, String responseBody)
    {
        super(message);

        setResponse(statusCode, statusMessage, responseBody, null);
    }


    /**
     * Constructor with an error message and HTTP response information.
     *
     * @param message
     *         Error message.
     *
     * @param statusCode
     *         HTTP status code.
     *
     * @param statusMessage
     *         HTTP status message.
     *
     * @param responseBody
     *         HTTP response body.
     *
     * @param responseHeaders
     *         Http response headers.
     *
     * @since 1.13
     */
    public AuthleteApiException(String message, int statusCode, String statusMessage, String responseBody, Map> responseHeaders)
    {
        super(message);

        setResponse(statusCode, statusMessage, responseBody, responseHeaders);
    }


    /**
     * Constructor with the cause.
     *
     * @param cause
     *         The cause of this exception.
     */
    public AuthleteApiException(Throwable cause)
    {
        super(cause);
    }


    /**
     * Constructor with the cause and HTTP response information.
     *
     * @param cause
     *         The cause of this exception.
     *
     * @param statusCode
     *         HTTP status code.
     *
     * @param statusMessage
     *         HTTP status message.
     *
     * @param responseBody
     *         HTTP response body.
     */
    public AuthleteApiException(Throwable cause, int statusCode, String statusMessage, String responseBody)
    {
        super(cause);

        setResponse(statusCode, statusMessage, responseBody, null);
    }


    /**
     * Constructor with the cause and HTTP response information.
     *
     * @param cause
     *         The cause of this exception.
     *
     * @param statusCode
     *         HTTP status code.
     *
     * @param statusMessage
     *         HTTP status message.
     *
     * @param responseBody
     *         HTTP response body.
     *
     * @param responseHeaders
     *         HTTP response headers.
     *
     * @since 1.13
     */
    public AuthleteApiException(Throwable cause, int statusCode, String statusMessage, String responseBody, Map> responseHeaders)
    {
        super(cause);

        setResponse(statusCode, statusMessage, responseBody, responseHeaders);
    }


    /**
     * Constructor with an error message and the cause.
     *
     * @param message
     *         Error message.
     *
     * @param cause
     *         The cause of this exception.
     */
    public AuthleteApiException(String message, Throwable cause)
    {
        super(message, cause);
    }


    /**
     * Constructor with an error message, the cause and HTTP response information.
     *
     * @param message
     *         Error message.
     *
     * @param cause
     *         The cause of this exception.
     *
     * @param statusCode
     *         HTTP status code.
     *
     * @param statusMessage
     *         HTTP status message.
     *
     * @param responseBody
     *         HTTP response body.
     */
    public AuthleteApiException(String message, Throwable cause, int statusCode, String statusMessage, String responseBody)
    {
        super(message, cause);

        setResponse(statusCode, statusMessage, responseBody, null);
    }


    /**
     * Constructor with an error message, the cause and HTTP response information.
     *
     * @param message
     *         Error message.
     *
     * @param cause
     *         The cause of this exception.
     *
     * @param statusCode
     *         HTTP status code.
     *
     * @param statusMessage
     *         HTTP status message.
     *
     * @param responseBody
     *         HTTP response body.
     *
     * @param responseHeaders
     *         HTTP response headers.
     *
     * @since 1.13
     */
    public AuthleteApiException(String message, Throwable cause, int statusCode, String statusMessage, String responseBody, Map> responseHeaders)
    {
        super(message, cause);

        setResponse(statusCode, statusMessage, responseBody, responseHeaders);
    }


    /**
     * Set the data fields related to HTTP response information.
     *
     * @param statusCode
     *         HTTP status code.
     *
     * @param statusMessage
     *         HTTP status message.
     *
     * @param responseBody
     *         HTTP response body.
     */
    private void setResponse(int statusCode, String statusMessage, String responseBody, Map> responseHeaders)
    {
        mStatusCode      = statusCode;
        mStatusMessage   = statusMessage;
        mResponseBody    = responseBody;
        mResponseHeaders = responseHeaders;
    }


    /**
     * Get the HTTP status code contained in the response from Authlete server.
     *
     * 

* Note that this method may return 0 if this exception was raised * before the response from Authlete server was obtained. *

* * @return * HTTP status code. */ public int getStatusCode() { return mStatusCode; } /** * Get the HTTP status message contained in the response from Authlete server. * *

* Note that this method may return {@code null} if this exception was raised * before the response from Authlete server was obtained. *

* * @return * HTTP status message. */ public String getStatusMessage() { return mStatusMessage; } /** * Get the response body contained in the response from Authlete server. * *

* Note that this method may return {@code null} if this exception was raised * before the response from Authlete server was obtained or if the response * did not contain any content. *

* * @return * HTTP response body. */ public String getResponseBody() { return mResponseBody; } /** * Get the response headers contained in the response from Authlete server. * *

* Note that this method may return {@code null} if this exception was raised * before the response from Authlete server was obtained. *

* * @return * HTTP response headers. * * @since 1.13 */ public Map> getResponseHeaders() { return mResponseHeaders; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy