Skip to content

YAML API is a specialized library that provides an intuitive, unified interface for managing YAML configuration files in Bukkit/Spigot/Paper plugins.

License

Notifications You must be signed in to change notification settings

CroaBeast/YAML-API

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Discord

YAML API

YAML API is a specialized library that simplifies working with YAML configuration files in Bukkit/Spigot/Paper plugins. It provides a robust and consistent interface for loading, saving, updating, and managing YAML-based configurations, along with advanced mapping capabilities for configuration sections and configurable units.


Overview

The YAML API package offers a set of tools designed to handle YAML configuration files efficiently. It abstracts the complexity of file I/O and reflection-based configuration parsing, allowing you to focus on using configuration data in your plugin.

Key components include:

  • YAMLFile: A class to load, save, and update YAML configuration files.
  • ResourceUtils: Utility methods for handling resources and file operations.
  • Configurable & ConfigurableFile: Interfaces and classes that provide easy access to the underlying FileConfiguration.
  • ConfigurableUnit: An interface representing a configuration unit, useful for handling permissions or groups in the configuration.
  • Mappable, SectionMappable, UnitMappable & HashMappable: A set of interfaces and classes for mapping configuration sections and units into Java collections.
  • YAMLUpdater: A class that updates YAML files by merging default values and preserving comments.

Key Features

  • Unified Configuration Management: Provides a consistent API for reading, writing, and updating YAML configuration files.

  • Dynamic Mapping and Conversion: Supports mapping configuration sections to custom units and collections, making it easier to work with complex configuration structures.

  • Resource and File Utilities: Includes helper classes to simplify file loading, resource saving, and directory management.

  • Comment Preservation and Updates: YAMLUpdater handles merging of default configuration values while preserving existing comments.

  • Reflection-Based Parsing: Uses reflection to dynamically access configuration sections and values, ensuring compatibility across server versions.


Usage Example

Below is an example demonstrating how to use the YAML API to load, update, and work with configuration files.

Example: Using ConfigurableFile and YAMLFile

package com.example.myplugin;

import me.croabeast.file.ConfigurableFile;
import me.croabeast.file.YAMLFile;
import org.bukkit.configuration.file.FileConfiguration;
import org.bukkit.plugin.java.JavaPlugin;

import java.io.IOException;

public class MyPlugin extends JavaPlugin {

    private ConfigurableFile config;

    @Override
    public void onEnable() {
        try {
            // Create a new configuration file located in the "config" folder
            config = new ConfigurableFile(this, "config", "settings")
                // Optionally, override methods to control updatability or other behaviors
                {
                    @Override
                    public boolean isUpdatable() {
                        // Retrieve the "update" key from the configuration to decide if updates are allowed
                        return get("update", false);
                    }
                };
            // Save the default configuration if not present
            config.saveDefaults();
            // Update the configuration file (merges defaults and preserves comments)
            config.update();
        } catch (IOException e) {
            e.printStackTrace();
        }

        // Access configuration values
        String prefix = config.get("lang-prefix", "&e MyPlugin »&7");
        getLogger().info("Language prefix: " + prefix);
    }
}

Example: Working with Mappable and SectionMappable

package com.example.myplugin;

import me.croabeast.file.SectionMappable;
import me.croabeast.file.ConfigurableFile;
import org.bukkit.configuration.ConfigurationSection;
import org.bukkit.plugin.java.JavaPlugin;

public class MyPlugin extends JavaPlugin {

    private ConfigurableFile config;

    @Override
    public void onEnable() {
        try {
            config = new ConfigurableFile(this, "config", "settings");
            config.saveDefaults();
            config.update();
        } catch (Exception e) {
            e.printStackTrace();
        }

        // Assume we have a configuration section "advancements"
        ConfigurationSection section = config.getConfiguration().getConfigurationSection("advancements");
        if (section != null) {
            // Create a SectionMappable from the configuration section
            SectionMappable.Set sectionMap = SectionMappable.asSet(section.getValues(false));
            // Process the mapped configuration as needed
            getLogger().info("Loaded advancements: " + sectionMap);
        }
    }
}

Maven / Gradle Installation

To include YAML API to the project, add the following repository and dependency to your build configuration. Replace ${version} with the desired version tag.

Maven

Add the repository and dependency to your pom.xml:

<repositories>
    <repository>
        <id>croabeast-repo</id>
        <url>https://croabeast.github.io/repo/</url>
    </repository>
</repositories>

<dependencies>
    <dependency>
        <groupId>me.croabeast</groupId>
        <artifactId>YAML-API</artifactId>
        <version>${version}</version>
        <scope>compile</scope>
    </dependency>
</dependencies>

Gradle

Add the repository and dependency to your build.gradle:

repositories {
    maven {
        url "https://croabeast.github.io/repo/"
    }
}

dependencies {
    implementation "me.croabeast:YAML-API:${version}"
}

Replace ${version} with the appropriate module version.


Conclusion

YAML API is a powerful library for managing YAML configurations in your Bukkit/Spigot/Paper plugins. It streamlines file operations, mapping, and updates while preserving comments and ensuring compatibility across server versions. Whether you are building simple configuration systems or working with complex, nested settings, YAML API provides the tools you need to efficiently manage your plugin’s configuration.

Happy coding! — CroaBeast

About

YAML API is a specialized library that provides an intuitive, unified interface for managing YAML configuration files in Bukkit/Spigot/Paper plugins.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages