package com.fr.start; import com.fr.common.report.ReportState; import com.fr.design.RestartHelper; import com.fr.design.dialog.FineJOptionPane; import com.fr.design.i18n.Toolkit; import com.fr.design.mainframe.messagecollect.StartErrorMessageCollector; import com.fr.design.mainframe.messagecollect.entity.DesignerErrorMessage; import com.fr.env.detect.base.DetectorBridge; import com.fr.env.detect.bean.DetectorResult; import com.fr.env.detect.bean.DetectorStatus; import com.fr.env.detect.bean.DetectorType; import com.fr.exit.DesignerExiter; import com.fr.general.IOUtils; import com.fr.io.utils.ResourceIOUtils; import com.fr.log.FineLoggerFactory; import com.fr.process.engine.core.CarryMessageEvent; import com.fr.process.engine.core.FineProcessContext; import com.fr.stable.StableUtils; import com.fr.stable.lifecycle.ErrorType; import com.fr.stable.lifecycle.ErrorTypeHelper; import com.fr.stable.lifecycle.FineLifecycleFatalError; import com.fr.stable.project.ProjectConstants; import javax.swing.JOptionPane; import java.util.HashMap; import java.util.Map; /** * @author hades * @version 10.0 * Created by hades on 2020/3/16 */ public class LifecycleFatalErrorHandler { private static final LifecycleFatalErrorHandler INSTANCE = new LifecycleFatalErrorHandler(); private Map map = new HashMap<>(); private LifecycleFatalErrorHandler() { map.put(ErrorTypeHelper.FINEDB, FineDBHandler.SELF); } public static LifecycleFatalErrorHandler getInstance() { return INSTANCE; } public void handle(FineLifecycleFatalError fatal) { SplashContext.getInstance().hide(); FineProcessContext.getParentPipe().fire(new CarryMessageEvent(ReportState.STOP.getValue())); Handler handler = map.get(fatal.getErrorType()); if (handler == null) { handler = DefaultHandler.SELF; } handler.handle(fatal); } interface Handler { void handle(FineLifecycleFatalError error); } /** * finedb处理 */ enum FineDBHandler implements Handler { /** * 自检测 */ SELF { @Override public void handle(FineLifecycleFatalError fatal) { String showText = generateShowText(fatal); StartErrorMessageCollector.getInstance().record(DesignerErrorMessage.FINEDB_PROBLEM.getId(), DesignerErrorMessage.FINEDB_PROBLEM.getMessage(), fatal.getMessage()); FineLoggerFactory.getLogger().error(DesignerErrorMessage.FINEDB_PROBLEM.getId() + ": " + DesignerErrorMessage.FINEDB_PROBLEM.getMessage()); int result = FineJOptionPane.showOptionDialog(null, showText, Toolkit.i18nText("Fine-Design_Basic_Error_Tittle"), JOptionPane.YES_NO_OPTION, JOptionPane.ERROR_MESSAGE, IOUtils.readIcon("com/fr/design/images/error/error2.png"), new Object[] {Toolkit.i18nText("Fine-Design_Basic_Reset"), Toolkit.i18nText("Fine-Design_Basic_Cancel")}, null); if (result == JOptionPane.YES_OPTION) { boolean success = false; try { ResourceIOUtils.copy(StableUtils.pathJoin(ProjectConstants.EMBED_DB_DIRECTORY, ProjectConstants.FINE_DB_NAME), StableUtils.pathJoin(ProjectConstants.EMBED_DB_DIRECTORY, ProjectConstants.FINE_DB_BAK_NAME)); success = ResourceIOUtils.delete(StableUtils.pathJoin(ProjectConstants.EMBED_DB_DIRECTORY, ProjectConstants.FINE_DB_NAME)); } catch (Exception e) { FineLoggerFactory.getLogger().error(e.getMessage(), e); afterBackupFailed(); } if (!success) { afterBackupFailed(); } else { RestartHelper.restart(); } } else { DesignerExiter.getInstance().execute(); } } /** * 生成展示信息 * * @param fatal 异常 * @return 文本 */ private String generateShowText(FineLifecycleFatalError fatal) { // todo 其实这里的交互还是有问题, 为什么在锁住和没权限的场景下,要重置 FineDB 呢。 DetectorResult detectorResult = DetectorBridge.getInstance().detect(DetectorType.FINE_DB_LOCKED, fatal); if (detectorResult.getStatus() == DetectorStatus.EXCEPTION) { return Toolkit.i18nText("Fine-Design_Error_Finedb_Locked_Backup_Reset"); } detectorResult = DetectorBridge.getInstance().detect(DetectorType.FINE_DB_PERMISSION, fatal); if (detectorResult.getStatus() == DetectorStatus.EXCEPTION) { return Toolkit.i18nText("Fine-Design_Error_Finedb_Permission_Backup_Reset"); } detectorResult = DetectorBridge.getInstance().detect(DetectorType.FINE_DB_DIRTY, fatal); if (detectorResult.getStatus() == DetectorStatus.EXCEPTION) { return Toolkit.i18nText("Fine-Design_Error_Finedb_Dirty_Backup_Reset"); } return Toolkit.i18nText("Fine-Design_Error_Finedb_Backup_Reset"); } private void afterBackupFailed() { FineJOptionPane.showMessageDialog(null, Toolkit.i18nText("Fine-Design_Error_Finedb_Backup_Reset_Result", ResourceIOUtils.getRealPath(StableUtils.pathJoin(ProjectConstants.EMBED_DB_DIRECTORY, ProjectConstants.FINE_DB_NAME))), Toolkit.i18nText("Fine-Design_Basic_Error"), JOptionPane.ERROR_MESSAGE); DesignerExiter.getInstance().execute(); } } } /** * 默认处理 */ enum DefaultHandler implements Handler { /** * 自处理 */ SELF { @Override public void handle(FineLifecycleFatalError fatal) { DesignerExiter.getInstance().exit(fatal); } } } }