/****************************************************************************** * * * Copyright 2016 Subterranean Security * * * * 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. * * * *****************************************************************************/ package com.subterranean_security.crimson.core.misc; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import com.subterranean_security.crimson.core.Reporter; import com.subterranean_security.crimson.core.util.MiscUtil; import com.subterranean_security.crimson.universal.Universal; import com.subterranean_security.crimson.viewer.ui.common.UINotification; public class EH implements Thread.UncaughtExceptionHandler { private static final Logger log = LoggerFactory.getLogger(EH.class); @Override public void uncaughtException(Thread thread, Throwable t) { if (Universal.instance == Universal.Instance.VIEWER) { try { if (UINotification.getPolicy().getOnException()) { UINotification.addConsoleBad("An unexpected exception has occurred"); } } catch (Exception e) { } } log.debug(MiscUtil.getStack(t)); Thread.currentThread().getStackTrace();// TODO send Reporter.report(Reporter.newReport().setCrStackTrace(MiscUtil.getStack(t)).build()); } public static void handle(Throwable t) { log.debug(MiscUtil.getStack(t)); Reporter.report(Reporter.newReport().setCrStackTrace(MiscUtil.getStack(t)).build()); } }