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

io.mosip.pmp.partner.exception.BaseUncheckedException Maven / Gradle / Ivy

package io.mosip.pmp.partner.exception;

import java.util.ArrayList;
import java.util.List;

/**
 * This is the base class for all MOSIP unchecked exceptions.
 * 
 * {@code BaseUncheckedException} is the superclass of those exceptions that can
 * be thrown during the normal operation of the Java Virtual Machine.
 *
 * 

* {@code RuntimeException} and its subclasses are unchecked * exceptions. Unchecked exceptions do not need to be declared in * a method or constructor's {@code throws} clause if they can be thrown by the * execution of the method or constructor and propagate outside the method or * constructor boundary. * * @author sanjeev.shrivastava Compile-Time Checking of Exceptions */ public class BaseUncheckedException extends RuntimeException { private static final long serialVersionUID = -875003872780128394L; public static final String EMPTY_SPACE = " "; private final List infoItems = new ArrayList<>(); /** * Constructs a new unchecked exception */ public BaseUncheckedException() { super(); } /** * Constructs a new checked exception with errorMessage * * @param errorMessage the detail message. */ public BaseUncheckedException(String errorMessage) { super(errorMessage); } /** * Constructs a new unchecked exception with the specified detail message and * error code. * * @param errorMessage the detail message. * @param errorCode the error code. * */ public BaseUncheckedException(String errorCode, String errorMessage) { super(errorCode + " --> " + errorMessage); addInfo(errorCode, errorMessage); } /** * Constructs a new unchecked exception with the specified detail message and * error code and error cause. * * * @param errorCode the error code * @param errorMessage the detail message. * @param rootCause the specified cause */ public BaseUncheckedException(String errorCode, String errorMessage, Throwable rootCause) { super(errorCode + " --> " + errorMessage, rootCause); addInfo(errorCode, errorMessage); if (rootCause instanceof BaseUncheckedException) { BaseUncheckedException bue = (BaseUncheckedException) rootCause; infoItems.addAll(bue.infoItems); } } /* * Returns a String object that can be used to get the exception message. * * @see java.lang.Throwable#getMessage() */ @Override public String getMessage() { return buildMessage(super.getMessage(), getCause()); } /** * This method add the information of error code and error message. * * @param errorCode the error code * @param errorText the detail message. * @return the instance of current BaseCheckedException */ public BaseUncheckedException addInfo(String errorCode, String errorText) { this.infoItems.add(new InfoItem(errorCode, errorText)); return this; } /** * Returns the list of error codes. * * @return the list of error codes */ public List getCodes() { List codes = new ArrayList<>(); for (int i = this.infoItems.size() - 1; i >= 0; i--) { codes.add(this.infoItems.get(i).errorCode); } return codes; } /** * Returns the list of exception messages. * * @return the list of exception messages */ public List getErrorTexts() { List errorTexts = new ArrayList<>(); for (int i = this.infoItems.size() - 1; i >= 0; i--) { errorTexts.add(this.infoItems.get(i).errorText); } return errorTexts; } /** * Return the last error code. * * @return the last error code */ public String getErrorCode() { return infoItems.get(0).errorCode; } /** * Return the last exception message. * * @return the last exception message */ public String getErrorText() { return infoItems.get(0).errorText; } public static String buildMessage(String message, Throwable cause) { if (cause != null) { StringBuilder sb = new StringBuilder(); if (message != null) { sb.append(message).append("; "); } sb.append("\n"); sb.append("nested exception is ").append(cause); return sb.toString(); } else { return message; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy