mirror of
https://github.com/EssentialsX/Essentials.git
synced 2025-01-05 07:57:59 +01:00
parent
6f20a789f9
commit
14c2ab5ddd
@ -49,6 +49,7 @@ import net.ess3.api.IJails;
|
|||||||
import net.ess3.api.ISettings;
|
import net.ess3.api.ISettings;
|
||||||
import net.ess3.nms.refl.providers.ReflFormattedCommandAliasProvider;
|
import net.ess3.nms.refl.providers.ReflFormattedCommandAliasProvider;
|
||||||
import net.ess3.nms.refl.providers.ReflKnownCommandsProvider;
|
import net.ess3.nms.refl.providers.ReflKnownCommandsProvider;
|
||||||
|
import net.ess3.nms.refl.providers.ReflOnlineModeProvider;
|
||||||
import net.ess3.nms.refl.providers.ReflPersistentDataProvider;
|
import net.ess3.nms.refl.providers.ReflPersistentDataProvider;
|
||||||
import net.ess3.nms.refl.providers.ReflServerStateProvider;
|
import net.ess3.nms.refl.providers.ReflServerStateProvider;
|
||||||
import net.ess3.nms.refl.providers.ReflSpawnEggProvider;
|
import net.ess3.nms.refl.providers.ReflSpawnEggProvider;
|
||||||
@ -165,6 +166,7 @@ public class Essentials extends JavaPlugin implements net.ess3.api.IEssentials {
|
|||||||
private transient MaterialTagProvider materialTagProvider;
|
private transient MaterialTagProvider materialTagProvider;
|
||||||
private transient SyncCommandsProvider syncCommandsProvider;
|
private transient SyncCommandsProvider syncCommandsProvider;
|
||||||
private transient PersistentDataProvider persistentDataProvider;
|
private transient PersistentDataProvider persistentDataProvider;
|
||||||
|
private transient ReflOnlineModeProvider onlineModeProvider;
|
||||||
private transient Kits kits;
|
private transient Kits kits;
|
||||||
private transient RandomTeleport randomTeleport;
|
private transient RandomTeleport randomTeleport;
|
||||||
private transient UpdateChecker updateChecker;
|
private transient UpdateChecker updateChecker;
|
||||||
@ -406,6 +408,8 @@ public class Essentials extends JavaPlugin implements net.ess3.api.IEssentials {
|
|||||||
persistentDataProvider = new ReflPersistentDataProvider(this);
|
persistentDataProvider = new ReflPersistentDataProvider(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
onlineModeProvider = new ReflOnlineModeProvider();
|
||||||
|
|
||||||
execTimer.mark("Init(Providers)");
|
execTimer.mark("Init(Providers)");
|
||||||
reload();
|
reload();
|
||||||
|
|
||||||
@ -1260,6 +1264,11 @@ public class Essentials extends JavaPlugin implements net.ess3.api.IEssentials {
|
|||||||
return persistentDataProvider;
|
return persistentDataProvider;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ReflOnlineModeProvider getOnlineModeProvider() {
|
||||||
|
return onlineModeProvider;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public PluginCommand getPluginCommand(final String cmd) {
|
public PluginCommand getPluginCommand(final String cmd) {
|
||||||
return this.getCommand(cmd);
|
return this.getCommand(cmd);
|
||||||
|
@ -7,6 +7,7 @@ import com.earth2me.essentials.commands.IEssentialsCommand;
|
|||||||
import com.earth2me.essentials.commands.PlayerNotFoundException;
|
import com.earth2me.essentials.commands.PlayerNotFoundException;
|
||||||
import com.earth2me.essentials.perm.PermissionsHandler;
|
import com.earth2me.essentials.perm.PermissionsHandler;
|
||||||
import com.earth2me.essentials.updatecheck.UpdateChecker;
|
import com.earth2me.essentials.updatecheck.UpdateChecker;
|
||||||
|
import net.ess3.nms.refl.providers.ReflOnlineModeProvider;
|
||||||
import net.ess3.provider.ContainerProvider;
|
import net.ess3.provider.ContainerProvider;
|
||||||
import net.ess3.provider.FormattedCommandAliasProvider;
|
import net.ess3.provider.FormattedCommandAliasProvider;
|
||||||
import net.ess3.provider.KnownCommandsProvider;
|
import net.ess3.provider.KnownCommandsProvider;
|
||||||
@ -156,5 +157,7 @@ public interface IEssentials extends Plugin {
|
|||||||
|
|
||||||
PersistentDataProvider getPersistentDataProvider();
|
PersistentDataProvider getPersistentDataProvider();
|
||||||
|
|
||||||
|
ReflOnlineModeProvider getOnlineModeProvider();
|
||||||
|
|
||||||
PluginCommand getPluginCommand(String cmd);
|
PluginCommand getPluginCommand(String cmd);
|
||||||
}
|
}
|
||||||
|
@ -190,6 +190,7 @@ public class Commandessentials extends EssentialsCommand {
|
|||||||
serverData.addProperty("bukkit-version", Bukkit.getBukkitVersion());
|
serverData.addProperty("bukkit-version", Bukkit.getBukkitVersion());
|
||||||
serverData.addProperty("server-version", Bukkit.getVersion());
|
serverData.addProperty("server-version", Bukkit.getVersion());
|
||||||
serverData.addProperty("server-brand", Bukkit.getName());
|
serverData.addProperty("server-brand", Bukkit.getName());
|
||||||
|
serverData.addProperty("online-mode", ess.getOnlineModeProvider().getOnlineModeString());
|
||||||
final JsonObject supportStatus = new JsonObject();
|
final JsonObject supportStatus = new JsonObject();
|
||||||
final VersionUtil.SupportStatus status = VersionUtil.getServerSupportStatus();
|
final VersionUtil.SupportStatus status = VersionUtil.getServerSupportStatus();
|
||||||
supportStatus.addProperty("status", status.name());
|
supportStatus.addProperty("status", status.name());
|
||||||
|
@ -0,0 +1,59 @@
|
|||||||
|
package net.ess3.nms.refl.providers;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
|
||||||
|
import java.lang.invoke.MethodHandle;
|
||||||
|
import java.lang.invoke.MethodHandles;
|
||||||
|
import java.lang.invoke.MethodType;
|
||||||
|
|
||||||
|
public class ReflOnlineModeProvider {
|
||||||
|
private final MethodHandle spigotBungeeGetter;
|
||||||
|
private final MethodHandle paperBungeeGetter;
|
||||||
|
private final boolean fancyPaperCheck;
|
||||||
|
|
||||||
|
public ReflOnlineModeProvider() {
|
||||||
|
MethodHandle spigotBungeeGetter = null;
|
||||||
|
MethodHandle paperBungeeGetter = null;
|
||||||
|
boolean fancyCheck = false;
|
||||||
|
try {
|
||||||
|
final MethodHandles.Lookup lookup = MethodHandles.lookup();
|
||||||
|
spigotBungeeGetter = lookup.findStaticGetter(Class.forName("org.spigotmc.SpigotConfig"), "bungee", boolean.class);
|
||||||
|
final Class<?> paperConfig = Class.forName("com.destroystokyo.paper.PaperConfig");
|
||||||
|
paperBungeeGetter = lookup.findStaticGetter(paperConfig, "bungeeOnlineMode", boolean.class);
|
||||||
|
paperBungeeGetter = lookup.findStatic(paperConfig, "isProxyOnlineMode", MethodType.methodType(boolean.class));
|
||||||
|
fancyCheck = true;
|
||||||
|
} catch (Throwable ignored) {
|
||||||
|
}
|
||||||
|
this.spigotBungeeGetter = spigotBungeeGetter;
|
||||||
|
this.paperBungeeGetter = paperBungeeGetter;
|
||||||
|
this.fancyPaperCheck = fancyCheck;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getOnlineModeString() {
|
||||||
|
if (spigotBungeeGetter == null) {
|
||||||
|
return Bukkit.getOnlineMode() ? "Online Mode" : "Offline Mode";
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
if (Bukkit.getOnlineMode()) {
|
||||||
|
return "Online Mode";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (fancyPaperCheck) {
|
||||||
|
if ((boolean) paperBungeeGetter.invoke()) {
|
||||||
|
// Could be Velocity or Bungee, so do not specify.
|
||||||
|
return "Proxy Mode";
|
||||||
|
}
|
||||||
|
return "Offline Mode";
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((boolean) spigotBungeeGetter.invoke() && (paperBungeeGetter == null || (boolean) paperBungeeGetter.invoke())) {
|
||||||
|
return "Bungee Mode";
|
||||||
|
}
|
||||||
|
|
||||||
|
return "Offline Mode";
|
||||||
|
} catch (Throwable ignored) {
|
||||||
|
return "Unknown";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user