com.azure.storage.blob.models.BlobStorageException Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of azure-storage-blob Show documentation
Show all versions of azure-storage-blob Show documentation
This module contains client library for Microsoft Azure Blob Storage.
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
package com.azure.storage.blob.models;
import com.azure.core.exception.HttpResponseException;
import com.azure.core.http.HttpResponse;
import com.azure.storage.common.implementation.StorageImplUtils;
import static com.azure.storage.common.implementation.Constants.HeaderConstants.ERROR_CODE;
/**
* A {@code BlobStorageException} is thrown whenever Azure Storage successfully returns an error code that is not
* 200-level. Users can inspect the status code and error code to determine the cause of the error response. The
* exception message may also contain more detailed information depending on the type of error. The user may also
* inspect the raw HTTP response or call toString to get the full payload of the error response if present. Note that
* even some expected "errors" will be thrown as a {@code BlobStorageException}. For example, some users may perform a
* getProperties request on an entity to determine whether it exists or not. If it does not exists, an exception will be
* thrown even though this may be considered an expected indication of absence in this case.
*
* Sample Code
* For more samples, please see the sample
* file
*/
public final class BlobStorageException extends HttpResponseException {
/**
* Constructs a {@code BlobStorageException}.
*
* @param message the exception message or the response content if a message is not available.
* @param response the HTTP response.
* @param value the error code of the exception.
*/
public BlobStorageException(String message, HttpResponse response, Object value) {
super(StorageImplUtils.convertStorageExceptionMessage(message, response), response, value);
}
/**
* @return The error code returned by the service.
*/
public BlobErrorCode getErrorCode() {
return BlobErrorCode.fromString(super.getResponse().getHeaders().getValue(ERROR_CODE));
}
/**
* @return The message returned by the service.
*/
public String getServiceMessage() {
return super.getMessage();
}
/**
* @return The status code on the response.
*/
public int getStatusCode() {
return super.getResponse().getStatusCode();
}
}