EzSkills is a compact RPG progression plugin that layers levelling, XP gain, and timed abilities on top of your server's gameplay. Use it standalone or integrate with plugins like EzTree, EzMine, or your own custom plugins to turn repetitive actions into a rewarding skill loop.
!Version !Minecraft !Software !Java
| Skill | Description |
|---|---|
| Woodcutting | Award XP for felling trees |
| Mining | Award XP for breaking ores and stone |
| Fishing | Award XP for catching fish |
| Fighting | Award XP for combat with mobs and players |
| Acrobatics | Award XP for jumping, falling, and sprinting |
Every source plugin that calls EzSkillsAPI.addExperience(plugin, ...) is subject to the per-plugin XP multiplier and enabled flag you configure centrally - no changes needed in third-party plugins.
EzSkillsAPI.registerAbility(definition). Custom abilities appear in the /abilities GUI automatically./abilities command opens an overview showing every registered ability with its current state: Ready (green), Preparing (yellow), or Active (gold).xp-base and xp-multiplier per skill in skills.yml.config.yml, set an xp-multiplier or enabled: false for any third-party plugin and any skill without touching their code./ezskills top.skills.yml and ability timings in abilities.yml.SkillLevelUpEvent fires immediately for rewards, rank unlocks, or boss-bar announcements./skills (levels) and /abilities (ability states).| Command | Description | Permission |
|---|---|---|
/skills | Open the skill progress overview GUI | ezskills.use |
/abilities | Open the ability state overview GUI | ezskills.use |
/ezskills)| Command | Description |
|---|---|
get <player> <skill> | Print a player's level and stored XP |
info <player> | Print a full skill overview (works offline) |
addxp <player> <skill> <amount> | Grant XP manually; fires level-up events |
setlevel <player> <skill> <level> | Set a level directly, resetting XP |
reset <player> <skill> | Reset one skill to level 1 |
resetall <player> | Reset all skills to level 1 |
top <skill> [limit] | Leaderboard by level (MySQL required for full results) |
ability <player> <ability> | Force-activate an ability, bypassing preparation |
reload | Reload all config files |
All /ezskills subcommands require the ezskills.admin permission.
| File | Controls |
|---|---|
config.yml | GUI titles, boss-bar notifications, plugin-overrides |
skills.yml | XP base and multiplier per skill |
abilities.yml | Preparation window, active duration, and cooldown per ability |
storage.yml | Storage backend (YAML or MySQL) and connection details |
# config.yml
plugin-overrides:
MyPlugin: # must match the exact plugin name
woodcutting:
enabled: true
xp-multiplier: 1.5 # 50% bonus Woodcutting XP from MyPlugin
mining:
enabled: false # MyPlugin cannot award Mining XP
| Method | Description |
|---|---|
EzSkillsAPI.addExperience(playerId, skill, amount) | Award XP directly (no multiplier applied) |
EzSkillsAPI.addExperience(plugin, playerId, skill, amount) | Award XP with the server-configured multiplier and enabled check |
EzSkillsAPI.getSkillLevel(playerId, skill) | Return the player's current level |
EzSkillsAPI.getSkillExperience(playerId, skill) | Return the player's accumulated XP |
EzSkillsAPI.setSkillLevel(playerId, skill, level) | Set a level directly, resetting XP |
EzSkillsAPI.getSkillProfile(playerId) | Return the full profile object (null if not cached) |
| Method | Description |
|---|---|
EzSkillsAPI.registerSkill(definition) | Register a custom skill at runtime; progress is persisted automatically |
EzSkillsAPI.getRegisteredSkills() | List all registered custom skill definitions |
| Method | Description |
|---|---|
EzSkillsAPI.registerAbility(definition) | Register a custom ability; appears in /abilities automatically |
EzSkillsAPI.getRegisteredAbilities() | List all registered ability definitions |
EzSkillsAPI.prepareAbility(playerId, ability) | Enter the preparation (charged) state |
EzSkillsAPI.activateAbility(playerId, ability) | Activate the ability immediately |
EzSkillsAPI.deactivateAbility(playerId, ability) | Cancel or end the ability early |
EzSkillsAPI.isAbilityActive(playerId, ability) | Check whether the ability is currently active. |
SkillLevelUpEvent - fires when a player reaches a new level (carries old and new level).EzSkillsAbilityPrepareEvent - fires when an ability enters its warm-up window.EzSkillsAbilityActivateEvent - fires when an ability activates.EzSkillsAbilityDeactivateEvent - fires when an ability ends or is cancelled.public class NightVisionAbility implements AbilityDefinition {
@Override public String getName() { return "NIGHT_VISION"; }
@Override public String getDisplayName() { return "Night Vision"; }
@Override public Material getIcon() { return Material.ENDER_EYE; } // optional - defaults to NETHER_STAR
@Override public String getDescription() { return "See clearly in the dark."; }
@Override public String getSkillName() { return "FIGHTING"; }
// Optional: override timing defaults (30s prep / 15s active / 120s cooldown)
}
// In onEnable:
EzSkillsAPI.registerAbility(new NightVisionAbility());
See the developer documentation for the full integration guide.
Drop a message on the forum thread or join our Discord server for quick support and integration tips.

Add skill-based XP, leveling, and timed abilities to any plugin with a clean API