Skip to content

Used as a base for Minecraft b1.7.3 plugin development, includes utility classes for common plugin tasks and convenience.

License

Notifications You must be signed in to change notification settings

AleksandarHaralanov/gradle-plugin-template

Repository files navigation

Gradle Plugin Template

A gradle template to use as a base for Minecraft b1.7.3 plugin development, including utility classes for common plugin tasks and convenience.

Usage

While the project may be compatible with other Integrated Development Environments (IDEs), it is highly recommended to use IntelliJ IDEA by JetBrains for optimal performance.

How To Clone

  1. Via VCS:

    • Open IntelliJ IDEA.
    • Go to File > New > Project from Version Control.
    • If you're on the dashboard home screen of the IDE, click CLONE FROM VCS on the top-right button.
    • In the URL field, paste the repository link:
      https://github.com/AleksandarHaralanov/gradle-plugin-template
      
    • Rename your project to have your desired plugin name.
    • Click Clone to download the project.
  2. Via Git:

    • Open your terminal and run the following command:
      git clone https://github.com/AleksandarHaralanov/gradle-plugin-template.git <project-name>

Notice

After cloning, update the src/main/resources/plugin.yml with your specific details.

Prerequisites

  • JDK 8 Required: This project is built upon JDK 8. Ensure that your development environment is set up with JDK 8 or a compatible version.

Features

Convenience

  • build.gradle:
    • Names the plugin's compiled .jar file using the plugin's name and version directly from the plugin.yml file.
  • Plugin:
    • Includes the onEnable and onDisable methods for the plugin's functionality.
    • Loggers that utilize the plugin's name and version for when the plugin is enabled and disabled.

Utility Classes

  • AboutUtil:

    • Purpose: Provides methods to easily access information about the plugin, such as its name, version, authors, and description.
    • Usage: Use this utility to display plugin information in console logs, help commands, or any other context where plugin details are required.
    • Features:
      • Fetches plugin metadata from the plugin.yml file.
      • Returns formatted strings for logging or display.
  • AccessUtil:

    • Purpose: Provides utility methods to interact with permissions, commands, and other access control aspects in the plugin.
    • Usage: Helps manage permissions, check user permissions, and handle command execution in a standardized way.
    • Features:
      • Permission checking.
      • Command execution.
      • Access control.
  • ColorUtil:

    • Purpose: Formats text messages with color codes compatible with Minecraft.
    • Usage: Style text messages for players or logs using color codes.
    • Features:
      • Applies color and formatting codes.
      • Easy integration with Minecraft text formatting.
  • ConfigUtil:

    • Purpose: Handles configuration file reading and writing.
    • Usage: Use to manage plugin configuration files, loading configuration data at startup and saving changes at shutdown.
    • Features:
      • Reads configuration data from YAML files.
      • Writes changes back to YAML files.
      • Provides default values for configuration settings.
  • DiscordUtil:

    • Purpose: Facilitates interaction with Discord services.
    • Usage: Helps send messages to Discord channels or get information from Discord.
    • Features:
      • Sends messages to Discord channels.
      • Retrieves messages or information from Discord.
      • Supports both text and rich media messages.
  • LoggerUtil:

    • Purpose: Provides a unified logging utility for the plugin.
    • Usage: Standardizes logging across the plugin, using the plugin's name and version.
    • Features:
      • Logs messages with the plugin’s name and version.
      • Supports various log levels (INFO, WARN, SEVERE, etc.)
      • Integrates with both console and file logging.
  • UpdateUtil:

    • Purpose: Manages plugin updates.
    • Usage: Monitors and checks for updates, notifying owners in console if a new version is available.
    • Features:
      • Checks for new plugin versions.
      • Notifies owners of available updates.
      • Integrates with GitHub API for repositories.

About

Used as a base for Minecraft b1.7.3 plugin development, includes utility classes for common plugin tasks and convenience.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages