|
| 1 | +package szczepanski.gerard.runnit.view.util; |
| 2 | + |
| 3 | +import org.apache.log4j.Logger; |
| 4 | + |
| 5 | +import lombok.RequiredArgsConstructor; |
| 6 | +import szczepanski.gerard.runit.common.exception.RunitRuntimeException; |
| 7 | +import szczepanski.gerard.runit.settings.service.loader.Settings; |
| 8 | +import szczepanski.gerard.runit.settings.service.loader.SettingsLoader; |
| 9 | +import szczepanski.gerard.runit.settings.service.writer.SettingsWriter; |
| 10 | + |
| 11 | +/** |
| 12 | + * This class is responsible for load Settings if exist, |
| 13 | + * and then check if settings are initialized. If not, then |
| 14 | + * invoke SettingsWriter restoreDefaults. |
| 15 | + * |
| 16 | + * If Settings file is not exist, then ProgramSettingsManager will create settings file, |
| 17 | + * with default configuration. |
| 18 | + * |
| 19 | + * @author Gerard Szczepanski |
| 20 | + */ |
| 21 | +@RequiredArgsConstructor |
| 22 | +public class ProgramSettingsManager { |
| 23 | + private static final Logger LOG = Logger.getLogger(ProgramSettingsManager.class); |
| 24 | + |
| 25 | + private final SettingsLoader settingsLoader; |
| 26 | + private final SettingsWriter settingsWriter; |
| 27 | + |
| 28 | + public void loadSettings() { |
| 29 | + LOG.debug("Loading settings"); |
| 30 | + |
| 31 | + try { |
| 32 | + Settings initialSettings = settingsLoader.getSettings(); |
| 33 | + restoreSettingsIfNotDefined(initialSettings); |
| 34 | + } catch (RunitRuntimeException e) { |
| 35 | + LOG.debug("Settings file is not created yet. Creating default settings file"); |
| 36 | + settingsWriter.restoreDefaultSettings(); |
| 37 | + } |
| 38 | + } |
| 39 | + |
| 40 | + private void restoreSettingsIfNotDefined(Settings initialSettings) { |
| 41 | + if (initialSettings.areSettingsNotDefined()) { |
| 42 | + LOG.debug("Settings are not defined. Injecting default settings"); |
| 43 | + settingsWriter.restoreDefaultSettings(); |
| 44 | + } |
| 45 | + } |
| 46 | + |
| 47 | +} |
0 commit comments