/* * Copyright (c) 2017 NOVA, All rights reserved. * This library is free software, licensed under GNU Lesser General Public License version 3 * * This file is part of NOVA. * * NOVA is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * NOVA 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with NOVA. If not, see <http://www.gnu.org/licenses/>. */ package nova.core.config; import java.util.Optional; /** * Implement this on classes annotated with {@link ConfigHolder} * to add additional custom handling to your config files. * * {@link #handle(com.typesafe.config.Config) handle(Config)} * is called after {@link Configuration} loads all fields * annotated with {@link Config}. * * @author ExE Boss */ public interface ConfigHandler { /** * This method allows you to do custom handling on your config files. * * It is called after {@link Configuration} loads all fields * annotated with {@link Config}. * * @param config The config object, which is actually immutable, * and any setter call creates a new instance with the change. * @return The modified config object, or an empty optional * to discard your changes. */ Optional<com.typesafe.config.Config> handle(com.typesafe.config.Config config); }