Unhandled exceptions in Web Client and Desktop Client blocks thrown on the client tier or passed from Middleware, are passed to the special handlers mechanism. This mechanism is implemented in GUI module and available for both blocks.
The handler should be a managed bean implementing the GenericExceptionHandler
interface,
handle processing in its handle()
method and return true
, or immediately return
false
, if this handler is not able to handle the passed exception. This behaviour enables creating
a “chain of responsibility” for handlers.
It is recommended to inherit your handlers from the AbstractGenericExceptionHandler
base class,
which is able to disassemble the exceptions chain (including ones packed inside RemoteException
)
and handle specific exception types. Exceptions types supported by this handler are defined by passing strings
array to the base constructor from the handler constructor. Each string of the array should contain one full
class name of the handled exception, for example:
@ManagedBean("cuba_EntityAccessExceptionHandler") public class EntityAccessExceptionHandler extends AbstractGenericExceptionHandler { public EntityAccessExceptionHandler() { super(EntityAccessException.class.getName()); } ...
If the exception class is not accessible on the client side, specify its name with the string literal:
@ManagedBean("cuba_OptimisticExceptionHandler") public class OptimisticExceptionHandler extends AbstractGenericExceptionHandler implements Ordered { public OptimisticExceptionHandler() { super("org.springframework.orm.jpa.JpaOptimisticLockingFailureException"); } ...
In the case of using AbstractGenericExceptionHandler
as a base class, the processing logic is located
in doHandle()
method and looks as follows:
@Override protected void doHandle(String className, String message, @Nullable Throwable throwable, WindowManager windowManager) { String msg = messages.getMainMessage("zeroBalance.message"); windowManager.showNotification(msg, IFrame.NotificationType.ERROR); }
If the name of the exception class is insufficient to make a decision whether this handler can be applied
to the exception, canHandle()
method should be defined. Above all, this method accepts the text
of the exception. If the handler is applicable for this exception, the method must return true
.
For example:
@ManagedBean("cuba_NumericOverflowExceptionHandler") public class NumericOverflowExceptionHandler extends AbstractGenericExceptionHandler { public NumericOverflowExceptionHandler() { super(ReportingSQLException.class.getName()); } @Override protected boolean canHandle(String className, String message, @Nullable Throwable throwable) { return StringUtils.containsIgnoreCase(message, "Numeric field overflow"); } ...