mirror of
https://github.com/PolyhedralDev/Terra.git
synced 2026-06-19 23:31:01 +00:00
implement reload and packs commands
This commit is contained in:
@@ -19,22 +19,22 @@ package com.dfsek.terra.addon;
|
|||||||
|
|
||||||
import ca.solostudios.strata.Versions;
|
import ca.solostudios.strata.Versions;
|
||||||
import ca.solostudios.strata.version.Version;
|
import ca.solostudios.strata.version.Version;
|
||||||
|
|
||||||
import cloud.commandframework.ArgumentDescription;
|
import cloud.commandframework.ArgumentDescription;
|
||||||
import cloud.commandframework.CommandManager;
|
import cloud.commandframework.CommandManager;
|
||||||
import cloud.commandframework.Description;
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
import cloud.commandframework.arguments.standard.StringArgument;
|
|
||||||
|
|
||||||
import com.dfsek.terra.api.Platform;
|
import com.dfsek.terra.api.Platform;
|
||||||
import com.dfsek.terra.api.addon.BaseAddon;
|
import com.dfsek.terra.api.addon.BaseAddon;
|
||||||
import com.dfsek.terra.api.command.RegistryArgument;
|
import com.dfsek.terra.api.command.RegistryArgument;
|
||||||
|
import com.dfsek.terra.api.config.ConfigPack;
|
||||||
import com.dfsek.terra.api.entity.CommandSender;
|
import com.dfsek.terra.api.entity.CommandSender;
|
||||||
import com.dfsek.terra.api.event.events.platform.CommandRegistrationEvent;
|
import com.dfsek.terra.api.event.events.platform.CommandRegistrationEvent;
|
||||||
import com.dfsek.terra.api.event.functional.FunctionalEventHandler;
|
import com.dfsek.terra.api.event.functional.FunctionalEventHandler;
|
||||||
|
|
||||||
|
|
||||||
public class InternalAddon implements BaseAddon {
|
public class InternalAddon implements BaseAddon {
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(InternalAddon.class);
|
||||||
private static final Version VERSION = Versions.getVersion(1, 0, 0);
|
private static final Version VERSION = Versions.getVersion(1, 0, 0);
|
||||||
|
|
||||||
public InternalAddon(Platform platform) {
|
public InternalAddon(Platform platform) {
|
||||||
@@ -49,15 +49,16 @@ public class InternalAddon implements BaseAddon {
|
|||||||
StringBuilder addons = new StringBuilder("Installed addons:\n");
|
StringBuilder addons = new StringBuilder("Installed addons:\n");
|
||||||
platform.getAddons()
|
platform.getAddons()
|
||||||
.forEach(addon -> addons
|
.forEach(addon -> addons
|
||||||
.append("- ")
|
.append(" - ")
|
||||||
.append(addon.getID())
|
.append(addon.getID())
|
||||||
.append('@')
|
.append('@')
|
||||||
.append(addon.getVersion().getFormatted())
|
.append(addon.getVersion().getFormatted())
|
||||||
.append('\n'));
|
.append('\n'));
|
||||||
context.getSender().sendMessage(addons.toString());
|
context.getSender().sendMessage(addons.toString());
|
||||||
})
|
})
|
||||||
);
|
)
|
||||||
manager.command(manager.commandBuilder("addons", ArgumentDescription.of("Get information about addons"))
|
.command(
|
||||||
|
manager.commandBuilder("addons")
|
||||||
.argument(RegistryArgument.of("addon", platform.getAddons()))
|
.argument(RegistryArgument.of("addon", platform.getAddons()))
|
||||||
.handler(context -> {
|
.handler(context -> {
|
||||||
BaseAddon addon = context.get("addon");
|
BaseAddon addon = context.get("addon");
|
||||||
@@ -74,7 +75,49 @@ public class InternalAddon implements BaseAddon {
|
|||||||
.append('\n'));
|
.append('\n'));
|
||||||
context.getSender().sendMessage(addonInfo.toString());
|
context.getSender().sendMessage(addonInfo.toString());
|
||||||
})
|
})
|
||||||
);
|
)
|
||||||
|
.command(manager.commandBuilder("packs", ArgumentDescription.of("List installed config packs"))
|
||||||
|
.handler(context -> {
|
||||||
|
StringBuilder packs = new StringBuilder("Installed packs:\n");
|
||||||
|
platform.getConfigRegistry().forEach(pack -> packs.append(" - ")
|
||||||
|
.append(pack.getID())
|
||||||
|
.append('@')
|
||||||
|
.append(pack.getVersion().getFormatted()));
|
||||||
|
context.getSender().sendMessage(packs.toString());
|
||||||
|
})
|
||||||
|
)
|
||||||
|
.command(manager.commandBuilder("packs")
|
||||||
|
.literal("info", ArgumentDescription.of("Get information about a pack"))
|
||||||
|
.argument(RegistryArgument.of("pack", platform.getConfigRegistry()))
|
||||||
|
.handler(context -> {
|
||||||
|
ConfigPack pack = context.get("pack");
|
||||||
|
StringBuilder packInfo = new StringBuilder("Pack ").append(pack.getID()).append('\n');
|
||||||
|
|
||||||
|
packInfo.append("Version: ").append(pack.getVersion().getFormatted()).append('\n');
|
||||||
|
packInfo.append("Author: ").append(pack.getAuthor()).append('\n');
|
||||||
|
|
||||||
|
packInfo.append("Addon Dependencies:\n");
|
||||||
|
pack.addons().forEach((id, versions) -> packInfo
|
||||||
|
.append(" - ")
|
||||||
|
.append(id.getID())
|
||||||
|
.append('@')
|
||||||
|
.append(versions.getFormatted())
|
||||||
|
.append('\n'));
|
||||||
|
context.getSender().sendMessage(packInfo.toString());
|
||||||
|
}))
|
||||||
|
.command(manager.commandBuilder("packs")
|
||||||
|
.literal("reload", ArgumentDescription.of("Reload config packs"))
|
||||||
|
.handler(context -> {
|
||||||
|
context.getSender().sendMessage("Reloading Terra...");
|
||||||
|
logger.info("Reloading Terra...");
|
||||||
|
if(platform.reload()) {
|
||||||
|
logger.info("Terra reloaded successfully.");
|
||||||
|
context.getSender().sendMessage("Terra reloaded successfully.");
|
||||||
|
} else {
|
||||||
|
logger.error("Terra failed to reload.");
|
||||||
|
context.getSender().sendMessage("Terra failed to reload. See logs for more information.");
|
||||||
|
}
|
||||||
|
}));
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user