-
-
Notifications
You must be signed in to change notification settings - Fork 70
API
Want to hook into my plugin? Here's a basic overview on the API. This is useful if you want to make a addon or an extend the features of my plugin. More API to come! Feel free to request API if needed.
JavaDoc available here
VotingPluginHooks - Class to make getting into the api a bit easier
- VotingPluginHooks.getInstance()
- Method to get main class
- Method to get user manager
- Method to inject into reward api
- User object
- Creating object (plugin is main class):
plugin.getVotingPluginUserManager().getVotingPluginUser(playerName);
plugin.getVotingPluginUserManager().getVotingPluginUser(player);
plugin.getVotingPluginUserManager().getVotingPluginUser(uuid);
- VotingPluginUserManager
- Using Examples:
- Get user points:
user.getPoints();
- Set user points:
user.setPoints(int);
- Get user points:
- Object to handle vote sites
- The class ConfigVoteSites that handles the file reading/editing
- Create object:
plugin.getVoteSite(name);
- Using object:
- Give vote site rewards:
voteSite.giveRewards(user); // user is user object
- Give vote site rewards:
-
With my command system, you can add your own custom commands in /vote or /adminvote, with tab complete support
-
Define what arguments to add ("(player)","(sitename)","(string)","(number)","(reward)","(list)","(boolean)" are ones the plugin will add tab support and for example, check if argument is a number)
-
Also use & to define multiple possible args (E.g. "Help&?")
-
Examples (plugin is my Main plugin class, either add a CommandHandler to voteCommand or adminVoteCommand):
plugin.voteCommand.add(new CommandHandler(new String[] { "Next", "(player)" }, "Permission", "Help message for /vote help or /av help") { @Override public void execute(CommandSender sender, String[] args) { // code to run when command is executed, if player has perms and // args like number is met, plugin will check if it should be a number and check if args match // no need to add it here } });
-
See my CommandLoader class for more examples
- When a player votes, it will trigger a PlayerVoteEvent
- You can use this to cancel a vote, or whatever you want to do with it
- Triggered after a vote has processed
- Trigger everytime player received vote points
- Trigger via any special reward
- SpecialRewardType
- Trigger when player vote cool down ends on allsites
- Trigger when player vote cool down ends on a votesite
- Triggered when a voteparty happens
- When a player is given a reward, it will trigger a PlayerRewardEvent
- You can use this to cancel a reward, or whatever you want to do with it
- Triggerd when plugin version changes
- Triggerd on login, this includes any delay from login plugins like AuthMe
- Also accounts for vanished logins (if enabled)
Setup/Configuration:
BungeeCord/Velocity Setups:
-
Proxy Setups
- PLUGINMESSAGING (Best method)
- REDIS (Second best)
- SOCKETS
- MYSQL
- Global Data Handling
- Multi-Proxy Setups
Knowledge base:
- Commands & Permissions
- Special Rewards
- File Layout
- API
- Converting data storage
- Vote Reminding
- Time Changes
- Minecraft Server Lists
- Performance Settings
- Bedrock Player Support
- Debug
- Minecraft Server Lists
- PlaceHolderAPI Expansion
- Signs
- Online/Offline Mode
- WIP MonthDateTotals
Troubleshooting
Rewards:
More setups: