Compare commits
2 Commits
054f39407d
...
afd95fd084
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
afd95fd084 | ||
|
|
6ac80610bf |
|
|
@ -2,7 +2,6 @@ import java.io.ByteArrayOutputStream
|
||||||
|
|
||||||
plugins {
|
plugins {
|
||||||
id("java")
|
id("java")
|
||||||
id("com.github.johnrengelman.shadow") version "7.1.0"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
group = "com.alttd"
|
group = "com.alttd"
|
||||||
|
|
@ -39,7 +38,7 @@ tasks {
|
||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
compileOnly("com.alttd.cosmos:cosmos-api:1.21.6-R0.1-SNAPSHOT") {
|
compileOnly("com.alttd.cosmos:cosmos-api:1.21.9-R0.1-SNAPSHOT") {
|
||||||
isChanging = true
|
isChanging = true
|
||||||
}
|
}
|
||||||
compileOnly("de.keyle:mypet:3.11-SNAPSHOT")
|
compileOnly("de.keyle:mypet:3.11-SNAPSHOT")
|
||||||
|
|
@ -49,11 +48,12 @@ dependencies {
|
||||||
}
|
}
|
||||||
|
|
||||||
fun gitCommit(): String {
|
fun gitCommit(): String {
|
||||||
val os = ByteArrayOutputStream()
|
// val os = ByteArrayOutputStream()
|
||||||
project.exec {
|
// project.exec {
|
||||||
isIgnoreExitValue = true
|
// isIgnoreExitValue = true
|
||||||
commandLine = "git rev-parse --short HEAD".split(" ")
|
// commandLine = "git rev-parse --short HEAD".split(" ")
|
||||||
standardOutput = os
|
// standardOutput = os
|
||||||
}
|
// }
|
||||||
return String(os.toByteArray()).trim()
|
// return String(os.toByteArray()).trim()
|
||||||
|
return "FIXME"
|
||||||
}
|
}
|
||||||
|
|
|
||||||
2
gradle/wrapper/gradle-wrapper.properties
vendored
2
gradle/wrapper/gradle-wrapper.properties
vendored
|
|
@ -1,5 +1,5 @@
|
||||||
distributionBase=GRADLE_USER_HOME
|
distributionBase=GRADLE_USER_HOME
|
||||||
distributionPath=wrapper/dists
|
distributionPath=wrapper/dists
|
||||||
distributionUrl=https\://services.gradle.org/distributions/gradle-7.5.1-bin.zip
|
distributionUrl=https\://services.gradle.org/distributions/gradle-9.0.0-bin.zip
|
||||||
zipStoreBase=GRADLE_USER_HOME
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
zipStorePath=wrapper/dists
|
zipStorePath=wrapper/dists
|
||||||
|
|
|
||||||
|
|
@ -8,12 +8,11 @@ dependencyResolutionManagement {
|
||||||
maven("https://repo.destro.xyz/snapshots") // Altitude - Galaxy
|
maven("https://repo.destro.xyz/snapshots") // Altitude - Galaxy
|
||||||
maven("https://repo.alttd.com/repository/alttd-snapshot/")
|
maven("https://repo.alttd.com/repository/alttd-snapshot/")
|
||||||
maven {
|
maven {
|
||||||
name = "nexus"
|
name = "AlttdNexus"
|
||||||
url = uri("https://repo.alttd.com/repository/alttd-snapshot/")
|
url = uri(
|
||||||
credentials {
|
"https://repo.alttd.com/repository/alttd-snapshot/"
|
||||||
username = providers.gradleProperty("alttdSnapshotUsername").get()
|
)
|
||||||
password = providers.gradleProperty("alttdSnapshotPassword").get()
|
credentials(PasswordCredentials::class)
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
|
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ import com.alttd.afkdectector.afkplayer.AFKPlayer;
|
||||||
import com.alttd.afkdectector.command.AFKCheckCommand;
|
import com.alttd.afkdectector.command.AFKCheckCommand;
|
||||||
import com.alttd.afkdectector.command.AFKListCommand;
|
import com.alttd.afkdectector.command.AFKListCommand;
|
||||||
import com.alttd.afkdectector.command.ReloadCommand;
|
import com.alttd.afkdectector.command.ReloadCommand;
|
||||||
|
import com.alttd.afkdectector.command.RelogCheckCommand;
|
||||||
import com.alttd.afkdectector.config.Config;
|
import com.alttd.afkdectector.config.Config;
|
||||||
import com.alttd.afkdectector.config.Messages;
|
import com.alttd.afkdectector.config.Messages;
|
||||||
import com.alttd.afkdectector.config.MessagesConfig;
|
import com.alttd.afkdectector.config.MessagesConfig;
|
||||||
|
|
@ -55,6 +56,7 @@ public class AFKDetector extends JavaPlugin implements Listener {
|
||||||
//getCommand("afk").setExecutor(new AFKCommand(this));
|
//getCommand("afk").setExecutor(new AFKCommand(this));
|
||||||
getCommand("afklist").setExecutor(new AFKListCommand(this));
|
getCommand("afklist").setExecutor(new AFKListCommand(this));
|
||||||
getCommand("afkcheck").setExecutor(new AFKCheckCommand(this));
|
getCommand("afkcheck").setExecutor(new AFKCheckCommand(this));
|
||||||
|
getCommand("relogcheck").setExecutor(new RelogCheckCommand(this));
|
||||||
getCommand("reloadafkdetector").setExecutor(new ReloadCommand(this));
|
getCommand("reloadafkdetector").setExecutor(new ReloadCommand(this));
|
||||||
new AFKCheckTimer(this).init();
|
new AFKCheckTimer(this).init();
|
||||||
myPetEnabled = getServer().getPluginManager().isPluginEnabled("MyPet");
|
myPetEnabled = getServer().getPluginManager().isPluginEnabled("MyPet");
|
||||||
|
|
|
||||||
65
src/main/java/com/alttd/afkdectector/command/RelogCheckCommand.java
Executable file
65
src/main/java/com/alttd/afkdectector/command/RelogCheckCommand.java
Executable file
|
|
@ -0,0 +1,65 @@
|
||||||
|
package com.alttd.afkdectector.command;
|
||||||
|
|
||||||
|
import com.alttd.afkdectector.AFKDetector;
|
||||||
|
import com.alttd.afkdectector.afkplayer.AFKPlayer;
|
||||||
|
import com.alttd.afkdectector.config.Messages;
|
||||||
|
import net.kyori.adventure.text.Component;
|
||||||
|
import net.kyori.adventure.text.format.NamedTextColor;
|
||||||
|
import net.kyori.adventure.text.minimessage.MiniMessage;
|
||||||
|
import net.kyori.adventure.title.Title;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.command.TabCompleter;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.player.PlayerCommandPreprocessEvent;
|
||||||
|
import org.bukkit.util.StringUtil;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
public class RelogCheckCommand implements CommandExecutor, TabCompleter {
|
||||||
|
|
||||||
|
private final AFKDetector plugin;
|
||||||
|
|
||||||
|
public RelogCheckCommand(AFKDetector plugin) {
|
||||||
|
this.plugin = plugin;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(@NotNull CommandSender sender, @NotNull Command command, @NotNull String label, String[] args) {
|
||||||
|
if (!(args.length > 0)) {
|
||||||
|
sender.sendMessage(Component.text(command.getUsage(), NamedTextColor.RED));
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
Player target = Bukkit.getPlayer(args[0]);
|
||||||
|
if (target == null) {
|
||||||
|
sender.sendMessage(Component.text(command.getUsage(), NamedTextColor.RED));
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
MiniMessage miniMessage = AFKDetector.miniMessage;
|
||||||
|
target.showTitle(Title.title(miniMessage.deserialize(Messages.RELOG_CHECK_TITLE.getMessage()),
|
||||||
|
miniMessage.deserialize(Messages.RELOG_CHECK_SUBTITLE.getMessage())));
|
||||||
|
if (sender instanceof Player player) {
|
||||||
|
String cmd = "msg " + args[0] + " " + Messages.RELOG_CHECK_MESSAGE.getMessage();
|
||||||
|
PlayerCommandPreprocessEvent commandEvent = new PlayerCommandPreprocessEvent(player, "/" + cmd);
|
||||||
|
Bukkit.getPluginManager().callEvent(commandEvent);
|
||||||
|
player.performCommand(cmd);
|
||||||
|
} else {
|
||||||
|
Bukkit.dispatchCommand(sender, "msg " + args[0] + " " + Messages.RELOG_CHECK_MESSAGE.getMessage());
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<String> onTabComplete(@NotNull CommandSender commandSender, @NotNull Command command, @NotNull String s, String[] strings) {
|
||||||
|
List<String> completions = new ArrayList<>();
|
||||||
|
if (strings.length == 1) {
|
||||||
|
StringUtil.copyPartialMatches(strings[0], plugin.players.values().stream().filter(AFKPlayer::isAFK).map(AFKPlayer::getPlayerName).collect(Collectors.toList()), completions);
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -19,6 +19,9 @@ public enum Messages {
|
||||||
AFK_CHECK_TITLE("afkcheck-title", "AFK CHECK"),
|
AFK_CHECK_TITLE("afkcheck-title", "AFK CHECK"),
|
||||||
AFK_CHECK_SUBTITLE("afkcheck-subtitle", "Please respond to the dm from staff!"),
|
AFK_CHECK_SUBTITLE("afkcheck-subtitle", "Please respond to the dm from staff!"),
|
||||||
AFK_CHECK_MESSAGE("afkcheck-message", "Hey, since you're near a farm and not moving. I'm making sure you aren't afk. Please respond to me if you're not AFK."),
|
AFK_CHECK_MESSAGE("afkcheck-message", "Hey, since you're near a farm and not moving. I'm making sure you aren't afk. Please respond to me if you're not AFK."),
|
||||||
|
RELOG_CHECK_TITLE("relogcheck-title", "AFK CHECK"),
|
||||||
|
RELOG_CHECK_SUBTITLE("relogcheck-subtitle", "Please respond to the dm from staff!"),
|
||||||
|
RELOG_CHECK_MESSAGE("relogcheck-message", "Hey, since you're near a farm and not moving. I'm making sure you aren't afk. Please respond to me if you're not AFK."),
|
||||||
AFK_KICK_STAFF_MESSAGE("afkkick-staff-messsge", "<gold><player> got afk kicked after being afk for <afk_time> minutes."),
|
AFK_KICK_STAFF_MESSAGE("afkkick-staff-messsge", "<gold><player> got afk kicked after being afk for <afk_time> minutes."),
|
||||||
SUSPICIOUS_KICK_COUNT("afkkick-suspicious-message", "<gold><player> has had <count> suspicious AFK kicks since last reboot."),
|
SUSPICIOUS_KICK_COUNT("afkkick-suspicious-message", "<gold><player> has had <count> suspicious AFK kicks since last reboot."),
|
||||||
AFK_SOON_BOSS_BAR("afk-soon-boss-bar", "<dark_aqua>Time until AFK.</dark_aqua>"),
|
AFK_SOON_BOSS_BAR("afk-soon-boss-bar", "<dark_aqua>Time until AFK.</dark_aqua>"),
|
||||||
|
|
|
||||||
|
|
@ -19,6 +19,11 @@ commands:
|
||||||
permission: afkdetector.afkcheck
|
permission: afkdetector.afkcheck
|
||||||
permission-message: You do not have permission!
|
permission-message: You do not have permission!
|
||||||
usage: /afkcheck <target>
|
usage: /afkcheck <target>
|
||||||
|
relogcheck:
|
||||||
|
description: Sends and relogcheck message to the target
|
||||||
|
permission: afkdetector.relogcheck
|
||||||
|
permission-message: You do not have permission!
|
||||||
|
usage: /relogcheck <target>
|
||||||
reloadafkdetector:
|
reloadafkdetector:
|
||||||
description: Reloads the plugin config
|
description: Reloads the plugin config
|
||||||
permission: afkdetector.reload
|
permission: afkdetector.reload
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user