/** * Copyright (C) 2001-2017 by RapidMiner and the contributors * * Complete list of developers available at our web site: * * http://rapidminer.com * * This program is free software: you can redistribute it and/or modify it under the terms of the * GNU Affero General Public License as published by the Free Software Foundation, either version 3 * of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without * even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License along with this program. * If not, see http://www.gnu.org/licenses/. */ package com.rapidminer.gui.safemode; import com.rapidminer.gui.tools.dialogs.ConfirmDialog; import com.rapidminer.tools.FileSystemService; import com.rapidminer.tools.I18N; import com.rapidminer.tools.LogService; import java.io.File; import java.io.IOException; import java.util.logging.Level; /** * Safe mode for RapidMiner. When {@link #launchStarts()} is called, a lock file is created. This * lock file is deleted in {@link #launchComplete()}. If RapidMiner starts, and the lock file still * exists when {@link #launchStarts()} is called, This class will ask the user whether they want to * go into safe mode, which disables loading of all plugins. * * @author Simon Fischer * */ public class SafeMode { private File lockFile; private boolean safeMode = false; public SafeMode() { lockFile = FileSystemService.getUserConfigFile("safeMode.lock"); } /** Call at the beginning of the startup phase. */ public void launchStarts() { if (lockFile.exists()) { // Lock file not deleted? Crashed during last startup LogService.getRoot().log(Level.INFO, "com.rapidminer.gui.safemode.SafeMode.lock_left_behind", lockFile); safeMode = askForSafeMode(); if (safeMode) { LogService.getRoot().log(Level.INFO, "com.rapidminer.gui.safemode.SafeMode.entering_safe_mode"); } } // Create file on startup try { lockFile.createNewFile(); } catch (IOException e) { LogService.getRoot().log( Level.INFO, I18N.getMessage(LogService.getRoot().getResourceBundle(), "com.rapidminer.gui.safemode.SafeMode.cannot_create_lock", lockFile), e); } } public void launchComplete() { if (lockFile.exists()) { // Delete lock on end of startup if (!lockFile.delete()) { LogService.getRoot().log(Level.WARNING, "com.rapidminer.gui.safemode.SafeMode.failed_to_delete_log_file", lockFile); } } } public boolean isSafeMode() { return safeMode; } private boolean askForSafeMode() { int result = SafeModeDialog.showSafeModeDialog("safemode.enter_safe_mode", ConfirmDialog.YES_NO_OPTION); return result == ConfirmDialog.YES_OPTION; } }