Module-HTTPD/src/main/java/dev/plex/request/impl/GetEndpoints.java

90 lines
3.8 KiB
Java
Raw Normal View History

2022-04-02 03:59:47 +00:00
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.ArrayList;
import java.util.UUID;
import java.util.stream.Collectors;
2022-04-02 04:14:12 +00:00
import org.bukkit.Bukkit;
import org.bukkit.OfflinePlayer;
2022-04-02 03:59:47 +00:00
//@RestController
//@RequestMapping("/api/admins")
2022-04-02 04:14:12 +00:00
public class GetEndpoints extends AbstractServlet
{
2022-04-02 03:59:47 +00:00
@GetMapping(endpoint = "/api/admins/")
2022-04-02 04:14:12 +00:00
public String getAdmins(HttpServletRequest request)
{
2022-04-02 03:59:47 +00:00
String ipAddress = request.getHeader("X-FORWARDED-FOR");
2022-04-02 04:14:12 +00:00
if (ipAddress == null)
{
2022-04-02 03:59:47 +00:00
ipAddress = request.getRemoteAddr();
}
final PlexPlayer player = DataUtils.getPlayerByIP(ipAddress);
2022-04-02 04:14:12 +00:00
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"))
{
2022-04-02 03:59:47 +00:00
PlexLog.debug("Plex-HTTPD using ranks check");
2022-04-02 04:14:12 +00:00
if (!player.getRankFromString().isAtLeast(Rank.ADMIN))
{
2022-04-02 03:59:47 +00:00
return new GsonBuilder().setPrettyPrinting().create().toJson(Plex.get().getAdminList().getAllAdminPlayers().stream().peek(plexPlayer -> plexPlayer.setIps(Lists.newArrayList())).collect(Collectors.toList()));
}
2022-04-02 04:14:12 +00:00
}
else if (Plex.get().getSystem().equalsIgnoreCase("permissions"))
{
2022-04-02 03:59:47 +00:00
PlexLog.debug("Plex-HTTPD using permissions check");
final OfflinePlayer offlinePlayer = Bukkit.getOfflinePlayer(UUID.fromString(player.getUuid()));
2022-04-02 04:14:12 +00:00
if (!HTTPDModule.getPermissions().playerHas(null, offlinePlayer, "plex.httpd.indefbans.access"))
{
2022-04-02 03:59:47 +00:00
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(new ArrayList<>(Plex.get().getAdminList().getAllAdminPlayers()));
}
@GetMapping(endpoint = "/api/indefbans/")
2022-04-02 04:14:12 +00:00
public String getBans(HttpServletRequest request)
{
2022-04-02 03:59:47 +00:00
String ipAddress = request.getHeader("X-FORWARDED-FOR");
2022-04-02 04:14:12 +00:00
if (ipAddress == null)
{
2022-04-02 03:59:47 +00:00
ipAddress = request.getRemoteAddr();
}
final PlexPlayer player = DataUtils.getPlayerByIP(ipAddress);
2022-04-02 04:14:12 +00:00
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"))
{
2022-04-02 03:59:47 +00:00
PlexLog.debug("Plex-HTTPD using ranks check");
2022-04-02 04:14:12 +00:00
if (!player.getRankFromString().isAtLeast(Rank.ADMIN))
{
2022-04-02 03:59:47 +00:00
return "Not a high enough rank to view this page.";
}
2022-04-02 04:14:12 +00:00
}
else if (Plex.get().getSystem().equalsIgnoreCase("permissions"))
{
2022-04-02 03:59:47 +00:00
PlexLog.debug("Plex-HTTPD using permissions check");
final OfflinePlayer offlinePlayer = Bukkit.getOfflinePlayer(UUID.fromString(player.getUuid()));
2022-04-02 04:14:12 +00:00
if (!HTTPDModule.getPermissions().playerHas(null, offlinePlayer, "plex.httpd.indefbans.access"))
{
2022-04-02 03:59:47 +00:00
return "Not enough permissions to view this page.";
}
}
return new GsonBuilder().setPrettyPrinting().create().toJson(new ArrayList<>(Plex.get().getPunishmentManager().getIndefiniteBans().stream().toList()));
}
}