-
-
Notifications
You must be signed in to change notification settings - Fork 45
API
The HuskTowns API provides methods for interfacing and editing towns, claims and users, alongside a selection of API events for listening to when players perform certain town actions.
The HuskTowns API shares version numbering with the plugin itself for consistency and convenience. Please note minor and patch plugin releases may make API additions and deprecations, but will not introduce breaking changes without notice.
API Version | HuskTowns Versions | Supported |
---|---|---|
v3.x | v3.0—Current | ✅ |
v2.x | v2.0—v2.3.1 | ❌ |
v1.x | v1.0—v2.3.1 | ❌ |
Note: For versions older than
v3.0
, the HuskTowns API was only distributed for the Bukkit platform (asnet.william278:husktowns
)
The HuskTowns API is available for the following platforms:
-
bukkit
- Bukkit, Spigot, Paper, etc. Provides Bukkit API event listeners and adapters toorg.bukkit
objects. -
common
- Common API for all platforms.
Targeting older versions
- The HuskTowns API was only distributed for the Bukkit module prior to
v3.0
; the artifact ID wasnet.william278:husktowns
instead ofnet.william278.husktowns:husktowns-PLATFORM
. - HuskTowns versions prior to
v2.3.1
are distributed on JitPack, and you will need to use thehttps://jitpack.io
repository instead.
- API Introduction
- Creating a class to interface with the API
- Checking if HuskTowns is present and creating the hook
- Getting an instance of the API
- CompletableFuture and Optional basics
- Next steps
Maven setup information
Add the repository to your pom.xml
as per below. You can alternatively specify /snapshots
for the repository containing the latest development builds (not recommended).
<repositories>
<repository>
<id>william278.net</id>
<url>https://repo.william278.net/releases</url>
</repository>
</repositories>
Add the dependency to your pom.xml
as per below. Replace VERSION
with the latest version of HuskTowns (without the v):
<dependency>
<groupId>net.william278.husktowns</groupId>
<artifactId>husktowns-PLATFORM</artifactId>
<version>VERSION</version>
<scope>provided</scope>
</dependency>
Gradle setup information
Add the dependency as per below to your build.gradle
. You can alternatively specify /snapshots
for the repository containing the latest development builds (not recommended).
allprojects {
repositories {
maven { url 'https://repo.william278.net/releases' }
}
}
Add the dependency as per below. Replace VERSION
with the latest version of HuskTowns (without the v):
dependencies {
compileOnly 'net.william278.husktowns:husktowns-PLATFORM:VERSION'
}
Add HuskTowns to your softdepend
(if you want to optionally use HuskTowns) or depend
(if your plugin relies on HuskTowns) section in plugin.yml
of your project.
name: MyPlugin
version: 1.0
main: net.william278.myplugin.MyPlugin
author: William278
description: 'A plugin that hooks with the HuskTowns API!'
softdepend: # Or, use 'depend' here
- HuskTowns
- Unless your plugin completely relies on HuskTowns, you shouldn't put HuskTowns API calls into your main class, otherwise if HuskTowns is not installed you'll encounter
ClassNotFoundException
s
public class HuskTownsAPIHook {
public HuskTownsAPIHook() {
// Ready to do stuff with the API
}
}
- Check to make sure the HuskTowns plugin is present before instantiating the API hook class
public class MyPlugin extends JavaPlugin {
public HuskTownsAPIHook huskTownsAPIHook;
@Override
public void onEnable() {
if (Bukkit.getPluginManager().getPlugin("HuskTowns") != null) {
this.huskTownsAPIHook = new HuskTownsAPIHook();
}
}
}
- You can now get the API instance by calling
HuskTownsAPI#getInstance()
- If targeting the Bukkit platform, you can also use
BukkitHuskTownsAPI#getBukkitInstance()
to get the Bukkit-extended API instance (recommended)
import net.william278.husktowns.api.HuskTownsAPI;
public class HuskTownsAPIHook {
private final HuskTownsAPI huskTownsAPI;
public HuskTownsAPIHook() {
this.huskTownsAPI = HuskTownsAPI.getInstance();
}
}
- HuskTowns API methods often deal with
CompletableFuture
s andOptional
s. - A
CompletableFuture
is an asynchronous callback mechanism. The method will be processed asynchronously and the data returned when it has been retrieved. Then, useCompletableFuture#thenAccept(data -> {})
to do what you want to do with thedata
you requested after it has asynchronously been retrieved, to prevent lag. - An
Optional
is a null-safe representation of data, or no data. You can check if the Optional is empty viaOptional#isEmpty()
(which will be returned by the API if no data could be found for the call you made). If the optional does contain data, you can get it via `Optional#get().
Warning: You should never call
#join()
on futures returned from the HuskTownsAPI as futures are processed on server asynchronous tasks, which could lead to thread deadlock and crash your server if you attempt to lock the main thread to process them.
Now that you've got everything ready, you can start doing stuff with the HuskTowns API!
This documentation is available via william278.net |
---|
- 📚 Setup
- 📦 Legacy Migration
- 📁 Database
- ⛅ Redis Support
- 📄 Config Files
- 📝 Translations
- 🔌 Hooks
- 🖥️ Commands
- 🏙️ Towns
- 🏠 Claims
- 🔨 Roles
- 🌟 Advancements
- ☯️ Relations
- ⚔️ Wars
- 🚫 Inactive Town Pruning
- 📦 API v3
- 🧡 Towns API
- ⚙️ Claims API
- ❗ API Events
- 🕸️ API v1 (Legacy)