1
0
forked from xjboss/KCauldronX

Add fake player do login

This commit is contained in:
xjboss 2017-07-02 19:55:18 +08:00
parent 0e0f8a1dc2
commit ad3dd74bd8
3 changed files with 56 additions and 24 deletions

View File

@ -54,11 +54,10 @@ minecraft {
mainClass = 'cpw.mods.fml.relauncher.ServerLaunchWrapper' mainClass = 'cpw.mods.fml.relauncher.ServerLaunchWrapper'
tweakClass = 'cpw.mods.fml.common.launcher.FMLTweaker' tweakClass = 'cpw.mods.fml.common.launcher.FMLTweaker'
installerVersion = "1.4" installerVersion = "1.4"
srgExtra "PK: org/bukkit/craftbukkit org/bukkit/craftbukkit/v1_7_R4" srgExtra "PK: org/bukkit/craftbukkit org/bukkit/craftbukkit/v1_7_R4"
} }
group = 'pw.prok' group = 'pw.prok'
ext.buildInfoCached = null; ext.buildInfoCached = null;
def buildInfo(String key) { def buildInfo(String key) {
@ -105,7 +104,7 @@ version = "${mcVersion}-${forgeVersion}.${revision}"
if (project.hasProperty('officialBuild')) println "Updated KCauldron version: ${version}" if (project.hasProperty('officialBuild')) println "Updated KCauldron version: ${version}"
launch4j { launch4j {
jreMinVersion = '1.6.0' jreMinVersion = '1.7.0'
} }
configurations { configurations {

View File

@ -8,11 +8,12 @@
import cpw.mods.fml.relauncher.Side; import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly; import cpw.mods.fml.relauncher.SideOnly;
import java.io.BufferedReader; import java.io.BufferedReader;
@@ -34,9 +35,21 @@ @@ -34,9 +35,23 @@
import net.minecraft.world.World; import net.minecraft.world.World;
import net.minecraft.world.WorldSettings; import net.minecraft.world.WorldSettings;
import net.minecraft.world.WorldType; import net.minecraft.world.WorldType;
+import net.minecraft.world.chunk.storage.AnvilSaveConverter; +import net.minecraft.world.chunk.storage.AnvilSaveConverter;
+import net.minecraftforge.common.MinecraftForge;
+import net.minecraftforge.common.util.FakePlayer; +import net.minecraftforge.common.util.FakePlayer;
+import net.minecraftforge.event.ForgeEventFactory; +import net.minecraftforge.event.ForgeEventFactory;
import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.LogManager;
@ -24,13 +25,14 @@
+ +
+import org.bukkit.craftbukkit.LoggerOutputStream; +import org.bukkit.craftbukkit.LoggerOutputStream;
+import org.bukkit.craftbukkit.SpigotTimings; // Spigot +import org.bukkit.craftbukkit.SpigotTimings; // Spigot
+import org.bukkit.event.player.PlayerLoginEvent;
+import org.bukkit.event.server.ServerCommandEvent; +import org.bukkit.event.server.ServerCommandEvent;
+// CraftBukkit end +// CraftBukkit end
+ +
@SideOnly(Side.SERVER) @SideOnly(Side.SERVER)
public class DedicatedServer extends MinecraftServer implements IServer public class DedicatedServer extends MinecraftServer implements IServer
{ {
@@ -44,7 +57,7 @@ @@ -44,7 +59,7 @@
public final List pendingCommandList = Collections.synchronizedList(new ArrayList()); public final List pendingCommandList = Collections.synchronizedList(new ArrayList());
private RConThreadQuery theRConThreadQuery; private RConThreadQuery theRConThreadQuery;
private RConThreadMain theRConThreadMain; private RConThreadMain theRConThreadMain;
@ -39,7 +41,7 @@
private ServerEula field_154332_n; private ServerEula field_154332_n;
private boolean canSpawnStructures; private boolean canSpawnStructures;
private WorldSettings.GameType gameType; private WorldSettings.GameType gameType;
@@ -52,10 +65,13 @@ @@ -52,10 +67,13 @@
public static boolean allowPlayerLogins = false; public static boolean allowPlayerLogins = false;
private static final String __OBFID = "CL_00001784"; private static final String __OBFID = "CL_00001784";
@ -56,7 +58,7 @@
{ {
private static final String __OBFID = "CL_00001787"; private static final String __OBFID = "CL_00001787";
{ {
@@ -82,31 +98,77 @@ @@ -82,31 +100,77 @@
}; };
} }
@ -141,7 +143,7 @@
field_155771_h.info("Starting minecraft server version 1.7.10"); field_155771_h.info("Starting minecraft server version 1.7.10");
if (Runtime.getRuntime().maxMemory() / 1024L / 1024L < 512L) if (Runtime.getRuntime().maxMemory() / 1024L / 1024L < 512L)
@@ -117,7 +179,7 @@ @@ -117,7 +181,7 @@
FMLCommonHandler.instance().onServerStart(this); FMLCommonHandler.instance().onServerStart(this);
field_155771_h.info("Loading properties"); field_155771_h.info("Loading properties");
@ -150,7 +152,7 @@
this.field_154332_n = new ServerEula(new File("eula.txt")); this.field_154332_n = new ServerEula(new File("eula.txt"));
if (!this.field_154332_n.func_154346_a()) if (!this.field_154332_n.func_154346_a())
@@ -172,6 +234,18 @@ @@ -172,6 +236,18 @@
this.setServerPort(this.settings.getIntProperty("server-port", 25565)); this.setServerPort(this.settings.getIntProperty("server-port", 25565));
} }
@ -169,7 +171,7 @@
field_155771_h.info("Generating keypair"); field_155771_h.info("Generating keypair");
this.setKeyPair(CryptManager.createNewKeyPair()); this.setKeyPair(CryptManager.createNewKeyPair());
field_155771_h.info("Starting Minecraft server on " + (this.getServerHostname().length() == 0 ? "*" : this.getServerHostname()) + ":" + this.getServerPort()); field_155771_h.info("Starting Minecraft server on " + (this.getServerHostname().length() == 0 ? "*" : this.getServerHostname()) + ":" + this.getServerPort());
@@ -180,7 +254,7 @@ @@ -180,7 +256,7 @@
{ {
this.func_147137_ag().addLanEndpoint(inetaddress, this.getServerPort()); this.func_147137_ag().addLanEndpoint(inetaddress, this.getServerPort());
} }
@ -178,7 +180,7 @@
{ {
field_155771_h.warn("**** FAILED TO BIND TO PORT!"); field_155771_h.warn("**** FAILED TO BIND TO PORT!");
field_155771_h.warn("The exception was: {}", new Object[] {ioexception.toString()}); field_155771_h.warn("The exception was: {}", new Object[] {ioexception.toString()});
@@ -196,10 +270,17 @@ @@ -196,10 +272,17 @@
field_155771_h.warn("To change this, set \"online-mode\" to \"true\" in the server.properties file."); field_155771_h.warn("To change this, set \"online-mode\" to \"true\" in the server.properties file.");
} }
@ -198,7 +200,7 @@
if (!PreYggdrasilConverter.func_152714_a(this.settings)) if (!PreYggdrasilConverter.func_152714_a(this.settings))
{ {
@@ -208,7 +289,8 @@ @@ -208,7 +291,8 @@
else else
{ {
FMLCommonHandler.instance().onServerStarted(); FMLCommonHandler.instance().onServerStarted();
@ -208,7 +210,7 @@
long j = System.nanoTime(); long j = System.nanoTime();
if (this.getFolderName() == null) if (this.getFolderName() == null)
@@ -274,11 +356,36 @@ @@ -274,11 +358,36 @@
this.theRConThreadMain.startThread(); this.theRConThreadMain.startThread();
} }
@ -225,7 +227,7 @@
+ // CraftBukkit end + // CraftBukkit end
+ // KCauldronX start + // KCauldronX start
+ for(FakePlayer fp:FakePlayer.fakePlayers){ + for(FakePlayer fp:FakePlayer.fakePlayers){
+ PlayerEvent.PlayerLoggedInEvent join=new PlayerEvent.PlayerLoggedInEvent(fp); + fp.callBukkitLoginEvent();
+ } + }
+ FakePlayer.fakePlayers=null; + FakePlayer.fakePlayers=null;
+ FakePlayer.BukkitInited=true; + FakePlayer.BukkitInited=true;
@ -245,7 +247,7 @@
public boolean canStructuresSpawn() public boolean canStructuresSpawn()
{ {
return this.canSpawnStructures; return this.canSpawnStructures;
@@ -364,11 +471,19 @@ @@ -364,11 +473,19 @@
public void executePendingCommands() public void executePendingCommands()
{ {

View File

@ -1,9 +1,10 @@
--- ../src-base/minecraft/net/minecraftforge/common/util/FakePlayer.java --- ../src-base/minecraft/net/minecraftforge/common/util/FakePlayer.java
+++ ../src-work/minecraft/net/minecraftforge/common/util/FakePlayer.java +++ ../src-work/minecraft/net/minecraftforge/common/util/FakePlayer.java
@@ -3,9 +3,11 @@ @@ -3,9 +3,12 @@
import com.mojang.authlib.GameProfile; import com.mojang.authlib.GameProfile;
import cpw.mods.fml.common.FMLCommonHandler; import cpw.mods.fml.common.FMLCommonHandler;
+import cpw.mods.fml.common.FMLLog;
+import cpw.mods.fml.common.gameevent.PlayerEvent; +import cpw.mods.fml.common.gameevent.PlayerEvent;
import net.minecraft.entity.player.EntityPlayer; import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.entity.player.EntityPlayerMP; import net.minecraft.entity.player.EntityPlayerMP;
@ -12,13 +13,21 @@
import net.minecraft.server.management.ItemInWorldManager; import net.minecraft.server.management.ItemInWorldManager;
import net.minecraft.stats.StatBase; import net.minecraft.stats.StatBase;
import net.minecraft.util.ChunkCoordinates; import net.minecraft.util.ChunkCoordinates;
@@ -13,13 +15,29 @@ @@ -13,15 +16,58 @@
import net.minecraft.util.IChatComponent; import net.minecraft.util.IChatComponent;
import net.minecraft.world.World; import net.minecraft.world.World;
import net.minecraft.world.WorldServer; import net.minecraft.world.WorldServer;
+import net.minecraftforge.cauldron.configuration.CauldronConfig; +import net.minecraftforge.cauldron.configuration.CauldronConfig;
+import net.minecraftforge.common.MinecraftForge;
+import net.minecraftforge.event.ForgeEventFactory; +import net.minecraftforge.event.ForgeEventFactory;
+import org.apache.logging.log4j.LogManager;
+import org.bukkit.Bukkit;
+import org.bukkit.craftbukkit.scheduler.CraftTask;
+import org.bukkit.event.player.AsyncPlayerPreLoginEvent;
+import org.bukkit.event.player.PlayerLoginEvent;
+import org.bukkit.event.player.PlayerPreLoginEvent;
+import java.net.InetAddress;
+import java.util.ArrayList; +import java.util.ArrayList;
+import java.util.HashSet; +import java.util.HashSet;
+import java.util.concurrent.ConcurrentSkipListSet; +import java.util.concurrent.ConcurrentSkipListSet;
@ -26,19 +35,41 @@
//Preliminary, simple Fake Player class //Preliminary, simple Fake Player class
public class FakePlayer extends EntityPlayerMP public class FakePlayer extends EntityPlayerMP
{ {
+ static public ArrayList<FakePlayer> fakePlayers=new ArrayList<>(); + static public ArrayList<FakePlayer> fakePlayers=new ArrayList();
+ static public boolean BukkitInited=false; + static public boolean BukkitInited=false;
public FakePlayer(WorldServer world, GameProfile name) public FakePlayer(WorldServer world, GameProfile name)
{ {
super(FMLCommonHandler.instance().getMinecraftServerInstance(), world, name, new ItemInWorldManager(world)); super(FMLCommonHandler.instance().getMinecraftServerInstance(), world, name, new ItemInWorldManager(world));
+ //KCauldronX Start + //KCauldronX Start
+ if(MinecraftServer.cauldronConfig.fakePlayerLogin.getValue()) + if(MinecraftServer.cauldronConfig.fakePlayerLogin.getValue()) {
+ if (!BukkitInited) { + if (!BukkitInited) {
+ fakePlayers.add(this); + fakePlayers.add(this);
+ } else { + } else {
+ PlayerEvent.PlayerLoggedInEvent join=new PlayerEvent.PlayerLoggedInEvent(this); + callBukkitLoginEvent();
+ }
+ } + }
+ //KCauldronX End + //KCauldronX End
} }
-
+ public void callBukkitLoginEvent(){
+ new Thread(new Runnable() {
+ @Override
+ public void run() {
+ AsyncPlayerPreLoginEvent prelogin2 = new AsyncPlayerPreLoginEvent(getCommandSenderName(), InetAddress.getLoopbackAddress(), getUniqueID());
+ Bukkit.getPluginManager().callEvent(prelogin2);
+ MinecraftServer.getServer().processQueue.add(new Runnable() {
+ @Override
+ public void run() {
+ PlayerPreLoginEvent prelogin1 = new PlayerPreLoginEvent(getCommandSenderName(), InetAddress.getLoopbackAddress(), getUniqueID());
+ Bukkit.getPluginManager().callEvent(prelogin1);
+ PlayerLoginEvent login = new PlayerLoginEvent(getBukkitEntity(), "localhost", InetAddress.getLoopbackAddress());
+ Bukkit.getPluginManager().callEvent(login);
+ FMLLog.info("%s","[KCauldronX] Fakeplayer "+getCommandSenderName()+" ("+getUniqueID()+") joined server");
+ }
+ });
+ }
+ }).start();
+ }
@Override public boolean canCommandSenderUseCommand(int i, String s){ return false; } @Override public boolean canCommandSenderUseCommand(int i, String s){ return false; }
@Override public ChunkCoordinates getPlayerCoordinates()
{