commonMain.de.griefed.serverpackcreator.api.ApiPlugins.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of serverpackcreator-api-jvm Show documentation
Show all versions of serverpackcreator-api-jvm Show documentation
ServerPackCreators API, to create server packs from Forge, Fabric, Quilt, LegacyFabric and NeoForge modpacks.
/* Copyright (C) 2024 Griefed
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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 this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301
* USA
*
* The full license can be found at https:github.com/Griefed/ServerPackCreator/blob/main/LICENSE
*/
package de.griefed.serverpackcreator.api
import de.griefed.serverpackcreator.api.plugins.serverpackhandler.PostGenExtension
import de.griefed.serverpackcreator.api.plugins.serverpackhandler.PreGenExtension
import de.griefed.serverpackcreator.api.plugins.serverpackhandler.PreZipExtension
import de.griefed.serverpackcreator.api.plugins.swinggui.TabExtension
import de.griefed.serverpackcreator.api.utilities.CommentedConfig
import de.griefed.serverpackcreator.api.utilities.File
import de.griefed.serverpackcreator.api.utilities.Optional
/**
* Manager for ServerPackCreator plugins. In itself it doesn't do much. It gathers lists of all
* available extensions for [TabExtension],[PreGenExtension],[PreZipExtension] and
* [PostGenExtension] so they can then be run during server pack generation and during
* initialization of the GUI.
*
* @author Griefed
*/
expect class ApiPlugins {
/**
* Get the global plugin configuration for a plugin of the passed ID. The configuration is wrapped
* in an [Optional], because a plugin may not provide a global configuration. If you intend
* on using a global configuration for your plugin, make sure to check whether it is present before
* trying to use it!
*
* @param pluginId The plugin ID of the...well...plugin.
* @return The global plugin configuration, wrapped in an Optional.
* @author Griefed
*/
fun getPluginConfig(pluginId: String): Optional
/**
* Run any and all Pre-Server Pack-Generation extensions, using the passed configuration model and
* the destination at which the server pack is to be generated and stored at.
*
* @param packConfig The configuration model from which to create the server pack.
* @param destination The destination at which the server pack will be generated and stored
* at.
* @author Griefed
*/
fun runPreGenExtensions(packConfig: PackConfig, destination: String)
/**
* Run any and all Pre-ZIP-archive creation extensions, using the passed configuration model and
* the destination at which the server pack is to be generated and stored at.
*
* @param packConfig The configuration model from which to create the server pack.
* @param destination The destination at which the server pack will be generated and stored
* at.
* @author Griefed
*/
fun runPreZipExtensions(packConfig: PackConfig, destination: String)
/**
* Run any and all Post-server pack-generation extensions, using the passed configuration model
* and the destination at which the server pack is to be generated and stored at.
*
* @param packConfig The configuration model from which to create the server pack.
* @param destination The destination at which the server pack will be generated and stored
* at.
* @author Griefed
*/
fun runPostGenExtensions(packConfig: PackConfig, destination: String)
/**
* Run any and all configuration-check extensions, using the passed configuration model and the
* destination at which the server pack is to be generated and stored at.
*
* @param packConfig The configuration model containing the server pack and plugin
* configurations to check.
* @param configCheck Collection of encountered errors, if any, for convenient result-checks.
* @return `true` if any custom check detected an error with the configuration.
* **Only** return `false` when not a **single** check
* errored.
* @author Griefed
*/
fun runConfigCheckExtensions(
packConfig: PackConfig,
configCheck: ConfigCheck = ConfigCheck()
): ConfigCheck
/**
* Get the configuration-file for a plugin, if it exists. This is wrapped in an [Optional],
* because not every plugin may provide a configuration-file to use globally for the relevant
* plugins settings. If you intend on using a global configuration, make sure to check whether the
* file is present, before moving on!
*
* @param pluginId The plugin ID with which to identify the correct config-file to return.
* @return The config-file corresponding to the ID of the plugin, wrapped in an Optional.
* @author Griefed
*/
fun getPluginConfigFile(pluginId: String): Optional
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy