1.2.0: Remove unnecessary events, use yml as a config, implement log disabling

This commit is contained in:
2025-11-25 23:10:57 +08:00
parent eabb5a69c1
commit 02f73ad13e
13 changed files with 193 additions and 140 deletions
+1 -1
View File
@@ -1,6 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<project version="4"> <project version="4">
<component name="CompilerConfiguration"> <component name="CompilerConfiguration">
<bytecodeTargetLevel target="18" /> <bytecodeTargetLevel target="17" />
</component> </component>
</project> </project>
+1 -1
View File
@@ -6,5 +6,5 @@
</list> </list>
</component> </component>
<component name="ExternalStorageConfigurationManager" enabled="true" /> <component name="ExternalStorageConfigurationManager" enabled="true" />
<component name="ProjectRootManager" version="2" languageLevel="JDK_18" default="true" project-jdk-name="17" project-jdk-type="JavaSDK" /> <component name="ProjectRootManager" version="2" languageLevel="JDK_17" default="true" project-jdk-name="17" project-jdk-type="JavaSDK" />
</project> </project>
-8
View File
@@ -1,8 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectModuleManager">
<modules>
<module fileurl="file://$PROJECT_DIR$/.idea/modules/notifyonstart.main.iml" filepath="$PROJECT_DIR$/.idea/modules/notifyonstart.main.iml" />
</modules>
</component>
</project>
+59 -20
View File
@@ -4,7 +4,21 @@
<option name="autoReloadType" value="SELECTIVE" /> <option name="autoReloadType" value="SELECTIVE" />
</component> </component>
<component name="ChangeListManager"> <component name="ChangeListManager">
<list default="true" id="ce97b9f5-6785-4670-b350-12f90ab9ea27" name="Changes" comment="dunno if it works (2)" /> <list default="true" id="ce97b9f5-6785-4670-b350-12f90ab9ea27" name="Changes" comment="1.2.0: Remove unnecessary events, use yml as a config">
<change beforePath="$PROJECT_DIR$/.idea/compiler.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/compiler.xml" afterDir="false" />
<change beforePath="$PROJECT_DIR$/.idea/misc.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/misc.xml" afterDir="false" />
<change beforePath="$PROJECT_DIR$/.idea/modules.xml" beforeDir="false" />
<change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
<change beforePath="$PROJECT_DIR$/src/main/java/moe/sob/events/player/PlayerBedEnter.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/main/java/moe/sob/events/player/PlayerBedEnter.java" afterDir="false" />
<change beforePath="$PROJECT_DIR$/src/main/java/moe/sob/events/player/PlayerBedLeave.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/main/java/moe/sob/events/player/PlayerBedLeave.java" afterDir="false" />
<change beforePath="$PROJECT_DIR$/src/main/java/moe/sob/events/player/PlayerChat.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/main/java/moe/sob/events/player/PlayerChat.java" afterDir="false" />
<change beforePath="$PROJECT_DIR$/src/main/java/moe/sob/events/player/PlayerCommandPreprocess.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/main/java/moe/sob/events/player/PlayerCommandPreprocess.java" afterDir="false" />
<change beforePath="$PROJECT_DIR$/src/main/java/moe/sob/events/player/PlayerJoin.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/main/java/moe/sob/events/player/PlayerJoin.java" afterDir="false" />
<change beforePath="$PROJECT_DIR$/src/main/java/moe/sob/events/player/PlayerQuit.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/main/java/moe/sob/events/player/PlayerQuit.java" afterDir="false" />
<change beforePath="$PROJECT_DIR$/src/main/java/moe/sob/events/world/WorldLoad.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/main/java/moe/sob/events/world/WorldLoad.java" afterDir="false" />
<change beforePath="$PROJECT_DIR$/src/main/java/moe/sob/events/world/WorldUnload.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/main/java/moe/sob/events/world/WorldUnload.java" afterDir="false" />
<change beforePath="$PROJECT_DIR$/src/main/resources/plugin.yml" beforeDir="false" afterPath="$PROJECT_DIR$/src/main/resources/plugin.yml" afterDir="false" />
</list>
<option name="SHOW_DIALOG" value="false" /> <option name="SHOW_DIALOG" value="false" />
<option name="HIGHLIGHT_CONFLICTS" value="true" /> <option name="HIGHLIGHT_CONFLICTS" value="true" />
<option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" /> <option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
@@ -46,24 +60,29 @@
<option name="hideEmptyMiddlePackages" value="true" /> <option name="hideEmptyMiddlePackages" value="true" />
<option name="showLibraryContents" value="true" /> <option name="showLibraryContents" value="true" />
</component> </component>
<component name="PropertiesComponent"><![CDATA[{ <component name="PropertiesComponent">{
"keyToString": { &quot;keyToString&quot;: {
"Downloaded.Files.Path.Enabled": "false", &quot;Downloaded.Files.Path.Enabled&quot;: &quot;false&quot;,
"Gradle.notify-on-start [build].executor": "Run", &quot;Gradle.notify-on-start [build].executor&quot;: &quot;Run&quot;,
"Repository.Attach.Annotations": "false", &quot;Repository.Attach.Annotations&quot;: &quot;false&quot;,
"Repository.Attach.JavaDocs": "false", &quot;Repository.Attach.JavaDocs&quot;: &quot;false&quot;,
"Repository.Attach.Sources": "false", &quot;Repository.Attach.Sources&quot;: &quot;false&quot;,
"RunOnceActivity.OpenProjectViewOnStart": "true", &quot;RunOnceActivity.OpenProjectViewOnStart&quot;: &quot;true&quot;,
"RunOnceActivity.ShowReadmeOnStart": "true", &quot;RunOnceActivity.ShowReadmeOnStart&quot;: &quot;true&quot;,
"RunOnceActivity.git.unshallow": "true", &quot;RunOnceActivity.git.unshallow&quot;: &quot;true&quot;,
"git-widget-placeholder": "main", &quot;git-widget-placeholder&quot;: &quot;main&quot;,
"last_opened_file_path": "G:/java/notify-on-start", &quot;last_opened_file_path&quot;: &quot;G:/java/notify-on-start&quot;,
"project.structure.last.edited": "Libraries", &quot;project.structure.last.edited&quot;: &quot;Libraries&quot;,
"project.structure.proportion": "0.0", &quot;project.structure.proportion&quot;: &quot;0.0&quot;,
"project.structure.side.proportion": "0.2", &quot;project.structure.side.proportion&quot;: &quot;0.2&quot;,
"settings.editor.selected.configurable": "reference.settingsdialog.project.gradle" &quot;settings.editor.selected.configurable&quot;: &quot;reference.settingsdialog.project.gradle&quot;
} }
}]]></component> }</component>
<component name="RecentsManager">
<key name="CopyClassDialog.RECENTS_KEY">
<recent name="moe.sob.commands" />
</key>
</component>
<component name="RunManager" selected="Gradle.notify-on-start [build]"> <component name="RunManager" selected="Gradle.notify-on-start [build]">
<configuration name="notify-on-start [build]" type="GradleRunConfiguration" factoryName="Gradle" nameIsGenerated="true"> <configuration name="notify-on-start [build]" type="GradleRunConfiguration" factoryName="Gradle" nameIsGenerated="true">
<ExternalSystemSettings> <ExternalSystemSettings>
@@ -177,15 +196,35 @@
<option name="project" value="LOCAL" /> <option name="project" value="LOCAL" />
<updated>1699768015200</updated> <updated>1699768015200</updated>
</task> </task>
<option name="localTasksCounter" value="6" /> <task id="LOCAL-00006" summary="1.2.0: Remove unnecessary events, use yml as a config">
<option name="closed" value="true" />
<created>1760533930115</created>
<option name="number" value="00006" />
<option name="presentableId" value="LOCAL-00006" />
<option name="project" value="LOCAL" />
<updated>1760533930115</updated>
</task>
<option name="localTasksCounter" value="7" />
<servers /> <servers />
</component> </component>
<component name="Vcs.Log.Tabs.Properties">
<option name="TAB_STATES">
<map>
<entry key="MAIN">
<value>
<State />
</value>
</entry>
</map>
</option>
</component>
<component name="VcsManagerConfiguration"> <component name="VcsManagerConfiguration">
<MESSAGE value="hmmm" /> <MESSAGE value="hmmm" />
<MESSAGE value="fix stuff and add more functionality (definitely) (hi again)" /> <MESSAGE value="fix stuff and add more functionality (definitely) (hi again)" />
<MESSAGE value="wrong version number" /> <MESSAGE value="wrong version number" />
<MESSAGE value="dunno if it works" /> <MESSAGE value="dunno if it works" />
<MESSAGE value="dunno if it works (2)" /> <MESSAGE value="dunno if it works (2)" />
<option name="LAST_COMMIT_MESSAGE" value="dunno if it works (2)" /> <MESSAGE value="1.2.0: Remove unnecessary events, use yml as a config" />
<option name="LAST_COMMIT_MESSAGE" value="1.2.0: Remove unnecessary events, use yml as a config" />
</component> </component>
</project> </project>
@@ -1,6 +1,7 @@
package moe.sob.events.player; package moe.sob.events.player;
import moe.sob.DiscordWebhook; import moe.sob.DiscordWebhook;
import moe.sob.Main;
import moe.sob.ServerUtils; import moe.sob.ServerUtils;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
@@ -15,18 +16,20 @@ import java.util.Date;
public class PlayerBedEnter implements Listener { public class PlayerBedEnter implements Listener {
@EventHandler @EventHandler
public void onPlayerBedEnter(PlayerBedEnterEvent event) { public void onPlayerBedEnter(PlayerBedEnterEvent event) {
Bukkit.getConsoleSender().sendMessage("Player entered a bed."); if (Main.configR.getBoolean("log")) {
Player player = event.getPlayer(); Bukkit.getConsoleSender().sendMessage("Player entered a bed.");
DiscordWebhook notify = new DiscordWebhook(ServerUtils.webhook_notify); Player player = event.getPlayer();
DiscordWebhook.EmbedObject embedObject = new DiscordWebhook.EmbedObject().setTitle(player.getName() + " is now sleeping...") DiscordWebhook notify = new DiscordWebhook(ServerUtils.webhook_notify);
.addField("Time", new Date().toString(), false) DiscordWebhook.EmbedObject embedObject = new DiscordWebhook.EmbedObject().setTitle(player.getName() + " is now sleeping...")
.addField("Player name", player.getName(), true) .addField("Time", new Date().toString(), false)
.setColor(Color.BLUE); .addField("Player name", player.getName(), true)
notify.addEmbed(embedObject); .setColor(Color.BLUE);
try { notify.addEmbed(embedObject);
notify.execute(); try {
} catch (IOException e) { notify.execute();
throw new RuntimeException(e); } catch (IOException e) {
throw new RuntimeException(e);
}
} }
} }
} }
@@ -1,6 +1,7 @@
package moe.sob.events.player; package moe.sob.events.player;
import moe.sob.DiscordWebhook; import moe.sob.DiscordWebhook;
import moe.sob.Main;
import moe.sob.ServerUtils; import moe.sob.ServerUtils;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
@@ -15,18 +16,20 @@ import java.util.Date;
public class PlayerBedLeave implements Listener { public class PlayerBedLeave implements Listener {
@EventHandler @EventHandler
public void onPlayerBedLeave(PlayerBedLeaveEvent event) { public void onPlayerBedLeave(PlayerBedLeaveEvent event) {
Bukkit.getConsoleSender().sendMessage("Player left a bed"); if (Main.configR.getBoolean("log")) {
Player player = event.getPlayer(); Bukkit.getConsoleSender().sendMessage("Player left a bed");
DiscordWebhook notify = new DiscordWebhook(ServerUtils.webhook_notify); Player player = event.getPlayer();
DiscordWebhook.EmbedObject embedObject = new DiscordWebhook.EmbedObject().setTitle(player.getName() + " is no longer sleeping.") DiscordWebhook notify = new DiscordWebhook(ServerUtils.webhook_notify);
.addField("Time", new Date().toString(), false) DiscordWebhook.EmbedObject embedObject = new DiscordWebhook.EmbedObject().setTitle(player.getName() + " is no longer sleeping.")
.addField("Player name", player.getName(), true) .addField("Time", new Date().toString(), false)
.setColor(Color.BLUE); .addField("Player name", player.getName(), true)
notify.addEmbed(embedObject); .setColor(Color.BLUE);
try { notify.addEmbed(embedObject);
notify.execute(); try {
} catch (IOException e) { notify.execute();
throw new RuntimeException(e); } catch (IOException e) {
throw new RuntimeException(e);
}
} }
} }
} }
@@ -1,6 +1,7 @@
package moe.sob.events.player; package moe.sob.events.player;
import moe.sob.DiscordWebhook; import moe.sob.DiscordWebhook;
import moe.sob.Main;
import moe.sob.ServerUtils; import moe.sob.ServerUtils;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
@@ -18,18 +19,19 @@ public class PlayerChat implements Listener {
@EventHandler @EventHandler
public void onPlayerChat(AsyncPlayerChatEvent event) { public void onPlayerChat(AsyncPlayerChatEvent event) {
Bukkit.getConsoleSender().sendMessage("A message was sent by " + event.getPlayer().getName()); // Bukkit.getConsoleSender().sendMessage("A message was sent by " + event.getPlayer().getName()); // kind of redundant considering the fact that we see chats in the console too
Player player = event.getPlayer(); if (!Main.configR.getBoolean("log")) {
DiscordWebhook notify = new DiscordWebhook(ServerUtils.webhook_notify); DiscordWebhook notify = new DiscordWebhook(ServerUtils.webhook_notify);
DiscordWebhook.EmbedObject embedObject = new DiscordWebhook.EmbedObject().setTitle("A message was sent by " + event.getPlayer().getName()) DiscordWebhook.EmbedObject embedObject = new DiscordWebhook.EmbedObject().setTitle("A message was sent by " + event.getPlayer().getName())
.addField("Send date", new Date().toString(), false) .addField("Send date", new Date().toString(), false)
.addField("Message content", event.getMessage(), true) .addField("Message content", event.getMessage(), true)
.setColor(Color.BLUE); .setColor(Color.BLUE);
notify.addEmbed(embedObject); notify.addEmbed(embedObject);
try { try {
notify.execute(); notify.execute();
} catch (IOException e) { } catch (IOException e) {
throw new RuntimeException(e); throw new RuntimeException(e);
}
} }
} }
} }
@@ -1,6 +1,7 @@
package moe.sob.events.player; package moe.sob.events.player;
import moe.sob.DiscordWebhook; import moe.sob.DiscordWebhook;
import moe.sob.Main;
import moe.sob.ServerUtils; import moe.sob.ServerUtils;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
@@ -16,36 +17,38 @@ import java.util.Date;
public class PlayerCommandPreprocess implements Listener { public class PlayerCommandPreprocess implements Listener {
@EventHandler @EventHandler
public void onPlayerCommandPreprocess(PlayerCommandPreprocessEvent event) { public void onPlayerCommandPreprocess(PlayerCommandPreprocessEvent event) {
Bukkit.getConsoleSender().sendMessage("%s used a command".formatted(event.getPlayer().getName())); if (Main.configR.getBoolean("log")) {
Player player = event.getPlayer(); Bukkit.getConsoleSender().sendMessage("%s used a command".formatted(event.getPlayer().getName()));
String[] command = event.getMessage().split(" "); // get the command name Player player = event.getPlayer();
DiscordWebhook notify = new DiscordWebhook(ServerUtils.webhook_notify); String[] command = event.getMessage().split(" "); // get the command name
DiscordWebhook.EmbedObject embedObject = new DiscordWebhook.EmbedObject().setTitle("Command used") DiscordWebhook notify = new DiscordWebhook(ServerUtils.webhook_notify);
.addField("Date of usage", new Date().toString(), false) DiscordWebhook.EmbedObject embedObject = new DiscordWebhook.EmbedObject().setTitle("Command used")
.addField("Player name", player.getName(), false) .addField("Date of usage", new Date().toString(), false)
.addField("Command", command[0], true) .addField("Player name", player.getName(), false)
.setColor(Color.BLUE); .addField("Command", command[0], true)
notify.addEmbed(embedObject); .setColor(Color.BLUE);
try { notify.addEmbed(embedObject);
notify.execute();
} catch (IOException e) {
throw new RuntimeException(e);
}
// temp: log on /stop
if (command[0].equals("/stop")) {
DiscordWebhook ntf = new DiscordWebhook(ServerUtils.webhook_notify);
DiscordWebhook.EmbedObject embed = new DiscordWebhook.EmbedObject()
.setTitle("Server stopped")
.setDescription("The server was stopped using the `/stop` command.")
.addField("Date", "<t:%n:R>".formatted(new Timestamp(System.currentTimeMillis()).getTime()), true)
.addField("Player name", player.getName(), true);
ntf.addEmbed(embed);
try { try {
ntf.execute(); notify.execute();
} catch (IOException e) { } catch (IOException e) {
throw new RuntimeException(e); throw new RuntimeException(e);
} }
// temp: log on /stop
if (command[0].equals("/stop")) {
DiscordWebhook ntf = new DiscordWebhook(ServerUtils.webhook_notify);
DiscordWebhook.EmbedObject embed = new DiscordWebhook.EmbedObject()
.setTitle("Server stopped")
.setDescription("The server was stopped using the `/stop` command.")
.addField("Date", "<t:%n:R>".formatted(new Timestamp(System.currentTimeMillis()).getTime()), true)
.addField("Player name", player.getName(), true);
ntf.addEmbed(embed);
try {
ntf.execute();
} catch (IOException e) {
throw new RuntimeException(e);
}
}
} }
} }
} }
@@ -17,19 +17,21 @@ import java.util.Date;
public class PlayerJoin implements Listener { public class PlayerJoin implements Listener {
@EventHandler @EventHandler
public void onPlayerJoin(PlayerJoinEvent event) { public void onPlayerJoin(PlayerJoinEvent event) {
Bukkit.getConsoleSender().sendMessage("A player has joined the server."); if (Main.configR.getBoolean("log")) {
Player player = event.getPlayer(); Bukkit.getConsoleSender().sendMessage("A player has joined the server.");
DiscordWebhook notify = new DiscordWebhook(ServerUtils.webhook_notify); Player player = event.getPlayer();
DiscordWebhook.EmbedObject embedObject = new DiscordWebhook.EmbedObject().setTitle("A player has joined the server.") DiscordWebhook notify = new DiscordWebhook(ServerUtils.webhook_notify);
.addField("Triggered at", new Date().toString(), false) DiscordWebhook.EmbedObject embedObject = new DiscordWebhook.EmbedObject().setTitle("A player has joined the server.")
.addField("Player name", player.getName(), true) .addField("Triggered at", new Date().toString(), false)
.setColor(Color.BLUE); .addField("Player name", player.getName(), true)
notify.addEmbed(embedObject); .setColor(Color.BLUE);
try { notify.addEmbed(embedObject);
Bukkit.broadcastMessage(Main.getGreetMessage(player)); try {
notify.execute(); Bukkit.broadcastMessage(Main.getGreetMessage(player));
} catch (IOException e) { notify.execute();
throw new RuntimeException(e); } catch (IOException e) {
throw new RuntimeException(e);
}
} }
} }
} }
@@ -1,6 +1,7 @@
package moe.sob.events.player; package moe.sob.events.player;
import moe.sob.DiscordWebhook; import moe.sob.DiscordWebhook;
import moe.sob.Main;
import moe.sob.ServerUtils; import moe.sob.ServerUtils;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
@@ -14,18 +15,20 @@ import java.util.Date;
public class PlayerQuit implements Listener { public class PlayerQuit implements Listener {
@EventHandler @EventHandler
public void onPlayerQuit(PlayerQuitEvent event) { public void onPlayerQuit(PlayerQuitEvent event) {
Bukkit.getConsoleSender().sendMessage("A player has left the server."); if (Main.configR.getBoolean("log")) {
Player player = event.getPlayer(); Bukkit.getConsoleSender().sendMessage("A player has left the server.");
DiscordWebhook.EmbedObject embedObject = new DiscordWebhook.EmbedObject().setTitle("A player has left the server.") Player player = event.getPlayer();
.addField("Date of exit", new Date().toString(), false) DiscordWebhook.EmbedObject embedObject = new DiscordWebhook.EmbedObject().setTitle("A player has left the server.")
.addField("Player name", event.getPlayer().getName(), true) .addField("Date of exit", new Date().toString(), false)
.setColor(Color.BLUE); .addField("Player name", event.getPlayer().getName(), true)
DiscordWebhook notify = new DiscordWebhook(ServerUtils.webhook_notify); .setColor(Color.BLUE);
notify.addEmbed(embedObject); DiscordWebhook notify = new DiscordWebhook(ServerUtils.webhook_notify);
try { notify.addEmbed(embedObject);
notify.execute(); try {
} catch (IOException e) { notify.execute();
throw new RuntimeException(e); } catch (IOException e) {
throw new RuntimeException(e);
}
} }
} }
} }
@@ -1,6 +1,7 @@
package moe.sob.events.world; package moe.sob.events.world;
import moe.sob.DiscordWebhook; import moe.sob.DiscordWebhook;
import moe.sob.Main;
import moe.sob.ServerUtils; import moe.sob.ServerUtils;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.event.EventHandler; import org.bukkit.event.EventHandler;
@@ -14,17 +15,19 @@ import java.util.Date;
public class WorldLoad implements Listener { public class WorldLoad implements Listener {
@EventHandler @EventHandler
public void onWorldLoad(WorldLoadEvent event) { public void onWorldLoad(WorldLoadEvent event) {
Bukkit.getConsoleSender().sendMessage("Triggered WorldLoad event."); if (Main.configR.getBoolean("log")) {
DiscordWebhook notify = new DiscordWebhook(ServerUtils.webhook_notify); Bukkit.getConsoleSender().sendMessage("Triggered WorldLoad event.");
DiscordWebhook.EmbedObject embedObject = new DiscordWebhook.EmbedObject().setTitle("World loaded") DiscordWebhook notify = new DiscordWebhook(ServerUtils.webhook_notify);
.addField("Time", new Date().toString(), false) DiscordWebhook.EmbedObject embedObject = new DiscordWebhook.EmbedObject().setTitle("World loaded")
.addField("World name", event.getWorld().getName(), true) .addField("Time", new Date().toString(), false)
.setColor(Color.BLUE); .addField("World name", event.getWorld().getName(), true)
notify.addEmbed(embedObject); .setColor(Color.BLUE);
try { notify.addEmbed(embedObject);
notify.execute(); try {
} catch (IOException e) { notify.execute();
throw new RuntimeException(e); } catch (IOException e) {
throw new RuntimeException(e);
}
} }
} }
} }
@@ -1,6 +1,7 @@
package moe.sob.events.world; package moe.sob.events.world;
import moe.sob.DiscordWebhook; import moe.sob.DiscordWebhook;
import moe.sob.Main;
import moe.sob.ServerUtils; import moe.sob.ServerUtils;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.event.EventHandler; import org.bukkit.event.EventHandler;
@@ -14,17 +15,19 @@ import java.util.Date;
public class WorldUnload implements Listener { public class WorldUnload implements Listener {
@EventHandler @EventHandler
public void onWorldUnload(WorldUnloadEvent event) { public void onWorldUnload(WorldUnloadEvent event) {
Bukkit.getConsoleSender().sendMessage("Triggered WorldUnload event."); if (Main.configR.getBoolean("log")) {
DiscordWebhook notify = new DiscordWebhook(ServerUtils.webhook_notify); Bukkit.getConsoleSender().sendMessage("Triggered WorldUnload event.");
DiscordWebhook.EmbedObject embedObject = new DiscordWebhook.EmbedObject().setTitle("WorldUnload").setDescription("A world was unloaded...") DiscordWebhook notify = new DiscordWebhook(ServerUtils.webhook_notify);
.addField("Time", new Date().toString(), false) DiscordWebhook.EmbedObject embedObject = new DiscordWebhook.EmbedObject().setTitle("WorldUnload").setDescription("A world was unloaded...")
.addField("World name", event.getWorld().getName(), true) .addField("Time", new Date().toString(), false)
.setColor(Color.BLUE); .addField("World name", event.getWorld().getName(), true)
notify.addEmbed(embedObject); .setColor(Color.BLUE);
try { notify.addEmbed(embedObject);
notify.execute(); try {
} catch (IOException e) { notify.execute();
throw new RuntimeException(e); } catch (IOException e) {
throw new RuntimeException(e);
}
} }
} }
} }
+1 -1
View File
@@ -14,7 +14,7 @@ commands:
usage: /send-message <message> usage: /send-message <message>
aliases: [sms] aliases: [sms]
set-logging: set-logging:
description: Enables or disables event logging in the server. Server performance is enhanced while logs are disabled. (Depending on server speed) description: Enables or disables event logging. Server performance is enhanced while logs are disabled. (Depending on server speed)
usage: /set-logging <true|false> usage: /set-logging <true|false>
permission: op permission: op
permission-message: Only operators can use this command. permission-message: Only operators can use this command.