mirror of
https://github.com/PaperMC/Paper.git
synced 2025-02-12 18:42:07 +01:00
Add Ban Methods to Player Objects
Allows a more logical API for banning players. player.banPlayer("Breaking the rules");
This commit is contained in:
parent
4e4f7912da
commit
582999642c
230
Spigot-API-Patches/Add-Ban-Methods-to-Player-Objects.patch
Normal file
230
Spigot-API-Patches/Add-Ban-Methods-to-Player-Objects.patch
Normal file
@ -0,0 +1,230 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Aikar <aikar@aikar.co>
|
||||||
|
Date: Sat, 28 Apr 2018 10:28:50 -0400
|
||||||
|
Subject: [PATCH] Add Ban Methods to Player Objects
|
||||||
|
|
||||||
|
Allows a more logical API for banning players.
|
||||||
|
|
||||||
|
player.banPlayer("Breaking the rules");
|
||||||
|
|
||||||
|
diff --git a/src/main/java/org/bukkit/OfflinePlayer.java b/src/main/java/org/bukkit/OfflinePlayer.java
|
||||||
|
index 3ab2e4c7..8daf2ddc 100644
|
||||||
|
--- a/src/main/java/org/bukkit/OfflinePlayer.java
|
||||||
|
+++ b/src/main/java/org/bukkit/OfflinePlayer.java
|
||||||
|
@@ -0,0 +0,0 @@ public interface OfflinePlayer extends ServerOperator, AnimalTamer, Configuratio
|
||||||
|
* @return true if banned, otherwise false
|
||||||
|
*/
|
||||||
|
public boolean isBanned();
|
||||||
|
+ // Paper start
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Permanently Bans this player from the server
|
||||||
|
+ *
|
||||||
|
+ * @param reason Reason for Ban
|
||||||
|
+ * @return Ban Entry
|
||||||
|
+ */
|
||||||
|
+ public default BanEntry banPlayer(String reason) {
|
||||||
|
+ return banPlayer(reason, null, null);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Permanently Bans this player from the server
|
||||||
|
+ * @param reason Reason for Ban
|
||||||
|
+ * @param source Source of the ban, or null for default
|
||||||
|
+ * @return Ban Entry
|
||||||
|
+ */
|
||||||
|
+ public default BanEntry banPlayer(String reason, String source) {
|
||||||
|
+ return banPlayer(reason, null, source);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Bans this player from the server
|
||||||
|
+ * @param reason Reason for Ban
|
||||||
|
+ * @param expires When to expire the ban
|
||||||
|
+ * @return Ban Entry
|
||||||
|
+ */
|
||||||
|
+ public default BanEntry banPlayer(String reason, Date expires) {
|
||||||
|
+ return banPlayer(reason, expires, null);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Bans this player from the server
|
||||||
|
+ * @param reason Reason for Ban
|
||||||
|
+ * @param expires When to expire the ban
|
||||||
|
+ * @param source Source of the ban or null for default
|
||||||
|
+ * @return Ban Entry
|
||||||
|
+ */
|
||||||
|
+ public default BanEntry banPlayer(String reason, Date expires, String source) {
|
||||||
|
+ return banPlayer(reason, expires, source, true);
|
||||||
|
+ }
|
||||||
|
+ public default BanEntry banPlayer(String reason, Date expires, String source, boolean kickIfOnline) {
|
||||||
|
+ BanEntry banEntry = Bukkit.getServer().getBanList(BanList.Type.NAME).addBan(getName(), reason, expires, source);
|
||||||
|
+ if (kickIfOnline && isOnline()) {
|
||||||
|
+ getPlayer().kickPlayer(reason);
|
||||||
|
+ }
|
||||||
|
+ return banEntry;
|
||||||
|
+ }
|
||||||
|
+ // Paper end
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks if this player is whitelisted or not
|
||||||
|
diff --git a/src/main/java/org/bukkit/entity/Player.java b/src/main/java/org/bukkit/entity/Player.java
|
||||||
|
index 87a9b750..d874d166 100644
|
||||||
|
--- a/src/main/java/org/bukkit/entity/Player.java
|
||||||
|
+++ b/src/main/java/org/bukkit/entity/Player.java
|
||||||
|
@@ -0,0 +0,0 @@
|
||||||
|
package org.bukkit.entity;
|
||||||
|
|
||||||
|
import java.net.InetSocketAddress;
|
||||||
|
+import java.util.Date;
|
||||||
|
|
||||||
|
import com.destroystokyo.paper.Title;
|
||||||
|
import com.destroystokyo.paper.profile.PlayerProfile;
|
||||||
|
import org.bukkit.Achievement;
|
||||||
|
+import org.bukkit.BanEntry;
|
||||||
|
+import org.bukkit.BanList;
|
||||||
|
+import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.ChatColor;
|
||||||
|
import org.bukkit.Effect;
|
||||||
|
import org.bukkit.GameMode;
|
||||||
|
@@ -0,0 +0,0 @@ public interface Player extends HumanEntity, Conversable, CommandSender, Offline
|
||||||
|
public void sendMap(MapView map);
|
||||||
|
|
||||||
|
// Paper start
|
||||||
|
+ /**
|
||||||
|
+ * Permanently Bans the Profile and IP address currently used by the player.
|
||||||
|
+ *
|
||||||
|
+ * @param reason Reason for ban
|
||||||
|
+ * @return Ban Entry
|
||||||
|
+ */
|
||||||
|
+ public default BanEntry banPlayerFull(String reason) {
|
||||||
|
+ return banPlayerFull(reason, null, null);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Permanently Bans the Profile and IP address currently used by the player.
|
||||||
|
+ *
|
||||||
|
+ * @param reason Reason for ban
|
||||||
|
+ * @param source Source of ban, or null for default
|
||||||
|
+ * @return Ban Entry
|
||||||
|
+ */
|
||||||
|
+ public default BanEntry banPlayerFull(String reason, String source) {
|
||||||
|
+ return banPlayerFull(reason, null, source);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Bans the Profile and IP address currently used by the player.
|
||||||
|
+ *
|
||||||
|
+ * @param reason Reason for Ban
|
||||||
|
+ * @param expires When to expire the ban
|
||||||
|
+ * @return Ban Entry
|
||||||
|
+ */
|
||||||
|
+ public default BanEntry banPlayerFull(String reason, Date expires) {
|
||||||
|
+ return banPlayerFull(reason, expires, null);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Bans the Profile and IP address currently used by the player.
|
||||||
|
+ *
|
||||||
|
+ * @param reason Reason for Ban
|
||||||
|
+ * @param expires When to expire the ban
|
||||||
|
+ * @param source Source of the ban, or null for default
|
||||||
|
+ * @return Ban Entry
|
||||||
|
+ */
|
||||||
|
+ public default BanEntry banPlayerFull(String reason, Date expires, String source) {
|
||||||
|
+ banPlayer(reason, expires, source);
|
||||||
|
+ return banPlayerIP(reason, expires, source, true);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Permanently Bans the IP address currently used by the player.
|
||||||
|
+ * Does not ban the Profile, use {@link #banPlayerFull(String, Date, String)}
|
||||||
|
+ *
|
||||||
|
+ * @param reason Reason for ban
|
||||||
|
+ * @param kickPlayer Whether or not to kick the player afterwards
|
||||||
|
+ * @return Ban Entry
|
||||||
|
+ */
|
||||||
|
+ public default BanEntry banPlayerIP(String reason, boolean kickPlayer) {
|
||||||
|
+ return banPlayerIP(reason, null, null, kickPlayer);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Permanently Bans the IP address currently used by the player.
|
||||||
|
+ * Does not ban the Profile, use {@link #banPlayerFull(String, Date, String)}
|
||||||
|
+ * @param reason Reason for ban
|
||||||
|
+ * @param source Source of ban, or null for default
|
||||||
|
+ * @param kickPlayer Whether or not to kick the player afterwards
|
||||||
|
+ * @return Ban Entry
|
||||||
|
+ */
|
||||||
|
+ public default BanEntry banPlayerIP(String reason, String source, boolean kickPlayer) {
|
||||||
|
+ return banPlayerIP(reason, null, source, kickPlayer);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Bans the IP address currently used by the player.
|
||||||
|
+ * Does not ban the Profile, use {@link #banPlayerFull(String, Date, String)}
|
||||||
|
+ * @param reason Reason for Ban
|
||||||
|
+ * @param expires When to expire the ban
|
||||||
|
+ * @param kickPlayer Whether or not to kick the player afterwards
|
||||||
|
+ * @return Ban Entry
|
||||||
|
+ */
|
||||||
|
+ public default BanEntry banPlayerIP(String reason, Date expires, boolean kickPlayer) {
|
||||||
|
+ return banPlayerIP(reason, expires, null, kickPlayer);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Permanently Bans the IP address currently used by the player.
|
||||||
|
+ * Does not ban the Profile, use {@link #banPlayerFull(String, Date, String)}
|
||||||
|
+ *
|
||||||
|
+ * @param reason Reason for ban
|
||||||
|
+ * @return Ban Entry
|
||||||
|
+ */
|
||||||
|
+ public default BanEntry banPlayerIP(String reason) {
|
||||||
|
+ return banPlayerIP(reason, null, null);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Permanently Bans the IP address currently used by the player.
|
||||||
|
+ * Does not ban the Profile, use {@link #banPlayerFull(String, Date, String)}
|
||||||
|
+ * @param reason Reason for ban
|
||||||
|
+ * @param source Source of ban, or null for default
|
||||||
|
+ * @return Ban Entry
|
||||||
|
+ */
|
||||||
|
+ public default BanEntry banPlayerIP(String reason, String source) {
|
||||||
|
+ return banPlayerIP(reason, null, source);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Bans the IP address currently used by the player.
|
||||||
|
+ * Does not ban the Profile, use {@link #banPlayerFull(String, Date, String)}
|
||||||
|
+ * @param reason Reason for Ban
|
||||||
|
+ * @param expires When to expire the ban
|
||||||
|
+ * @return Ban Entry
|
||||||
|
+ */
|
||||||
|
+ public default BanEntry banPlayerIP(String reason, Date expires) {
|
||||||
|
+ return banPlayerIP(reason, expires, null);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Bans the IP address currently used by the player.
|
||||||
|
+ * Does not ban the Profile, use {@link #banPlayerFull(String, Date, String)}
|
||||||
|
+ * @param reason Reason for Ban
|
||||||
|
+ * @param expires When to expire the ban
|
||||||
|
+ * @param source Source of the banm or null for default
|
||||||
|
+ * @return Ban Entry
|
||||||
|
+ */
|
||||||
|
+ public default BanEntry banPlayerIP(String reason, Date expires, String source) {
|
||||||
|
+ return banPlayerIP(reason, expires, source, true);
|
||||||
|
+ }
|
||||||
|
+ public default BanEntry banPlayerIP(String reason, Date expires, String source, boolean kickPlayer) {
|
||||||
|
+ BanEntry banEntry = Bukkit.getServer().getBanList(BanList.Type.IP).addBan(getAddress().getAddress().getHostAddress(), reason, expires, source);
|
||||||
|
+ if (kickPlayer && isOnline()) {
|
||||||
|
+ getPlayer().kickPlayer(reason);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return banEntry;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sends an Action Bar message to the client.
|
||||||
|
--
|
@ -5,7 +5,7 @@ Subject: [PATCH] Add player view distance API
|
|||||||
|
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/EntityPlayer.java b/src/main/java/net/minecraft/server/EntityPlayer.java
|
diff --git a/src/main/java/net/minecraft/server/EntityPlayer.java b/src/main/java/net/minecraft/server/EntityPlayer.java
|
||||||
index 9829cdd89..5b0675718 100644
|
index dfaab774d..3058dfef0 100644
|
||||||
--- a/src/main/java/net/minecraft/server/EntityPlayer.java
|
--- a/src/main/java/net/minecraft/server/EntityPlayer.java
|
||||||
+++ b/src/main/java/net/minecraft/server/EntityPlayer.java
|
+++ b/src/main/java/net/minecraft/server/EntityPlayer.java
|
||||||
@@ -0,0 +0,0 @@ public class EntityPlayer extends EntityHuman implements ICrafting {
|
@@ -0,0 +0,0 @@ public class EntityPlayer extends EntityHuman implements ICrafting {
|
||||||
|
@ -19,7 +19,7 @@ index b0b3033e7..afc13e851 100644
|
|||||||
+ }
|
+ }
|
||||||
}
|
}
|
||||||
diff --git a/src/main/java/net/minecraft/server/EntityLiving.java b/src/main/java/net/minecraft/server/EntityLiving.java
|
diff --git a/src/main/java/net/minecraft/server/EntityLiving.java b/src/main/java/net/minecraft/server/EntityLiving.java
|
||||||
index 756590ac0..05d1fc10d 100644
|
index d15cfdd76..2aaeac324 100644
|
||||||
--- a/src/main/java/net/minecraft/server/EntityLiving.java
|
--- a/src/main/java/net/minecraft/server/EntityLiving.java
|
||||||
+++ b/src/main/java/net/minecraft/server/EntityLiving.java
|
+++ b/src/main/java/net/minecraft/server/EntityLiving.java
|
||||||
@@ -0,0 +0,0 @@ public abstract class EntityLiving extends Entity {
|
@@ -0,0 +0,0 @@ public abstract class EntityLiving extends Entity {
|
||||||
|
@ -5,7 +5,7 @@ Subject: [PATCH] Fix lag from explosions processing dead entities
|
|||||||
|
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/Explosion.java b/src/main/java/net/minecraft/server/Explosion.java
|
diff --git a/src/main/java/net/minecraft/server/Explosion.java b/src/main/java/net/minecraft/server/Explosion.java
|
||||||
index 98c2bdcf..a1ebcf85 100644
|
index 98c2bdcf7..a1ebcf858 100644
|
||||||
--- a/src/main/java/net/minecraft/server/Explosion.java
|
--- a/src/main/java/net/minecraft/server/Explosion.java
|
||||||
+++ b/src/main/java/net/minecraft/server/Explosion.java
|
+++ b/src/main/java/net/minecraft/server/Explosion.java
|
||||||
@@ -0,0 +0,0 @@ public class Explosion {
|
@@ -0,0 +0,0 @@ public class Explosion {
|
||||||
|
@ -5,7 +5,7 @@ Subject: [PATCH] Stop updating flowing block if material has changed
|
|||||||
|
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/BlockFlowing.java b/src/main/java/net/minecraft/server/BlockFlowing.java
|
diff --git a/src/main/java/net/minecraft/server/BlockFlowing.java b/src/main/java/net/minecraft/server/BlockFlowing.java
|
||||||
index 62234a7c..3b47253a 100644
|
index 62234a7c9..3b47253a4 100644
|
||||||
--- a/src/main/java/net/minecraft/server/BlockFlowing.java
|
--- a/src/main/java/net/minecraft/server/BlockFlowing.java
|
||||||
+++ b/src/main/java/net/minecraft/server/BlockFlowing.java
|
+++ b/src/main/java/net/minecraft/server/BlockFlowing.java
|
||||||
@@ -0,0 +0,0 @@ public class BlockFlowing extends BlockFluids {
|
@@ -0,0 +0,0 @@ public class BlockFlowing extends BlockFluids {
|
||||||
|
Loading…
Reference in New Issue
Block a user