2010-02-08 15:30:06 +02:00
|
|
|
/*
|
2011-12-06 02:42:25 +02:00
|
|
|
* Licensed to ElasticSearch and Shay Banon under one
|
2010-02-08 15:30:06 +02:00
|
|
|
* or more contributor license agreements. See the NOTICE file
|
|
|
|
* distributed with this work for additional information
|
2011-12-06 02:42:25 +02:00
|
|
|
* regarding copyright ownership. ElasticSearch licenses this
|
2010-02-08 15:30:06 +02:00
|
|
|
* file to you 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 org.elasticsearch;
|
|
|
|
|
2011-02-16 01:41:01 +02:00
|
|
|
import org.elasticsearch.rest.RestStatus;
|
|
|
|
|
2010-02-08 15:30:06 +02:00
|
|
|
/**
|
2010-02-13 20:03:37 +02:00
|
|
|
* A base class for all elasticsearch exceptions.
|
|
|
|
*
|
2011-12-06 02:42:25 +02:00
|
|
|
*
|
2010-02-08 15:30:06 +02:00
|
|
|
*/
|
|
|
|
public class ElasticSearchException extends RuntimeException {
|
|
|
|
|
|
|
|
/**
|
2010-02-13 20:03:37 +02:00
|
|
|
* Construct a <code>ElasticSearchException</code> with the specified detail message.
|
2010-02-08 15:30:06 +02:00
|
|
|
*
|
|
|
|
* @param msg the detail message
|
|
|
|
*/
|
|
|
|
public ElasticSearchException(String msg) {
|
|
|
|
super(msg);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2010-02-13 20:03:37 +02:00
|
|
|
* Construct a <code>ElasticSearchException</code> with the specified detail message
|
2010-02-08 15:30:06 +02:00
|
|
|
* and nested exception.
|
|
|
|
*
|
|
|
|
* @param msg the detail message
|
|
|
|
* @param cause the nested exception
|
|
|
|
*/
|
|
|
|
public ElasticSearchException(String msg, Throwable cause) {
|
|
|
|
super(msg, cause);
|
|
|
|
}
|
|
|
|
|
2011-02-16 01:41:01 +02:00
|
|
|
/**
|
|
|
|
* Returns the rest status code associated with this exception.
|
|
|
|
*/
|
|
|
|
public RestStatus status() {
|
|
|
|
ElasticSearchException current = this;
|
|
|
|
while (current instanceof ElasticSearchWrapperException) {
|
|
|
|
if (getCause() == null) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
if (getCause() instanceof ElasticSearchException) {
|
|
|
|
current = (ElasticSearchException) getCause();
|
|
|
|
} else {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (current == this) {
|
|
|
|
return RestStatus.INTERNAL_SERVER_ERROR;
|
|
|
|
} else {
|
|
|
|
return current.status();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-02-13 20:03:37 +02:00
|
|
|
/**
|
|
|
|
* Unwraps the actual cause from the exception for cases when the exception is a
|
|
|
|
* {@link ElasticSearchWrapperException}.
|
|
|
|
*
|
|
|
|
* @see org.elasticsearch.ExceptionsHelper#unwrapCause(Throwable)
|
|
|
|
*/
|
2010-02-08 15:30:06 +02:00
|
|
|
public Throwable unwrapCause() {
|
|
|
|
return ExceptionsHelper.unwrapCause(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the detail message, including the message from the nested exception
|
|
|
|
* if there is one.
|
|
|
|
*/
|
|
|
|
public String getDetailedMessage() {
|
|
|
|
if (getCause() != null) {
|
|
|
|
StringBuilder sb = new StringBuilder();
|
2010-07-12 01:33:38 +03:00
|
|
|
sb.append(toString()).append("; ");
|
|
|
|
if (getCause() instanceof ElasticSearchException) {
|
|
|
|
sb.append(((ElasticSearchException) getCause()).getDetailedMessage());
|
|
|
|
} else {
|
|
|
|
sb.append(getCause());
|
2010-02-08 15:30:06 +02:00
|
|
|
}
|
|
|
|
return sb.toString();
|
|
|
|
} else {
|
2010-07-12 01:33:38 +03:00
|
|
|
return super.toString();
|
2010-02-08 15:30:06 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2011-01-04 18:09:46 +02:00
|
|
|
* Retrieve the innermost cause of this exception, if none, returns the current exception.
|
2010-02-08 15:30:06 +02:00
|
|
|
*/
|
|
|
|
public Throwable getRootCause() {
|
2011-01-04 18:09:46 +02:00
|
|
|
Throwable rootCause = this;
|
2010-02-08 15:30:06 +02:00
|
|
|
Throwable cause = getCause();
|
|
|
|
while (cause != null && cause != rootCause) {
|
|
|
|
rootCause = cause;
|
|
|
|
cause = cause.getCause();
|
|
|
|
}
|
|
|
|
return rootCause;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve the most specific cause of this exception, that is,
|
|
|
|
* either the innermost cause (root cause) or this exception itself.
|
|
|
|
* <p>Differs from {@link #getRootCause()} in that it falls back
|
|
|
|
* to the present exception if there is no root cause.
|
|
|
|
*
|
|
|
|
* @return the most specific cause (never <code>null</code>)
|
|
|
|
*/
|
|
|
|
public Throwable getMostSpecificCause() {
|
|
|
|
Throwable rootCause = getRootCause();
|
|
|
|
return (rootCause != null ? rootCause : this);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check whether this exception contains an exception of the given type:
|
|
|
|
* either it is of the given class itself or it contains a nested cause
|
|
|
|
* of the given type.
|
|
|
|
*
|
|
|
|
* @param exType the exception type to look for
|
|
|
|
* @return whether there is a nested exception of the specified type
|
|
|
|
*/
|
|
|
|
public boolean contains(Class exType) {
|
|
|
|
if (exType == null) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (exType.isInstance(this)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
Throwable cause = getCause();
|
|
|
|
if (cause == this) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (cause instanceof ElasticSearchException) {
|
|
|
|
return ((ElasticSearchException) cause).contains(exType);
|
|
|
|
} else {
|
|
|
|
while (cause != null) {
|
|
|
|
if (exType.isInstance(cause)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
if (cause.getCause() == cause) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
cause = cause.getCause();
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|