/*
* #%L
* carewebframework
* %%
* Copyright (C) 2008 - 2016 Regenstrief Institute, 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.
*
* This Source Code Form is also subject to the terms of the Health-Related
* Additional Disclaimer of Warranty and Limitation of Liability available at
*
* http://www.carewebframework.org/licensing/disclaimer.
*
* #L%
*/
package org.carewebframework.api;
import org.apache.commons.lang.ObjectUtils;
import org.carewebframework.common.StrUtil;
import org.springframework.core.ErrorCoded;
import org.springframework.core.NestedCheckedException;
/**
* Superclass for all checked exceptions thrown in the framework
* <p>
* This class is <code>abstract</code> to force the programmer to extend the class.
* <code>getMessage</code> will include nested exception information; <code>printStackTrace</code>
* and other like methods will delegate to the wrapped exception, if any.
* </p>
* <p>
* Extends Spring's handy <code>NestedCheckedException</code> to wrap runtime exceptions with a root
* cause.
* </p>
*/
public class FrameworkCheckedException extends NestedCheckedException implements IThrowableContext, ErrorCoded {
private static final long serialVersionUID = 1L;
private String errorCode;
private final String throwableContext;
public FrameworkCheckedException(String msg) {
this(msg, null, null);
}
public FrameworkCheckedException(String msg, Throwable cause, String throwableContext) {
this(msg, cause, throwableContext, (Object[]) null);
}
public FrameworkCheckedException(String msg, Throwable cause, String throwableContext, Object... params) {
super(StrUtil.formatMessage(msg, params), cause);
this.throwableContext = throwableContext;
if (msg.startsWith("@")) {
errorCode = msg.substring(1);
}
}
/**
* Appends nested exception message
*
* @see org.springframework.core.NestedExceptionUtils#buildMessage(String, Throwable)
*/
@Override
public final String getMessage() {
return super.getMessage();
}
@Override
public boolean equals(Object other) {
if (this == other) {
return true;
}
if (!(other instanceof FrameworkCheckedException)) {
return false;
}
FrameworkCheckedException otherBe = (FrameworkCheckedException) other;
return getMessage().equals(otherBe.getMessage()) && ObjectUtils.equals(getCause(), otherBe.getCause());
}
@Override
public final int hashCode() {
return getMessage().hashCode();
}
@Override
public final String getErrorCode() {
return errorCode;
}
@Override
public final String getThrowableContext() {
return throwableContext;
}
}