mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2025-01-23 16:41:22 +01:00
Implemented SettingsService
This commit is contained in:
parent
0f63ffe859
commit
5d3bc4c95d
@ -2,7 +2,7 @@ plugins {
|
|||||||
id "com.jfrog.bintray" version "1.8.4"
|
id "com.jfrog.bintray" version "1.8.4"
|
||||||
}
|
}
|
||||||
|
|
||||||
ext.apiVersion = '5.0-R0.2'
|
ext.apiVersion = '5.0-R0.3'
|
||||||
|
|
||||||
bintray {
|
bintray {
|
||||||
user = System.getenv('BINTRAY_USER')
|
user = System.getenv('BINTRAY_USER')
|
||||||
|
@ -56,9 +56,13 @@ enum Capability {
|
|||||||
*/
|
*/
|
||||||
DATA_EXTENSION_SHOW_IN_PLAYER_TABLE,
|
DATA_EXTENSION_SHOW_IN_PLAYER_TABLE,
|
||||||
/**
|
/**
|
||||||
*
|
* QueryService and CommonQueries
|
||||||
*/
|
*/
|
||||||
QUERY_API;
|
QUERY_API,
|
||||||
|
/**
|
||||||
|
* SettingsService
|
||||||
|
*/
|
||||||
|
SETTINGS_API;
|
||||||
|
|
||||||
static Optional<Capability> getByName(String name) {
|
static Optional<Capability> getByName(String name) {
|
||||||
if (name == null) {
|
if (name == null) {
|
||||||
|
@ -0,0 +1,79 @@
|
|||||||
|
/*
|
||||||
|
* This file is part of Player Analytics (Plan).
|
||||||
|
*
|
||||||
|
* Plan is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Lesser General Public License v3 as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Plan 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 Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public License
|
||||||
|
* along with Plan. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
package com.djrapitops.plan.settings;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
|
import java.util.function.Supplier;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Service for defining plugin specific settings to the Plan config.
|
||||||
|
* <p>
|
||||||
|
* All given paths will be prepended with "Plugins." to place the settings in the plugins config section.
|
||||||
|
* It is recommended to use setting paths {@code "<Plugin_name>.Some_setting"}
|
||||||
|
* <p>
|
||||||
|
* Requires Capability SETTINGS_API
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public interface SettingsService {
|
||||||
|
|
||||||
|
static SettingsService getInstance() {
|
||||||
|
return Optional.ofNullable(SettingsServiceHolder.service)
|
||||||
|
.orElseThrow(() -> new IllegalStateException("SettingsService has not been initialised yet."));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a String from the config or the default value.
|
||||||
|
*
|
||||||
|
* @param path Path in the config
|
||||||
|
* @param defaultValue Supplier for the default value, {@code () -> "Example"}.
|
||||||
|
* @return value in the config
|
||||||
|
*/
|
||||||
|
String getString(String path, Supplier<String> defaultValue);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a Integer from the config or the default value.
|
||||||
|
*
|
||||||
|
* @param path Path in the config
|
||||||
|
* @param defaultValue Supplier for the default value, {@code () -> 500}.
|
||||||
|
* @return value in the config
|
||||||
|
*/
|
||||||
|
Integer getInteger(String path, Supplier<Integer> defaultValue);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a String list from the config or the default value.
|
||||||
|
*
|
||||||
|
* @param path Path in the config
|
||||||
|
* @param defaultValue Supplier for the default value, {@code () -> Arrays.asList("Example", "Another")}.
|
||||||
|
* @return value in the config
|
||||||
|
*/
|
||||||
|
List<String> getStringList(String path, Supplier<List<String>> defaultValue);
|
||||||
|
|
||||||
|
class SettingsServiceHolder {
|
||||||
|
static SettingsService service;
|
||||||
|
|
||||||
|
private SettingsServiceHolder() {
|
||||||
|
/* Static variable holder */
|
||||||
|
}
|
||||||
|
|
||||||
|
static void set(SettingsService service) {
|
||||||
|
SettingsServiceHolder.service = service;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -32,6 +32,7 @@ import com.djrapitops.plan.identification.ServerInfo;
|
|||||||
import com.djrapitops.plan.processing.Processing;
|
import com.djrapitops.plan.processing.Processing;
|
||||||
import com.djrapitops.plan.query.QueryServiceImplementation;
|
import com.djrapitops.plan.query.QueryServiceImplementation;
|
||||||
import com.djrapitops.plan.settings.ConfigSystem;
|
import com.djrapitops.plan.settings.ConfigSystem;
|
||||||
|
import com.djrapitops.plan.settings.SettingsServiceImplementation;
|
||||||
import com.djrapitops.plan.settings.locale.LocaleSystem;
|
import com.djrapitops.plan.settings.locale.LocaleSystem;
|
||||||
import com.djrapitops.plan.storage.database.DBSystem;
|
import com.djrapitops.plan.storage.database.DBSystem;
|
||||||
import com.djrapitops.plan.storage.database.queries.objects.ServerQueries;
|
import com.djrapitops.plan.storage.database.queries.objects.ServerQueries;
|
||||||
@ -73,6 +74,7 @@ public class PlanSystem implements SubSystem {
|
|||||||
private final DeliveryUtilities deliveryUtilities;
|
private final DeliveryUtilities deliveryUtilities;
|
||||||
private final ExtensionServiceImplementation extensionService;
|
private final ExtensionServiceImplementation extensionService;
|
||||||
private final QueryServiceImplementation queryService;
|
private final QueryServiceImplementation queryService;
|
||||||
|
private final SettingsServiceImplementation settingsService;
|
||||||
private final ErrorHandler errorHandler;
|
private final ErrorHandler errorHandler;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
@ -93,6 +95,7 @@ public class PlanSystem implements SubSystem {
|
|||||||
DeliveryUtilities deliveryUtilities,
|
DeliveryUtilities deliveryUtilities,
|
||||||
ExtensionServiceImplementation extensionService,
|
ExtensionServiceImplementation extensionService,
|
||||||
QueryServiceImplementation queryService,
|
QueryServiceImplementation queryService,
|
||||||
|
SettingsServiceImplementation settingsService,
|
||||||
ErrorHandler errorHandler
|
ErrorHandler errorHandler
|
||||||
) {
|
) {
|
||||||
this.files = files;
|
this.files = files;
|
||||||
@ -111,6 +114,7 @@ public class PlanSystem implements SubSystem {
|
|||||||
this.deliveryUtilities = deliveryUtilities;
|
this.deliveryUtilities = deliveryUtilities;
|
||||||
this.extensionService = extensionService;
|
this.extensionService = extensionService;
|
||||||
this.queryService = queryService;
|
this.queryService = queryService;
|
||||||
|
this.settingsService = settingsService;
|
||||||
this.errorHandler = errorHandler;
|
this.errorHandler = errorHandler;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -145,6 +149,7 @@ public class PlanSystem implements SubSystem {
|
|||||||
);
|
);
|
||||||
queryService.register();
|
queryService.register();
|
||||||
extensionService.register();
|
extensionService.register();
|
||||||
|
settingsService.register();
|
||||||
enabled = true;
|
enabled = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -0,0 +1,104 @@
|
|||||||
|
/*
|
||||||
|
* This file is part of Player Analytics (Plan).
|
||||||
|
*
|
||||||
|
* Plan is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Lesser General Public License v3 as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Plan 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 Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public License
|
||||||
|
* along with Plan. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
package com.djrapitops.plan.settings;
|
||||||
|
|
||||||
|
import com.djrapitops.plan.settings.config.ConfigNode;
|
||||||
|
import com.djrapitops.plan.settings.config.PlanConfig;
|
||||||
|
import com.djrapitops.plugin.logging.L;
|
||||||
|
import com.djrapitops.plugin.logging.error.ErrorHandler;
|
||||||
|
|
||||||
|
import javax.inject.Inject;
|
||||||
|
import javax.inject.Singleton;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
|
import java.util.function.Supplier;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Implementation for {@link SettingsService}.
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
@Singleton
|
||||||
|
public class SettingsServiceImplementation implements SettingsService {
|
||||||
|
|
||||||
|
private final PlanConfig config;
|
||||||
|
private final ErrorHandler errorHandler;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
public SettingsServiceImplementation(
|
||||||
|
PlanConfig config,
|
||||||
|
ErrorHandler errorHandler
|
||||||
|
) {
|
||||||
|
this.config = config;
|
||||||
|
this.errorHandler = errorHandler;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void register() {
|
||||||
|
SettingsService.SettingsServiceHolder.set(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getString(String path, Supplier<String> defaultValue) {
|
||||||
|
String pluginPath = getPluginPath(path);
|
||||||
|
Optional<ConfigNode> node = config.getNode(pluginPath);
|
||||||
|
if (node.isPresent()) {
|
||||||
|
return node.get().getString();
|
||||||
|
} else {
|
||||||
|
set(pluginPath, defaultValue);
|
||||||
|
return config.getString(pluginPath);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> void set(String pluginPath, Supplier<T> defaultValue) {
|
||||||
|
config.set(pluginPath, defaultValue.get());
|
||||||
|
|
||||||
|
try {
|
||||||
|
config.save();
|
||||||
|
} catch (IOException e) {
|
||||||
|
errorHandler.log(L.ERROR, this.getClass(), e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Integer getInteger(String path, Supplier<Integer> defaultValue) {
|
||||||
|
String pluginPath = getPluginPath(path);
|
||||||
|
Optional<ConfigNode> node = config.getNode(pluginPath);
|
||||||
|
if (node.isPresent()) {
|
||||||
|
return node.get().getInteger();
|
||||||
|
} else {
|
||||||
|
set(pluginPath, defaultValue);
|
||||||
|
return config.getInteger(pluginPath);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<String> getStringList(String path, Supplier<List<String>> defaultValue) {
|
||||||
|
String pluginPath = getPluginPath(path);
|
||||||
|
Optional<ConfigNode> node = config.getNode(pluginPath);
|
||||||
|
if (node.isPresent()) {
|
||||||
|
return node.get().getStringList();
|
||||||
|
} else {
|
||||||
|
set(pluginPath, defaultValue);
|
||||||
|
return config.getStringList(pluginPath);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private String getPluginPath(String path) {
|
||||||
|
return "Plugin." + path;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user