Skip to content

Latest commit

 

History

History
23 lines (15 loc) · 3 KB

api.creole

File metadata and controls

23 lines (15 loc) · 3 KB

API

<<<Back to Development Overview<<<

This page is under construction.

The hooks package of NCPCore contains two "managers" for different concepts to exempt players from checks.

  • NCPExemptionManager
    This is the simple way to just exempt a player from a check, then unexempt. The current implementation is meant to be used short-term rather. Different plugins using exemptions might easily conflict. There is a command to set exemptions manually as well (useful for faster testing). If a player is exempted from a check, the check will not be run at all (for virtually all cases).
  • NCPHookManager
    This allows to register "hooks" that get called in case of violations and allow to do more complex stuff ("after-failure" hooks: the check is run). Hooks are able to prevent further actions processing, you can also register "stats" hooks that come first or force your hook to be registered before other hooks by implementing an extra interface. Cancelling the actions processing will not reset violation levels(!). For some cases you can reset them manually, though that is not officially supported yet (Example: MovingData.getData(player).clearFlyData() ...clearMorePacketsData() ...survivalFlyVL = 0).

Moving/flying skills might work with adding velocity to the player - if not, please provide us with a moving trace: using a development build of NCP, setting moving.debug to true (hidden setting). The console spam is very useful to find bugs. A workaround can be to add velocity to the MovingData of a player for some special cases, but for ordinary things we prefer to get a bug report!

Take a look at the hooks packages of NoCheatPlus and CompatNoCheatPlus (/(/NCP modules changed with 3.9.2-RC-b520 !))


There are more spots that are accessible, but most are "not officially supported", such as ConfigurationManager, DataManager, ExecutionHistory. Some are designs of older times, some are more like refactoring stages (probably stuck in it slightly).

Some methods of the TickTask (utilities) might be useful.

Reloading the configuration can also be registered for:

  • NCPReloadEvent (commands.CommandHandler). Called after reload done.
  • You can register a component implementing INotifyReload (commands) to receive word of reloading the config just before the event is fired. This is also used by some checks and other components of NCP. These are cleared on reloading.

The plugin class itself does have some methods some of which could be of use, however we prefer you to use NCPAPIProvider.getNoCheatPlusAPI(), since we might separate some API from the plugin class itself, keeping the static API provider as long as possible (since 3.9.2-RC-b520 some static API has been moved to not-static, still implemented in the plugin class, should use NoCheatPlusAPI, though).