mirror of
https://github.com/plexusorg/Module-HTTPD.git
synced 2024-12-22 16:04:59 +00:00
Merge remote-tracking branch 'origin/master'
# Conflicts: # src/main/java/dev/plex/request/impl/AdminsEndpoint.java
This commit is contained in:
commit
5d6a2deb2e
9 changed files with 274 additions and 108 deletions
|
@ -2,7 +2,10 @@ package dev.plex;
|
||||||
|
|
||||||
import dev.plex.config.ModuleConfig;
|
import dev.plex.config.ModuleConfig;
|
||||||
import dev.plex.module.PlexModule;
|
import dev.plex.module.PlexModule;
|
||||||
import dev.plex.request.impl.GetEndpoints;
|
import dev.plex.request.impl.AdminsEndpoint;
|
||||||
|
import dev.plex.request.impl.IndefBansEndpoint;
|
||||||
|
import dev.plex.request.impl.ListEndpoint;
|
||||||
|
import dev.plex.request.impl.PunishmentsEndpoint;
|
||||||
import dev.plex.util.PlexLog;
|
import dev.plex.util.PlexLog;
|
||||||
import java.util.concurrent.atomic.AtomicReference;
|
import java.util.concurrent.atomic.AtomicReference;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
|
@ -27,12 +30,11 @@ public class HTTPDModule extends PlexModule
|
||||||
@Getter
|
@Getter
|
||||||
private static Permission permissions = null;
|
private static Permission permissions = null;
|
||||||
|
|
||||||
private ModuleConfig moduleConfig;
|
public static ModuleConfig moduleConfig;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void load()
|
public void load()
|
||||||
{
|
{
|
||||||
|
|
||||||
moduleConfig = new ModuleConfig(this, "settings.yml");
|
moduleConfig = new ModuleConfig(this, "settings.yml");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -58,13 +60,15 @@ public class HTTPDModule extends PlexModule
|
||||||
connector.setHost(moduleConfig.getString("server.bind-address"));
|
connector.setHost(moduleConfig.getString("server.bind-address"));
|
||||||
connector.setPort(moduleConfig.getInt("server.port"));
|
connector.setPort(moduleConfig.getInt("server.port"));
|
||||||
|
|
||||||
new GetEndpoints();
|
new AdminsEndpoint();
|
||||||
|
new IndefBansEndpoint();
|
||||||
|
new ListEndpoint();
|
||||||
|
new PunishmentsEndpoint();
|
||||||
|
|
||||||
server.setConnectors(new Connector[]{connector});
|
server.setConnectors(new Connector[]{connector});
|
||||||
server.setHandler(context);
|
server.setHandler(context);
|
||||||
|
|
||||||
atomicServer.set(server);
|
atomicServer.set(server);
|
||||||
PlexLog.debug("Set atomicServer value? {0}", atomicServer.get() != null);
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
server.start();
|
server.start();
|
||||||
|
@ -76,6 +80,7 @@ public class HTTPDModule extends PlexModule
|
||||||
}
|
}
|
||||||
}, "Jetty-Server");
|
}, "Jetty-Server");
|
||||||
serverThread.start();
|
serverThread.start();
|
||||||
|
PlexLog.log("Starting Jetty server on port " + moduleConfig.getInt("server.port"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
25
src/main/java/dev/plex/logging/Log.java
Normal file
25
src/main/java/dev/plex/logging/Log.java
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
package dev.plex.logging;
|
||||||
|
|
||||||
|
import dev.plex.HTTPDModule;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.ChatColor;
|
||||||
|
|
||||||
|
|
||||||
|
public class Log
|
||||||
|
{
|
||||||
|
public static void log(String message, Object... strings)
|
||||||
|
{
|
||||||
|
for (int i = 0; i < strings.length; i++)
|
||||||
|
{
|
||||||
|
if (message.contains("{" + i + "}"))
|
||||||
|
{
|
||||||
|
message = message.replace("{" + i + "}", strings[i].toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (HTTPDModule.moduleConfig.getBoolean("server.logging"))
|
||||||
|
{
|
||||||
|
Bukkit.getConsoleSender().sendMessage(String.format(ChatColor.DARK_AQUA + "[Plex HTTPD] " + ChatColor.GRAY + "%s", message));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -2,7 +2,7 @@ package dev.plex.request;
|
||||||
|
|
||||||
import com.google.common.collect.Lists;
|
import com.google.common.collect.Lists;
|
||||||
import dev.plex.HTTPDModule;
|
import dev.plex.HTTPDModule;
|
||||||
import dev.plex.util.PlexLog;
|
import dev.plex.logging.Log;
|
||||||
import jakarta.servlet.ServletException;
|
import jakarta.servlet.ServletException;
|
||||||
import jakarta.servlet.http.HttpServlet;
|
import jakarta.servlet.http.HttpServlet;
|
||||||
import jakarta.servlet.http.HttpServletRequest;
|
import jakarta.servlet.http.HttpServletRequest;
|
||||||
|
@ -16,7 +16,6 @@ import org.eclipse.jetty.servlet.ServletHolder;
|
||||||
|
|
||||||
public class AbstractServlet extends HttpServlet
|
public class AbstractServlet extends HttpServlet
|
||||||
{
|
{
|
||||||
|
|
||||||
private final List<Mapping> GET_MAPPINGS = Lists.newArrayList();
|
private final List<Mapping> GET_MAPPINGS = Lists.newArrayList();
|
||||||
|
|
||||||
public AbstractServlet()
|
public AbstractServlet()
|
||||||
|
@ -42,16 +41,13 @@ public class AbstractServlet extends HttpServlet
|
||||||
@Override
|
@Override
|
||||||
public void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException
|
public void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException
|
||||||
{
|
{
|
||||||
|
String ipAddress = req.getRemoteAddr();
|
||||||
PlexLog.debug("Context Path: " + req.getHttpServletMapping().getMatchValue());
|
|
||||||
|
|
||||||
String ipAddress = req.getHeader("X-FORWARDED-FOR");
|
|
||||||
if (ipAddress == null)
|
if (ipAddress == null)
|
||||||
{
|
{
|
||||||
ipAddress = req.getRemoteAddr();
|
ipAddress = req.getHeader("X-FORWARDED-FOR");
|
||||||
}
|
}
|
||||||
PlexLog.debug("HTTP Remote IP: " + ipAddress);
|
|
||||||
PlexLog.debug("HTTP Local IP: " + req.getLocalAddr());
|
Log.log(ipAddress + " visited endpoint " + req.getHttpServletMapping().getMatchValue());
|
||||||
|
|
||||||
/*Enumeration<String> headerz = req.getHeaderNames();
|
/*Enumeration<String> headerz = req.getHeaderNames();
|
||||||
while (headerz.hasMoreElements()) {
|
while (headerz.hasMoreElements()) {
|
||||||
|
@ -59,7 +55,6 @@ public class AbstractServlet extends HttpServlet
|
||||||
PlexLog.debug("Header: {0} Value {1}", header, req.getHeader(header));
|
PlexLog.debug("Header: {0} Value {1}", header, req.getHeader(header));
|
||||||
}*/
|
}*/
|
||||||
|
|
||||||
PlexLog.debug("-------------------------");
|
|
||||||
GET_MAPPINGS.stream().filter(mapping -> mapping.getMapping().endpoint().substring(1, mapping.getMapping().endpoint().length() - 1).equalsIgnoreCase(req.getHttpServletMapping().getMatchValue())).forEach(mapping ->
|
GET_MAPPINGS.stream().filter(mapping -> mapping.getMapping().endpoint().substring(1, mapping.getMapping().endpoint().length() - 1).equalsIgnoreCase(req.getHttpServletMapping().getMatchValue())).forEach(mapping ->
|
||||||
{
|
{
|
||||||
if (mapping.headers != null)
|
if (mapping.headers != null)
|
||||||
|
@ -84,9 +79,8 @@ public class AbstractServlet extends HttpServlet
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
public class Mapping
|
public static class Mapping
|
||||||
{
|
{
|
||||||
private final Method method;
|
private final Method method;
|
||||||
private final GetMapping mapping;
|
private final GetMapping mapping;
|
||||||
|
|
56
src/main/java/dev/plex/request/impl/AdminsEndpoint.java
Normal file
56
src/main/java/dev/plex/request/impl/AdminsEndpoint.java
Normal file
|
@ -0,0 +1,56 @@
|
||||||
|
package dev.plex.request.impl;
|
||||||
|
|
||||||
|
import com.google.common.collect.Lists;
|
||||||
|
import com.google.gson.GsonBuilder;
|
||||||
|
import dev.plex.HTTPDModule;
|
||||||
|
import dev.plex.Plex;
|
||||||
|
import dev.plex.cache.DataUtils;
|
||||||
|
import dev.plex.player.PlexPlayer;
|
||||||
|
import dev.plex.rank.enums.Rank;
|
||||||
|
import dev.plex.request.AbstractServlet;
|
||||||
|
import dev.plex.request.GetMapping;
|
||||||
|
import dev.plex.util.PlexLog;
|
||||||
|
import jakarta.servlet.http.HttpServletRequest;
|
||||||
|
import java.util.UUID;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.OfflinePlayer;
|
||||||
|
|
||||||
|
public class AdminsEndpoint extends AbstractServlet
|
||||||
|
{
|
||||||
|
@GetMapping(endpoint = "/api/admins/")
|
||||||
|
public String getAdmins(HttpServletRequest request)
|
||||||
|
{
|
||||||
|
String ipAddress = request.getRemoteAddr();
|
||||||
|
if (ipAddress == null)
|
||||||
|
{
|
||||||
|
return "An IP address could not be detected. Please ensure you are connecting using IPv4.";
|
||||||
|
}
|
||||||
|
final PlexPlayer player = DataUtils.getPlayerByIP(ipAddress);
|
||||||
|
if (player == null)
|
||||||
|
{
|
||||||
|
// This likely means they've never joined the server before. That's okay. We can just not return IPs.
|
||||||
|
return new GsonBuilder().setPrettyPrinting().create().toJson(Plex.get().getAdminList().getAllAdminPlayers().stream().peek(plexPlayer -> plexPlayer.setIps(Lists.newArrayList())).collect(Collectors.toList()));
|
||||||
|
}
|
||||||
|
if (Plex.get().getSystem().equalsIgnoreCase("ranks"))
|
||||||
|
{
|
||||||
|
PlexLog.debug("Plex-HTTPD using ranks check");
|
||||||
|
if (!player.getRankFromString().isAtLeast(Rank.ADMIN))
|
||||||
|
{
|
||||||
|
// Don't return IPs either if the person is not an Admin or above.
|
||||||
|
return new GsonBuilder().setPrettyPrinting().create().toJson(Plex.get().getAdminList().getAllAdminPlayers().stream().peek(plexPlayer -> plexPlayer.setIps(Lists.newArrayList())).collect(Collectors.toList()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (Plex.get().getSystem().equalsIgnoreCase("permissions"))
|
||||||
|
{
|
||||||
|
PlexLog.debug("Plex-HTTPD using permissions check");
|
||||||
|
final OfflinePlayer offlinePlayer = Bukkit.getOfflinePlayer(UUID.fromString(player.getUuid()));
|
||||||
|
if (!HTTPDModule.getPermissions().playerHas(null, offlinePlayer, "plex.httpd.admins.access"))
|
||||||
|
{
|
||||||
|
// If the person doesn't have permission, don't return IPs
|
||||||
|
return new GsonBuilder().setPrettyPrinting().create().toJson(Plex.get().getAdminList().getAllAdminPlayers().stream().peek(plexPlayer -> plexPlayer.setIps(Lists.newArrayList())).collect(Collectors.toList()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return new GsonBuilder().setPrettyPrinting().create().toJson(Plex.get().getAdminList().getAllAdminPlayers());
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,90 +0,0 @@
|
||||||
package dev.plex.request.impl;
|
|
||||||
|
|
||||||
import com.google.common.collect.Lists;
|
|
||||||
import com.google.gson.GsonBuilder;
|
|
||||||
import dev.plex.HTTPDModule;
|
|
||||||
import dev.plex.Plex;
|
|
||||||
import dev.plex.cache.DataUtils;
|
|
||||||
import dev.plex.player.PlexPlayer;
|
|
||||||
import dev.plex.rank.enums.Rank;
|
|
||||||
import dev.plex.request.AbstractServlet;
|
|
||||||
import dev.plex.request.GetMapping;
|
|
||||||
import dev.plex.util.PlexLog;
|
|
||||||
import dev.plex.util.adapter.LocalDateTimeSerializer;
|
|
||||||
import jakarta.servlet.http.HttpServletRequest;
|
|
||||||
import org.bukkit.Bukkit;
|
|
||||||
import org.bukkit.OfflinePlayer;
|
|
||||||
|
|
||||||
import java.time.LocalDateTime;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.UUID;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
//@RestController
|
|
||||||
//@RequestMapping("/api/admins")
|
|
||||||
public class GetEndpoints extends AbstractServlet
|
|
||||||
{
|
|
||||||
@GetMapping(endpoint = "/api/admins/")
|
|
||||||
public String getAdmins(HttpServletRequest request)
|
|
||||||
{
|
|
||||||
String ipAddress = request.getHeader("X-FORWARDED-FOR");
|
|
||||||
if (ipAddress == null)
|
|
||||||
{
|
|
||||||
ipAddress = request.getRemoteAddr();
|
|
||||||
}
|
|
||||||
final PlexPlayer player = DataUtils.getPlayerByIP(ipAddress);
|
|
||||||
if (player == null)
|
|
||||||
{
|
|
||||||
return "Couldn't load your IP Address: " + ipAddress + ". Check if your SSL settings are setup correctly.";
|
|
||||||
}
|
|
||||||
if (Plex.get().getSystem().equalsIgnoreCase("ranks"))
|
|
||||||
{
|
|
||||||
PlexLog.debug("Plex-HTTPD using ranks check");
|
|
||||||
if (!player.getRankFromString().isAtLeast(Rank.ADMIN))
|
|
||||||
{
|
|
||||||
return new GsonBuilder().registerTypeAdapter(LocalDateTime.class, new LocalDateTimeSerializer()).setPrettyPrinting().create().toJson(Plex.get().getAdminList().getAllAdminPlayers().stream().peek(plexPlayer -> plexPlayer.setIps(Lists.newArrayList())).peek(plexPlayer -> plexPlayer.setPunishments(Lists.newArrayList())).collect(Collectors.toList()));
|
|
||||||
}
|
|
||||||
} else if (Plex.get().getSystem().equalsIgnoreCase("permissions"))
|
|
||||||
{
|
|
||||||
PlexLog.debug("Plex-HTTPD using permissions check");
|
|
||||||
final OfflinePlayer offlinePlayer = Bukkit.getOfflinePlayer(UUID.fromString(player.getUuid()));
|
|
||||||
if (!HTTPDModule.getPermissions().playerHas(null, offlinePlayer, "plex.httpd.admins.access"))
|
|
||||||
{
|
|
||||||
return new GsonBuilder().registerTypeAdapter(LocalDateTime.class, new LocalDateTimeSerializer()).setPrettyPrinting().create().toJson(Plex.get().getAdminList().getAllAdminPlayers().stream().peek(plexPlayer -> plexPlayer.setIps(Lists.newArrayList())).peek(plexPlayer -> plexPlayer.setPunishments(Lists.newArrayList())).collect(Collectors.toList()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return new GsonBuilder().registerTypeAdapter(LocalDateTime.class, new LocalDateTimeSerializer()).setPrettyPrinting().create().toJson(new ArrayList<>(Plex.get().getAdminList().getAllAdminPlayers()));
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping(endpoint = "/api/indefbans/")
|
|
||||||
public String getBans(HttpServletRequest request)
|
|
||||||
{
|
|
||||||
String ipAddress = request.getHeader("X-FORWARDED-FOR");
|
|
||||||
if (ipAddress == null)
|
|
||||||
{
|
|
||||||
ipAddress = request.getRemoteAddr();
|
|
||||||
}
|
|
||||||
final PlexPlayer player = DataUtils.getPlayerByIP(ipAddress);
|
|
||||||
if (player == null)
|
|
||||||
{
|
|
||||||
return "Couldn't load your IP Address: " + ipAddress + ". Check if your SSL settings are setup correctly.";
|
|
||||||
}
|
|
||||||
if (Plex.get().getSystem().equalsIgnoreCase("ranks"))
|
|
||||||
{
|
|
||||||
PlexLog.debug("Plex-HTTPD using ranks check");
|
|
||||||
if (!player.getRankFromString().isAtLeast(Rank.ADMIN))
|
|
||||||
{
|
|
||||||
return "Not a high enough rank to view this page.";
|
|
||||||
}
|
|
||||||
} else if (Plex.get().getSystem().equalsIgnoreCase("permissions"))
|
|
||||||
{
|
|
||||||
PlexLog.debug("Plex-HTTPD using permissions check");
|
|
||||||
final OfflinePlayer offlinePlayer = Bukkit.getOfflinePlayer(UUID.fromString(player.getUuid()));
|
|
||||||
if (!HTTPDModule.getPermissions().playerHas(null, offlinePlayer, "plex.httpd.indefbans.access"))
|
|
||||||
{
|
|
||||||
return "Not enough permissions to view this page.";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return new GsonBuilder().setPrettyPrinting().create().toJson(Plex.get().getPunishmentManager().getIndefiniteBans().stream().toList());
|
|
||||||
}
|
|
||||||
}
|
|
51
src/main/java/dev/plex/request/impl/IndefBansEndpoint.java
Normal file
51
src/main/java/dev/plex/request/impl/IndefBansEndpoint.java
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
package dev.plex.request.impl;
|
||||||
|
|
||||||
|
import com.google.gson.GsonBuilder;
|
||||||
|
import dev.plex.HTTPDModule;
|
||||||
|
import dev.plex.Plex;
|
||||||
|
import dev.plex.cache.DataUtils;
|
||||||
|
import dev.plex.player.PlexPlayer;
|
||||||
|
import dev.plex.rank.enums.Rank;
|
||||||
|
import dev.plex.request.AbstractServlet;
|
||||||
|
import dev.plex.request.GetMapping;
|
||||||
|
import dev.plex.util.PlexLog;
|
||||||
|
import jakarta.servlet.http.HttpServletRequest;
|
||||||
|
import java.util.UUID;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.OfflinePlayer;
|
||||||
|
|
||||||
|
public class IndefBansEndpoint extends AbstractServlet
|
||||||
|
{
|
||||||
|
@GetMapping(endpoint = "/api/indefbans/")
|
||||||
|
public String getBans(HttpServletRequest request)
|
||||||
|
{
|
||||||
|
String ipAddress = request.getRemoteAddr();
|
||||||
|
if (ipAddress == null)
|
||||||
|
{
|
||||||
|
return "An IP address could not be detected. Please ensure you are connecting using IPv4.";
|
||||||
|
}
|
||||||
|
final PlexPlayer player = DataUtils.getPlayerByIP(ipAddress);
|
||||||
|
if (player == null)
|
||||||
|
{
|
||||||
|
return "Couldn't load your IP Address: " + ipAddress + ". Have you joined the server before?";
|
||||||
|
}
|
||||||
|
if (Plex.get().getSystem().equalsIgnoreCase("ranks"))
|
||||||
|
{
|
||||||
|
PlexLog.debug("Plex-HTTPD using ranks check");
|
||||||
|
if (!player.getRankFromString().isAtLeast(Rank.ADMIN))
|
||||||
|
{
|
||||||
|
return "Not a high enough rank to view this page.";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (Plex.get().getSystem().equalsIgnoreCase("permissions"))
|
||||||
|
{
|
||||||
|
PlexLog.debug("Plex-HTTPD using permissions check");
|
||||||
|
final OfflinePlayer offlinePlayer = Bukkit.getOfflinePlayer(UUID.fromString(player.getUuid()));
|
||||||
|
if (!HTTPDModule.getPermissions().playerHas(null, offlinePlayer, "plex.httpd.indefbans.access"))
|
||||||
|
{
|
||||||
|
return "Not enough permissions to view this page.";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return new GsonBuilder().setPrettyPrinting().create().toJson(Plex.get().getPunishmentManager().getIndefiniteBans().stream().toList());
|
||||||
|
}
|
||||||
|
}
|
25
src/main/java/dev/plex/request/impl/ListEndpoint.java
Normal file
25
src/main/java/dev/plex/request/impl/ListEndpoint.java
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
package dev.plex.request.impl;
|
||||||
|
|
||||||
|
import com.google.gson.GsonBuilder;
|
||||||
|
import dev.plex.request.AbstractServlet;
|
||||||
|
import dev.plex.request.GetMapping;
|
||||||
|
import jakarta.servlet.http.HttpServletRequest;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class ListEndpoint extends AbstractServlet
|
||||||
|
{
|
||||||
|
List<String> players = new ArrayList<>();
|
||||||
|
|
||||||
|
@GetMapping(endpoint = "/api/list/")
|
||||||
|
public String getOnlinePlayers(HttpServletRequest request)
|
||||||
|
{
|
||||||
|
for (Player player : Bukkit.getOnlinePlayers())
|
||||||
|
{
|
||||||
|
players.add(player.getName());
|
||||||
|
}
|
||||||
|
return new GsonBuilder().setPrettyPrinting().create().toJson(players.stream().toList());
|
||||||
|
}
|
||||||
|
}
|
99
src/main/java/dev/plex/request/impl/PunishmentsEndpoint.java
Normal file
99
src/main/java/dev/plex/request/impl/PunishmentsEndpoint.java
Normal file
|
@ -0,0 +1,99 @@
|
||||||
|
package dev.plex.request.impl;
|
||||||
|
|
||||||
|
import com.google.gson.GsonBuilder;
|
||||||
|
import dev.plex.HTTPDModule;
|
||||||
|
import dev.plex.Plex;
|
||||||
|
import dev.plex.cache.DataUtils;
|
||||||
|
import dev.plex.player.PlexPlayer;
|
||||||
|
import dev.plex.player.PunishedPlayer;
|
||||||
|
import dev.plex.rank.enums.Rank;
|
||||||
|
import dev.plex.request.AbstractServlet;
|
||||||
|
import dev.plex.request.GetMapping;
|
||||||
|
import dev.plex.util.PlexLog;
|
||||||
|
import dev.plex.util.adapter.LocalDateTimeSerializer;
|
||||||
|
import jakarta.servlet.http.HttpServletRequest;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.time.LocalDateTime;
|
||||||
|
import java.util.UUID;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.OfflinePlayer;
|
||||||
|
|
||||||
|
public class PunishmentsEndpoint extends AbstractServlet
|
||||||
|
{
|
||||||
|
@GetMapping(endpoint = "/api/punishments/")
|
||||||
|
public String getPunishments(HttpServletRequest request)
|
||||||
|
{
|
||||||
|
String ipAddress = request.getRemoteAddr();
|
||||||
|
if (ipAddress == null)
|
||||||
|
{
|
||||||
|
return "An IP address could not be detected. Please ensure you are connecting using IPv4.";
|
||||||
|
}
|
||||||
|
if (request.getPathInfo() == null)
|
||||||
|
{
|
||||||
|
return "Please specify the UUID of the player you would like to check.\nExample: /api/punishments/<uuid>";
|
||||||
|
}
|
||||||
|
try
|
||||||
|
{
|
||||||
|
UUID uuid = UUID.fromString(request.getPathInfo().replace("/", ""));
|
||||||
|
final PunishedPlayer punishedPlayer = new PunishedPlayer(uuid);
|
||||||
|
final PlexPlayer player = DataUtils.getPlayerByIP(ipAddress);
|
||||||
|
if (punishedPlayer.getPunishments().isEmpty())
|
||||||
|
{
|
||||||
|
return "This player has been a good boy. They have no punishments! Or they've never been on the server before. Take your pick.";
|
||||||
|
}
|
||||||
|
if (player == null)
|
||||||
|
{
|
||||||
|
// If the player is null, give it to them without the IPs
|
||||||
|
return new GsonBuilder().registerTypeAdapter(LocalDateTime.class, new LocalDateTimeSerializer()).setPrettyPrinting().create().toJson(punishedPlayer.getPunishments().stream().peek(punishment -> punishment.setIp("")).toList());
|
||||||
|
}
|
||||||
|
if (Plex.get().getSystem().equalsIgnoreCase("ranks"))
|
||||||
|
{
|
||||||
|
PlexLog.debug("Plex-HTTPD using ranks check");
|
||||||
|
if (!player.getRankFromString().isAtLeast(Rank.ADMIN))
|
||||||
|
{
|
||||||
|
// Don't return IPs either if the person is not an Admin or above.
|
||||||
|
return new GsonBuilder().registerTypeAdapter(LocalDateTime.class, new LocalDateTimeSerializer()).setPrettyPrinting().create().toJson(punishedPlayer.getPunishments().stream().peek(punishment -> punishment.setIp("")).toList());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (Plex.get().getSystem().equalsIgnoreCase("permissions"))
|
||||||
|
{
|
||||||
|
PlexLog.debug("Plex-HTTPD using permissions check");
|
||||||
|
final OfflinePlayer offlinePlayer = Bukkit.getOfflinePlayer(UUID.fromString(player.getUuid()));
|
||||||
|
if (!HTTPDModule.getPermissions().playerHas(null, offlinePlayer, "plex.httpd.punishments.access"))
|
||||||
|
{
|
||||||
|
// If the person doesn't have permission, don't return IPs
|
||||||
|
return new GsonBuilder().registerTypeAdapter(LocalDateTime.class, new LocalDateTimeSerializer()).setPrettyPrinting().create().toJson(punishedPlayer.getPunishments().stream().peek(punishment -> punishment.setIp("")).toList());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return new GsonBuilder().registerTypeAdapter(LocalDateTime.class, new LocalDateTimeSerializer()).setPrettyPrinting().create().toJson(punishedPlayer.getPunishments().stream().toList());
|
||||||
|
}
|
||||||
|
catch (java.lang.IllegalArgumentException ignored)
|
||||||
|
{
|
||||||
|
return "Invalid UUID";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public File getPunishmentsFile(UUID uuid)
|
||||||
|
{
|
||||||
|
File folder = new File(Plex.get().getDataFolder() + File.separator + "punishments");
|
||||||
|
if (!folder.exists())
|
||||||
|
{
|
||||||
|
folder.mkdir();
|
||||||
|
}
|
||||||
|
|
||||||
|
File file = new File(folder, "" + uuid.toString() + ".json");
|
||||||
|
if (!file.exists())
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
file.createNewFile();
|
||||||
|
}
|
||||||
|
catch (IOException e)
|
||||||
|
{
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return file;
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,3 +1,4 @@
|
||||||
server:
|
server:
|
||||||
bind-address: 0.0.0.0
|
bind-address: 0.0.0.0
|
||||||
port: 27192
|
port: 27192
|
||||||
|
logging: false
|
Loading…
Reference in a new issue