|
|
|
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<ErrorType, Handler> 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);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|