Jump to content
Sign in to follow this  
Inthedash6

Code Interlude Antibot

Recommended Posts

http://www.4shared.com/img/PnpeKHRNce/s25/157e7930310/image

http://www.4shared.com/rar/WiimsNndba/antibot.html Download data files

 

ACIS:

### Eclipse Workspace Patch 1.0
#P aCis_gameserver
Index: java/net/sf/l2j/gameserver/datatables/AntiBotTable.java
===================================================================
--- java/net/sf/l2j/gameserver/datatables/AntiBotTable.java	(revision 0)
+++ java/net/sf/l2j/gameserver/datatables/AntiBotTable.java	(revision 0)
@@ -0,0 +1,183 @@
+/*
+ * This program is free software: you can redistribute it and/or modify it under
+ * the terms of the GNU General Public License as published by the Free Software
+ * Foundation, either version 3 of the License, or (at your option) any later
+ * version.
+ * 
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
+ * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
+ * details.
+ * 
+ * You should have received a copy of the GNU General Public License along with
+ * this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+package net.sf.l2j.gameserver.datatables;
+
+import java.io.ByteArrayOutputStream;
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.IOException;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.Map.Entry;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import net.sf.l2j.gameserver.ThreadPoolManager;
+import net.sf.l2j.gameserver.model.actor.instance.L2PcInstance;
+import net.sf.l2j.gameserver.network.serverpackets.PledgeImage;
+import net.sf.l2j.util.Rnd;
+
+/**
+ * 
+ * @author Fissban
+ *
+ */
+public class AntiBotTable
+{
+	public static Logger _log = Logger.getLogger(AntiBotTable.class.getName());
+	
+	public static Map<Integer, antiBotData> _imageAntiBotOri = new HashMap<>();
+	public static Map<Integer, antiBotData> _imageAntiBotClient = new HashMap<>();
+	
+	public final static int[] img_antibot_id =
+	{
+		7000, 7001, 7002, 7003, 7004, 7005, 7006, 7007, 7008, 7009
+	};
+	
+	public void loadImage()
+	{
+		LoadImgAntiBot();
+		_log.log(Level.INFO, "loading " + _imageAntiBotOri.size() + " images of AntiBot");
+	}
+	
+	private static void LoadImgAntiBot()
+	{
+		_imageAntiBotOri.clear();
+		int cont = 0;
+		
+		for (int imgId : img_antibot_id)
+		{
+			File image = new File("data/images/antibot/" + imgId + ".dds");
+			_imageAntiBotOri.put(cont, new antiBotData(cont, ConverterImgBytes(image)));
+			cont++;
+		}
+		
+		ThreadPoolManager.getInstance().scheduleGeneralAtFixedRate(new startEncriptCaptcha(), 100, 600000); // 10 Minutes
+	}
+	
+	public void sendImage(L2PcInstance player, int imgId)
+	{
+		PledgeImage packet = null;
+		
+		if ((imgId >= 50000) && (imgId <= 800000))
+		{
+			for (Entry<Integer, antiBotData> entrySet : _imageAntiBotClient.entrySet())
+			{
+				antiBotData imgCoding = entrySet.getValue();
+				
+				if (imgId == imgCoding.getCodificacion())
+				{
+					packet = new PledgeImage(imgId, imgCoding.getImagen());
+				}
+			}
+		}
+		
+		player.sendPacket(packet);
+	}
+	
+	public static class startEncriptCaptcha implements Runnable
+	{
+		public startEncriptCaptcha()
+		{
+			
+		}
+		
+		@Override
+		public void run()
+		{
+			_imageAntiBotClient.clear();
+			
+			for (Entry<Integer, antiBotData> entrySet : _imageAntiBotOri.entrySet())
+			{
+				entrySet.getValue().getImagen();
+				_imageAntiBotClient.put(entrySet.getKey(), new antiBotData(Rnd.get(50000, 800000), entrySet.getValue().getImagen()));
+			}
+		}
+	}
+	
+	public int getAntiBotClientID(int pos)
+	{
+		int returnCoding = 0;
+		
+		for (Entry<Integer, antiBotData> entrySet : _imageAntiBotClient.entrySet())
+		{
+			int numeroImage = entrySet.getKey().intValue(); 
+			
+			if (pos == numeroImage)
+			{
+				antiBotData imgCoding = entrySet.getValue();
+				returnCoding = imgCoding.getCodificacion();
+			}
+			
+			if (pos > 9)
+			{
+				_log.log(Level.SEVERE, "error in getAntiBotClientID...number dont exist");
+			}
+		}
+		return returnCoding;
+	}
+	
+	public static class antiBotData
+	{
+		int _codificacion;
+		byte[] _data;
+		
+		public antiBotData(int codificacion, byte[] data)
+		{
+			_codificacion = codificacion;
+			_data = data;
+		}
+		
+		public int getCodificacion()
+		{
+			return _codificacion;
+		}
+		
+		public byte[] getImagen()
+		{
+			return _data;
+		}
+	}
+	
+	private static byte[] ConverterImgBytes(File imagen)
+	{
+		ByteArrayOutputStream bos = new ByteArrayOutputStream();
+		
+		byte[] buffer = new byte[1024];
+		try (FileInputStream fis = new FileInputStream(imagen))
+		{
+			for (int readNum; (readNum = fis.read(buffer)) != -1;)
+			{
+				bos.write(buffer, 0, readNum);
+			}
+		}
+		catch (IOException e)
+		{
+			_log.log(Level.SEVERE, "Error when converter image to byte[]");
+		}
+		
+		return bos.toByteArray();
+	}
+	
+	public static AntiBotTable getInstance()
+	{
+		return SingletonHolder._instance;
+	}
+	
+	private static class SingletonHolder
+	{
+		protected static final AntiBotTable _instance = new AntiBotTable();
+	}
+}
Index: java/net/sf/l2j/gameserver/GameServer.java
===================================================================
--- java/net/sf/l2j/gameserver/GameServer.java	(revision 13)
+++ java/net/sf/l2j/gameserver/GameServer.java	(working copy)
@@ -35,6 +35,7 @@
 import net.sf.l2j.gameserver.communitybbs.Manager.ForumsBBSManager;
 import net.sf.l2j.gameserver.datatables.AccessLevels;
 import net.sf.l2j.gameserver.datatables.AdminCommandAccessRights;
+import net.sf.l2j.gameserver.datatables.AntiBotTable;
 import net.sf.l2j.gameserver.datatables.ArmorSetsTable;
 import net.sf.l2j.gameserver.datatables.AugmentationData;
 import net.sf.l2j.gameserver.datatables.BookmarkTable;
@@ -309,6 +310,8 @@
 		
 		MovieMakerManager.getInstance();
 		
+		AntiBotTable.getInstance().loadImage();
+		
 		if (Config.DEADLOCK_DETECTOR)
 		{
 			_log.info("Deadlock detector is enabled. Timer: " + Config.DEADLOCK_CHECK_INTERVAL + "s.");
Index: java/net/sf/l2j/Config.java
===================================================================
--- java/net/sf/l2j/Config.java	(revision 13)
+++ java/net/sf/l2j/Config.java	(working copy)
@@ -513,6 +513,13 @@
 	public static boolean STORE_SKILL_COOLTIME;
 	public static int BUFFS_MAX_AMOUNT;
 	
+	/** AntiBot */
+	public static boolean ANTIBOT_ENABLE;
+	public static int ANTIBOT_TIME_JAIL;
+	public static int ANTIBOT_TIME_VOTE;
+	public static int ANTIBOT_KILL_MOBS;
+	public static int ANTIBOT_MIN_LEVEL;
+	
 	// --------------------------------------------------
 	// Server
 	// --------------------------------------------------
@@ -1110,6 +1117,12 @@
 			BUFFS_MAX_AMOUNT = players.getProperty("MaxBuffsAmount", 20);
 			STORE_SKILL_COOLTIME = players.getProperty("StoreSkillCooltime", true);
 			
+			ANTIBOT_ENABLE = players.getProperty("AntiBotEnable", true);
+			ANTIBOT_TIME_JAIL = players.getProperty("AntiBotTimeJail", 1);
+			ANTIBOT_TIME_VOTE = players.getProperty("AntiBotTimeVote", 30);
+			ANTIBOT_KILL_MOBS = players.getProperty("AntiBotKillMobs", 1);
+			ANTIBOT_MIN_LEVEL = players.getProperty("AntiBotMinLevel", 1);				
+			
 			// server
 			ExProperties server = load(SERVER_FILE);
 			
Index: java/net/sf/l2j/gameserver/network/clientpackets/RequestBypassToServer.java
===================================================================
--- java/net/sf/l2j/gameserver/network/clientpackets/RequestBypassToServer.java	(revision 13)
+++ java/net/sf/l2j/gameserver/network/clientpackets/RequestBypassToServer.java	(working copy)
@@ -179,6 +179,18 @@
 				final int arenaId = Integer.parseInt(_command.substring(12).trim());
 				activeChar.enterOlympiadObserverMode(arenaId);
 			}
+			else if (_command.startsWith("antibot"))
+			{
+				StringTokenizer st = new StringTokenizer(_command);
+				st.nextToken();
+				
+				if (st.hasMoreTokens())
+				{
+					activeChar.checkCode(st.nextToken());
+					return;
+				}
+				activeChar.checkCode("Fail");
+			}
 		}
 		catch (Exception e)
 		{
Index: java/net/sf/l2j/gameserver/network/clientpackets/Say2.java
===================================================================
--- java/net/sf/l2j/gameserver/network/clientpackets/Say2.java	(revision 13)
+++ java/net/sf/l2j/gameserver/network/clientpackets/Say2.java	(working copy)
@@ -49,6 +49,7 @@
 	public final static int PARTYROOM_COMMANDER = 15; // (Yellow)
 	public final static int PARTYROOM_ALL = 16; // (Red)
 	public final static int HERO_VOICE = 17;
+	public final static int CRITICAL_ANNOUNCE = 18;
 	
 	private final static String[] CHAT_NAMES =
 	{
@@ -69,7 +70,8 @@
 		"PARTYMATCH_ROOM",
 		"PARTYROOM_COMMANDER",
 		"PARTYROOM_ALL",
-		"HERO_VOICE"
+		"HERO_VOICE",
+		"CRITICAL_ANNOUNCE"
 	};
 	
 	private static final String[] WALKER_COMMAND_LIST =
Index: java/net/sf/l2j/gameserver/network/serverpackets/PledgeImage.java
===================================================================
--- java/net/sf/l2j/gameserver/network/serverpackets/PledgeImage.java	(revision 0)
+++ java/net/sf/l2j/gameserver/network/serverpackets/PledgeImage.java	(revision 0)
@@ -0,0 +1,44 @@
+/*
+ * This program is free software: you can redistribute it and/or modify it under
+ * the terms of the GNU General Public License as published by the Free Software
+ * Foundation, either version 3 of the License, or (at your option) any later
+ * version.
+ * 
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
+ * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
+ * details.
+ * 
+ * You should have received a copy of the GNU General Public License along with
+ * this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+package net.sf.l2j.gameserver.network.serverpackets;
+
+public class PledgeImage extends L2GameServerPacket
+{
+	private final int _crestId;
+	private final byte[] _data;
+	
+	public PledgeImage(int crestId, byte[] data)
+	{
+		_crestId = crestId;
+		_data = data;
+	}
+	
+	@Override
+	protected final void writeImpl()
+	{
+		writeC(0x6c);
+		writeD(_crestId);
+		
+		if (_data != null)
+		{
+			writeD(_data.length);
+			writeB(_data);
+		}
+		else
+		{
+			writeD(0);
+		}
+	}
+}
\ No newline at end of file
Index: java/net/sf/l2j/gameserver/model/actor/instance/L2PcInstance.java
===================================================================
--- java/net/sf/l2j/gameserver/model/actor/instance/L2PcInstance.java	(revision 13)
+++ java/net/sf/l2j/gameserver/model/actor/instance/L2PcInstance.java	(working copy)
@@ -48,6 +48,7 @@
 import net.sf.l2j.gameserver.communitybbs.BB.Forum;
 import net.sf.l2j.gameserver.communitybbs.Manager.ForumsBBSManager;
 import net.sf.l2j.gameserver.datatables.AccessLevels;
+import net.sf.l2j.gameserver.datatables.AntiBotTable;
 import net.sf.l2j.gameserver.datatables.CharNameTable;
 import net.sf.l2j.gameserver.datatables.CharTemplateTable;
 import net.sf.l2j.gameserver.datatables.ClanTable;
@@ -157,12 +158,14 @@
 import net.sf.l2j.gameserver.model.zone.type.L2BossZone;
 import net.sf.l2j.gameserver.network.L2GameClient;
 import net.sf.l2j.gameserver.network.SystemMessageId;
+import net.sf.l2j.gameserver.network.clientpackets.Say2;
 import net.sf.l2j.gameserver.network.serverpackets.AbstractNpcInfo;
 import net.sf.l2j.gameserver.network.serverpackets.ActionFailed;
 import net.sf.l2j.gameserver.network.serverpackets.ChairSit;
 import net.sf.l2j.gameserver.network.serverpackets.ChangeWaitType;
 import net.sf.l2j.gameserver.network.serverpackets.CharInfo;
 import net.sf.l2j.gameserver.network.serverpackets.ConfirmDlg;
+import net.sf.l2j.gameserver.network.serverpackets.CreatureSay;
 import net.sf.l2j.gameserver.network.serverpackets.EtcStatusUpdate;
 import net.sf.l2j.gameserver.network.serverpackets.ExAutoSoulShot;
 import net.sf.l2j.gameserver.network.serverpackets.ExDuelUpdateUserInfo;
@@ -170,6 +173,7 @@
 import net.sf.l2j.gameserver.network.serverpackets.ExFishingStart;
 import net.sf.l2j.gameserver.network.serverpackets.ExOlympiadMode;
 import net.sf.l2j.gameserver.network.serverpackets.ExSetCompassZoneCode;
+import net.sf.l2j.gameserver.network.serverpackets.ExShowScreenMessage;
 import net.sf.l2j.gameserver.network.serverpackets.ExStorageMaxCount;
 import net.sf.l2j.gameserver.network.serverpackets.FriendList;
 import net.sf.l2j.gameserver.network.serverpackets.GetOnVehicle;
@@ -219,6 +223,7 @@
 import net.sf.l2j.gameserver.network.serverpackets.TradePressOwnOk;
 import net.sf.l2j.gameserver.network.serverpackets.TradeStart;
 import net.sf.l2j.gameserver.network.serverpackets.UserInfo;
+import net.sf.l2j.gameserver.skills.AbnormalEffect;
 import net.sf.l2j.gameserver.skills.Env;
 import net.sf.l2j.gameserver.skills.Formulas;
 import net.sf.l2j.gameserver.skills.Stats;
@@ -364,6 +369,11 @@
 		}
 	}
 	
+	private String _code = "";
+	private int _attempt = 0;
+	private int _mobs_dead = 0;
+	public static ScheduledFuture<?> _antiBotTask;
+	
 	private L2GameClient _client;
 	
 	private String _accountName;
@@ -10647,4 +10657,183 @@
 			}
 		}
 	}
+	
+	// AntiBoot
+	public void antibot()
+	{
+		increaseMobsDead();
+		
+		if (getMobsDead() >= Config.ANTIBOT_KILL_MOBS)
+		{
+			resetMobsDead();
+			_antiBotTask = ThreadPoolManager.getInstance().scheduleGeneral(new startAntiBotTask(), Config.ANTIBOT_TIME_VOTE * 1000);
+		}
+	}
+	
+	private static void stopAntiBotTask()
+	{
+		if (_antiBotTask != null)
+		{
+			_antiBotTask.cancel(false);
+			_antiBotTask = null;
+		}
+	}
+	
+	private class startAntiBotTask implements Runnable
+	{
+		public startAntiBotTask()
+		{
+			setIsParalyzed(true);
+			setIsInvul(true);
+			startAbnormalEffect(AbnormalEffect.FLOATING_ROOT);
+			sendPacket(new ExShowScreenMessage("[AntiBot]: You have " + Config.ANTIBOT_TIME_VOTE + " to confirm the Captcha!", 10000));
+			getActingPlayer().sendPacket(new CreatureSay(0, Say2.CRITICAL_ANNOUNCE, "[AntiBot]:", "You have " + Config.ANTIBOT_TIME_VOTE + " to confirm the Catpcha."));
+			showHtml_Start();
+		}
+		
+		@Override
+		public void run()
+		{
+			if (!isInJail())
+			{
+				sendPacket(new CreatureSay(0, Say2.HERO_VOICE, "[AntiBot]:", "Your time limit has elapsed."));
+				increaseAttempt();
+				
+				if (getAttempt() >= 3)
+				{
+					setIsParalyzed(false);
+					setIsInvul(false);
+					startAbnormalEffect(AbnormalEffect.FLOATING_ROOT);
+					getActingPlayer().setPunishLevel(L2PcInstance.PunishLevel.JAIL, Config.ANTIBOT_TIME_JAIL);
+					getActingPlayer().sendPacket(new CreatureSay(0, Say2.HERO_VOICE, "[AntiBot]:", "Character " + getName() + " jailed for " + Config.ANTIBOT_TIME_JAIL + " minutes."));
+					_log.warning("[AntiBot]: Character " + getName() + " jailed for " + Config.ANTIBOT_TIME_JAIL + " minutes.");
+				}
+				else
+				{
+					_antiBotTask = ThreadPoolManager.getInstance().scheduleGeneral(new startAntiBotTask(), Config.ANTIBOT_TIME_VOTE * 1000);
+				}
+			}
+		}
+	}
+	
+	public String num2img(int numero) 
+	{
+		String num = Integer.toString(numero);
+		char[] digitos = num.toCharArray();
+		
+		String tmp = "";
+		for(int x=0;x<num.length();x++) 
+		{
+			int dig = Integer.parseInt(Character.toString(digitos[x]));
+			final int it = AntiBotTable.getInstance().getAntiBotClientID(dig);
+			AntiBotTable.getInstance().sendImage(this, it);
+			tmp += "<img src=Crest.crest_" + Config.SERVER_ID + "_" + it + " width=38 height=33 align=left>";
+		}
+		
+		return tmp;
+	}
+	
+	public void showHtml_Start()
+	{
+		NpcHtmlMessage html = new NpcHtmlMessage(0);
+		html.setFile("data/html/antiBot/start.htm");
+		
+		html.replace("%playerName%", getName());
+		html.replace("%attemp%", String.valueOf(3 - getAttempt()));
+		int maxR = 3;
+		
+		String random = new String();
+		
+		for(int x = 0; x<maxR; x++)
+			random += Integer.toString(Rnd.get(0,9));
+		
+		html.replace("%code1%",num2img(Integer.parseInt(random)));
+				
+		this.sendPacket(html);
+		setCode(String.valueOf(Integer.parseInt(random)));
+	}
+	
+	public void showHtml_End()
+	{
+		NpcHtmlMessage html = new NpcHtmlMessage(0);
+		html.setFile("data/html/antiBot/end.htm");
+		html.replace("%playerName%", getName());
+		
+		this.sendPacket(html);
+	}
+	
+	public void checkCode(String code)
+	{
+		if (code.equals(getCode()))
+		{
+			stopAntiBotTask();
+			resetAttempt();
+			
+			sendPacket(new CreatureSay(0, Say2.HERO_VOICE, "[AntiBot]:", "Congratulations, has passed control."));
+			setIsParalyzed(false);
+			setIsInvul(false);
+			stopAbnormalEffect(AbnormalEffect.FLOATING_ROOT);
+		}
+		else
+		{
+			stopAntiBotTask();
+			increaseAttempt();
+			
+			_antiBotTask = ThreadPoolManager.getInstance().scheduleGeneral(new startAntiBotTask(), Config.ANTIBOT_TIME_VOTE * 1000);
+		}
+		
+		if (getAttempt() >= 3)
+		{
+			stopAntiBotTask();
+			resetAttempt();
+			
+			setIsParalyzed(false);
+			setIsInvul(false);
+			startAbnormalEffect(AbnormalEffect.FLOATING_ROOT);
+			
+			setPunishLevel(PunishLevel.JAIL, Config.ANTIBOT_TIME_JAIL);
+			sendPacket(new CreatureSay(0, Say2.HERO_VOICE, "[AntiBot]:", "Character " + getName() + " jailed for " + Config.ANTIBOT_TIME_JAIL + " minutes."));
+			_log.warning("[AntiBot]: Character " + getName() + " jailed for " + Config.ANTIBOT_TIME_JAIL + " minutes.");
+		}
+	}
+	
+	private int getMobsDead()
+	{
+		return _mobs_dead;
+	}
+	
+	private void increaseMobsDead()
+	{
+		_mobs_dead++;
+	}
+	
+	private void resetMobsDead()
+	{
+		_mobs_dead = 0;
+	}
+	
+	private void setCode(String code)
+	{
+		_code = code;
+	}
+	
+	private String getCode()
+	{
+		return _code;
+	}
+	
+	public void increaseAttempt()
+	{
+		_attempt += 1;
+	}
+	
+	public int getAttempt()
+	{
+		return _attempt;
+	}
+	
+	public void resetAttempt()
+	{
+		_attempt = 0;
+	}	
 }
\ No newline at end of file
Index: java/net/sf/l2j/gameserver/model/actor/L2Attackable.java
===================================================================
--- java/net/sf/l2j/gameserver/model/actor/L2Attackable.java	(revision 13)
+++ java/net/sf/l2j/gameserver/model/actor/L2Attackable.java	(working copy)
@@ -450,6 +450,12 @@
 		if (!super.doDie(killer))
 			return false;
 		
+		// AntiBot
+		if (Config.ANTIBOT_ENABLE && (killer != null) && killer instanceof L2PcInstance && (killer.getLevel() >= Config.ANTIBOT_MIN_LEVEL))
+		{
+			killer.getActingPlayer().antibot();
+		}
+		
 		// Notify the Quest Engine of the L2Attackable death if necessary
 		try
 		{
Index: config/players.properties
===================================================================
--- config/players.properties	(revision 13)
+++ config/players.properties	(working copy)
@@ -294,4 +294,23 @@
 MaxBuffsAmount = 20
 
 # Store buffs/debuffs on user logout?
-StoreSkillCooltime = True
\ No newline at end of file
+StoreSkillCooltime = True
+
+#=============================================================
+#                        AntiBot 
+#=============================================================
+
+# AntiBot. True to enable, False to disable.
+AntiBotEnable = True
+
+# Time the user will be in jail in minutes.
+AntiBotTimeJail = 10
+
+# Time that the user will have to control captcha in seconds.
+AntiBotTimeVote = 40
+
+# Dead mobs needed for captcha.
+AntiBotKillMobs = 100
+
+# Level min need for captcha.
+AntiBotMinLevel = 1
\ No newline at end of file

Frozen:

### Eclipse Workspace Patch 1.0
#P L2jFrozen_GameServer
Index: head-src/com/l2jfrozen/gameserver/model/L2Attackable.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/model/L2Attackable.java	(revision 1118)
+++ head-src/com/l2jfrozen/gameserver/model/L2Attackable.java	(working copy)
@@ -542,6 +542,12 @@
 			LOGGER.error("", e);
 		}
 		
+		// AntiBot
+		if (Config.ANTIBOT_ENABLE && (killer != null) && killer instanceof L2PcInstance && (killer.getLevel() >= Config.ANTIBOT_MIN_LEVEL))
+		{
+			killer.getActingPlayer().antibot();
+		}
+		
 		// Notify the Quest Engine of the L2Attackable death if necessary
 		try
 		{
Index: head-src/com/l2jfrozen/gameserver/datatables/AntiBotTable.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/datatables/AntiBotTable.java	(revision 0)
+++ head-src/com/l2jfrozen/gameserver/datatables/AntiBotTable.java	(revision 0)
@@ -0,0 +1,183 @@
+/*
+ * This program is free software: you can redistribute it and/or modify it under
+ * the terms of the GNU General Public License as published by the Free Software
+ * Foundation, either version 3 of the License, or (at your option) any later
+ * version.
+ * 
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
+ * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
+ * details.
+ * 
+ * You should have received a copy of the GNU General Public License along with
+ * this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+package com.l2jfrozen.gameserver.datatables;
+
+import java.io.ByteArrayOutputStream;
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.IOException;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.Map.Entry;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import com.l2jfrozen.gameserver.model.actor.instance.L2PcInstance;
+import com.l2jfrozen.gameserver.network.serverpackets.PledgeImage;
+import com.l2jfrozen.gameserver.thread.ThreadPoolManager;
+import com.l2jfrozen.util.random.Rnd;
+
+/**
+ * 
+ * @author Fissban
+ *
+ */
+public class AntiBotTable
+{
+	public static Logger _log = Logger.getLogger(AntiBotTable.class.getName());
+	
+	public static Map<Integer, antiBotData> _imageAntiBotOri = new HashMap<>();
+	public static Map<Integer, antiBotData> _imageAntiBotClient = new HashMap<>();
+	
+	public final static int[] img_antibot_id =
+	{
+		7000, 7001, 7002, 7003, 7004, 7005, 7006, 7007, 7008, 7009
+	};
+	
+	public void loadImage()
+	{
+		LoadImgAntiBot();
+		_log.log(Level.INFO, "loading " + _imageAntiBotOri.size() + " images of AntiBot");
+	}
+	
+	private static void LoadImgAntiBot()
+	{
+		_imageAntiBotOri.clear();
+		int cont = 0;
+		
+		for (int imgId : img_antibot_id)
+		{
+			File image = new File("data/images/antibot/" + imgId + ".dds");
+			_imageAntiBotOri.put(cont, new antiBotData(cont, ConverterImgBytes(image)));
+			cont++;
+		}
+		
+		ThreadPoolManager.getInstance().scheduleGeneralAtFixedRate(new startEncriptCaptcha(), 100, 600000); // 10 Minutes
+	}
+	
+	public void sendImage(L2PcInstance player, int imgId)
+	{
+		PledgeImage packet = null;
+		
+		if ((imgId >= 50000) && (imgId <= 800000))
+		{
+			for (Entry<Integer, antiBotData> entrySet : _imageAntiBotClient.entrySet())
+			{
+				antiBotData imgCoding = entrySet.getValue();
+				
+				if (imgId == imgCoding.getCodificacion())
+				{
+					packet = new PledgeImage(imgId, imgCoding.getImagen());
+				}
+			}
+		}
+		
+		player.sendPacket(packet);
+	}
+	
+	public static class startEncriptCaptcha implements Runnable
+	{
+		public startEncriptCaptcha()
+		{
+			
+		}
+		
+		@Override
+		public void run()
+		{
+			_imageAntiBotClient.clear();
+			
+			for (Entry<Integer, antiBotData> entrySet : _imageAntiBotOri.entrySet())
+			{
+				entrySet.getValue().getImagen();
+				_imageAntiBotClient.put(entrySet.getKey(), new antiBotData(Rnd.get(50000, 800000), entrySet.getValue().getImagen()));
+			}
+		}
+	}
+	
+	public int getAntiBotClientID(int pos)
+	{
+		int returnCoding = 0;
+		
+		for (Entry<Integer, antiBotData> entrySet : _imageAntiBotClient.entrySet())
+		{
+			int numeroImage = entrySet.getKey().intValue(); 
+			
+			if (pos == numeroImage)
+			{
+				antiBotData imgCoding = entrySet.getValue();
+				returnCoding = imgCoding.getCodificacion();
+			}
+			
+			if (pos > 9)
+			{
+				_log.log(Level.SEVERE, "error in getAntiBotClientID...number dont exist");
+			}
+		}
+		return returnCoding;
+	}
+	
+	public static class antiBotData
+	{
+		int _codificacion;
+		byte[] _data;
+		
+		public antiBotData(int codificacion, byte[] data)
+		{
+			_codificacion = codificacion;
+			_data = data;
+		}
+		
+		public int getCodificacion()
+		{
+			return _codificacion;
+		}
+		
+		public byte[] getImagen()
+		{
+			return _data;
+		}
+	}
+	
+	private static byte[] ConverterImgBytes(File imagen)
+	{
+		ByteArrayOutputStream bos = new ByteArrayOutputStream();
+		
+		byte[] buffer = new byte[1024];
+		try (FileInputStream fis = new FileInputStream(imagen))
+		{
+			for (int readNum; (readNum = fis.read(buffer)) != -1;)
+			{
+				bos.write(buffer, 0, readNum);
+			}
+		}
+		catch (IOException e)
+		{
+			_log.log(Level.SEVERE, "Error when converter image to byte[]");
+		}
+		
+		return bos.toByteArray();
+	}
+	
+	public static AntiBotTable getInstance()
+	{
+		return SingletonHolder._instance;
+	}
+	
+	private static class SingletonHolder
+	{
+		protected static final AntiBotTable _instance = new AntiBotTable();
+	}
+}
\ No newline at end of file
Index: head-src/com/l2jfrozen/gameserver/network/serverpackets/PledgeImage.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/network/serverpackets/PledgeImage.java	(revision 0)
+++ head-src/com/l2jfrozen/gameserver/network/serverpackets/PledgeImage.java	(revision 0)
@@ -0,0 +1,50 @@
+/*
+ * This program is free software: you can redistribute it and/or modify it under
+ * the terms of the GNU General Public License as published by the Free Software
+ * Foundation, either version 3 of the License, or (at your option) any later
+ * version.
+ * 
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
+ * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
+ * details.
+ * 
+ * You should have received a copy of the GNU General Public License along with
+ * this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+package com.l2jfrozen.gameserver.network.serverpackets;
+
+public class PledgeImage extends L2GameServerPacket
+{
+	private final int _crestId;
+	private final byte[] _data;
+	
+	public PledgeImage(int crestId, byte[] data)
+	{
+		_crestId = crestId;
+		_data = data;
+	}
+	
+	@Override
+	protected final void writeImpl()
+	{
+		writeC(0x6c);
+		writeD(_crestId);
+		
+		if (_data != null)
+		{
+			writeD(_data.length);
+			writeB(_data);
+		}
+		else
+		{
+			writeD(0);
+		}
+	}
+
+	@Override
+	public String getType()
+	{
+		return null;
+	}
+}
Index: head-src/com/l2jfrozen/gameserver/GameServer.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/GameServer.java	(revision 1118)
+++ head-src/com/l2jfrozen/gameserver/GameServer.java	(working copy)
@@ -44,6 +44,7 @@
 import com.l2jfrozen.gameserver.controllers.GameTimeController;
 import com.l2jfrozen.gameserver.controllers.RecipeController;
 import com.l2jfrozen.gameserver.controllers.TradeController;
+import com.l2jfrozen.gameserver.datatables.AntiBotTable;
 import com.l2jfrozen.gameserver.datatables.GmListTable;
 import com.l2jfrozen.gameserver.datatables.HeroSkillTable;
 import com.l2jfrozen.gameserver.datatables.NobleSkillTable;
@@ -423,6 +424,9 @@
 		AdminCommandAccessRights.getInstance();
 		GmListTable.getInstance();
 		
+		Util.printSection("AntiBot");
+		AntiBotTable.getInstance().loadImage();
+		
 		Util.printSection("Handlers");
 		ItemHandler.getInstance();
 		SkillHandler.getInstance();
Index: config/head/other.properties
===================================================================
--- config/head/other.properties	(revision 1118)
+++ config/head/other.properties	(working copy)
@@ -239,4 +239,23 @@
 ClickTask = 50
 
 # Crit announce
-GMShowCritAnnouncerName = False
\ No newline at end of file
+GMShowCritAnnouncerName = False
+
+#=============================================================
+#                        AntiBot 
+#=============================================================
+
+# AntiBot. True to enable, False to disable.
+AntiBotEnable = True
+
+# Time the user will be in jail in minutes.
+AntiBotTimeJail = 10
+
+# Time that the user will have to control captcha in seconds.
+AntiBotTimeVote = 40
+
+# Dead mobs needed for captcha.
+AntiBotKillMobs = 100
+
+# Level min need for captcha.
+AntiBotMinLevel = 1
\ No newline at end of file
Index: head-src/com/l2jfrozen/gameserver/model/actor/instance/L2PcInstance.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/model/actor/instance/L2PcInstance.java	(revision 1118)
+++ head-src/com/l2jfrozen/gameserver/model/actor/instance/L2PcInstance.java	(working copy)
@@ -61,6 +61,7 @@
 import com.l2jfrozen.gameserver.controllers.GameTimeController;
 import com.l2jfrozen.gameserver.controllers.RecipeController;
 import com.l2jfrozen.gameserver.datatables.AccessLevel;
+import com.l2jfrozen.gameserver.datatables.AntiBotTable;
 import com.l2jfrozen.gameserver.datatables.GmListTable;
 import com.l2jfrozen.gameserver.datatables.HeroSkillTable;
 import com.l2jfrozen.gameserver.datatables.NobleSkillTable;
@@ -175,6 +176,7 @@
 import com.l2jfrozen.gameserver.network.serverpackets.ExOlympiadUserInfo;
 import com.l2jfrozen.gameserver.network.serverpackets.ExPCCafePointInfo;
 import com.l2jfrozen.gameserver.network.serverpackets.ExSetCompassZoneCode;
+import com.l2jfrozen.gameserver.network.serverpackets.ExShowScreenMessage;
 import com.l2jfrozen.gameserver.network.serverpackets.FriendList;
 import com.l2jfrozen.gameserver.network.serverpackets.HennaInfo;
 import com.l2jfrozen.gameserver.network.serverpackets.InventoryUpdate;
@@ -712,6 +714,12 @@
 		}
 	}
 	
+	/** AntiBot. */
+	private String _code = "";
+	private int _attempt = 0;
+	private int _mobs_dead = 0;
+	public static ScheduledFuture<?> _antiBotTask;
+	
 	/** The _client. */
 	private L2GameClient _client;
 	
@@ -18740,6 +18748,8 @@
 	// during fall validations will be disabled for 10 ms.
 	/** The Constant FALLING_VALIDATION_DELAY. */
 	private static final int FALLING_VALIDATION_DELAY = 10000;
+
+	public static final String Say2 = null;
 	
 	/** The _falling timestamp. */
 	private long _fallingTimestamp = 0;
@@ -19644,4 +19654,182 @@
 		_currentPetSkill = new SkillDat(currentSkill, ctrlPressed, shiftPressed);
 	}
 	
+	// AntiBot
+	public void antibot()
+	{
+		increaseMobsDead();
+		
+		if (getMobsDead() >= Config.ANTIBOT_KILL_MOBS)
+		{
+			resetMobsDead();
+			_antiBotTask = ThreadPoolManager.getInstance().scheduleGeneral(new startAntiBotTask(), Config.ANTIBOT_TIME_VOTE * 1000);
+		}
+	}
+	
+	private static void stopAntiBotTask()
+	{
+		if (_antiBotTask != null)
+		{
+			_antiBotTask.cancel(false);
+			_antiBotTask = null;
+		}
+	}
+	
+	private class startAntiBotTask implements Runnable
+	{
+		public startAntiBotTask()
+		{
+			setIsParalyzed(true);
+			setIsInvul(true);
+			startAbnormalEffect(L2Character.ABNORMAL_EFFECT_FLOATING_ROOT);
+			sendPacket(new ExShowScreenMessage("[AntiBot]: You have " + Config.ANTIBOT_TIME_VOTE + " to confirm the Captcha!", 10000));
+			getActingPlayer().sendPacket(new CreatureSay(0, Say2.CRITICAL_ANNOUNCE, "[AntiBot]:", "You have " + Config.ANTIBOT_TIME_VOTE + " to confirm the Catpcha."));
+			showHtml_Start();			
+		}
+		
+		@Override
+		public void run()
+		{
+			if (!isInJail())
+			{
+				sendPacket(new CreatureSay(0, Say2.HERO_VOICE, "[AntiBot]:", "Your time limit has elapsed."));
+				increaseAttempt();
+				
+				if (getAttempt() >= 3)
+				{
+					setIsParalyzed(false);
+					setIsInvul(false);
+					startAbnormalEffect(L2Character.ABNORMAL_EFFECT_FLOATING_ROOT);
+					getActingPlayer().setPunishLevel(L2PcInstance.PunishLevel.JAIL, Config.ANTIBOT_TIME_JAIL);
+					getActingPlayer().sendPacket(new CreatureSay(0, Say2.HERO_VOICE, "[AntiBot]:", "Character " + getName() + " jailed for " + Config.ANTIBOT_TIME_JAIL + " minutes."));
+					LOGGER.warn("[AntiBot]: Character " + getName() + " jailed for " + Config.ANTIBOT_TIME_JAIL + " minutes.");					
+				}
+				else
+				{
+					_antiBotTask = ThreadPoolManager.getInstance().scheduleGeneral(new startAntiBotTask(), Config.ANTIBOT_TIME_VOTE * 1000);
+				}
+			}
+		}
+	}
+	
+	public String num2img(int numero) 
+	{
+		String num = Integer.toString(numero);
+		char[] digitos = num.toCharArray();
+		
+		String tmp = "";
+		for(int x=0;x<num.length();x++) 
+		{
+			int dig = Integer.parseInt(Character.toString(digitos[x]));
+			final int it = AntiBotTable.getInstance().getAntiBotClientID(dig);
+			AntiBotTable.getInstance().sendImage(this, it);
+			tmp += "<img src=Crest.crest_" + Config.SERVER_ID + "_" + it + " width=38 height=33 align=left>";
+		}
+		
+		return tmp;
+	}
+	
+	public void showHtml_Start()
+	{
+		NpcHtmlMessage html = new NpcHtmlMessage(0);
+		html.setFile("data/html/antiBot/start.htm");
+		
+		html.replace("%playerName%", getName());
+		html.replace("%attemp%", String.valueOf(3 - getAttempt()));
+		int maxR = 3;
+		
+		String random = new String();
+		
+		for(int x = 0; x<maxR; x++)
+			random += Integer.toString(Rnd.get(0,9));
+		
+		html.replace("%code1%",num2img(Integer.parseInt(random)));
+		
+		this.sendPacket(html);
+		setCode(String.valueOf(Integer.parseInt(random)));
+	}
+	
+	public void showHtml_End()
+	{
+		NpcHtmlMessage html = new NpcHtmlMessage(0);
+		html.setFile("data/html/antiBot/end.htm");
+		html.replace("%playerName%", getName());
+		
+		this.sendPacket(html);
+	}
+	
+	public void checkCode(String code)
+	{
+		if (code.equals(getCode()))
+		{
+			stopAntiBotTask();
+			resetAttempt();
+			
+			sendPacket(new CreatureSay(0, Say2.HERO_VOICE, "[AntiBot]:", "Congratulations, has passed control."));
+			setIsParalyzed(false);
+			setIsInvul(false);
+			stopAbnormalEffect(L2Character.ABNORMAL_EFFECT_FLOATING_ROOT);
+		}
+		else
+		{
+			stopAntiBotTask();
+			increaseAttempt();
+			
+			_antiBotTask = ThreadPoolManager.getInstance().scheduleGeneral(new startAntiBotTask(), Config.ANTIBOT_TIME_VOTE * 1000);
+		}
+		
+		if (getAttempt() >= 3)
+		{
+			stopAntiBotTask();
+			resetAttempt();
+			
+			setIsParalyzed(false);
+			setIsInvul(false);
+			startAbnormalEffect(L2Character.ABNORMAL_EFFECT_FLOATING_ROOT);
+			
+			setPunishLevel(PunishLevel.JAIL, Config.ANTIBOT_TIME_JAIL);
+			sendPacket(new CreatureSay(0, Say2.HERO_VOICE, "[AntiBot]:", "Character " + getName() + " jailed for " + Config.ANTIBOT_TIME_JAIL + " minutes."));
+			LOGGER.warn("[AntiBot]: Character " + getName() + " jailed for " + Config.ANTIBOT_TIME_JAIL + " minutes.");
+		}
+	}
+	
+	private int getMobsDead()
+	{
+		return _mobs_dead;
+	}
+	
+	private void increaseMobsDead()
+	{
+		_mobs_dead++;
+	}
+	
+	private void resetMobsDead()
+	{
+		_mobs_dead = 0;
+	}
+	
+	private void setCode(String code)
+	{
+		_code = code;
+	}
+	
+	private String getCode()
+	{
+		return _code;
+	}
+	
+	public void increaseAttempt()
+	{
+		_attempt += 1;
+	}
+	
+	public int getAttempt()
+	{
+		return _attempt;
+	}
+	
+	public void resetAttempt()
+	{
+		_attempt = 0;
+	}		
 }
\ No newline at end of file
Index: head-src/com/l2jfrozen/Config.java
===================================================================
--- head-src/com/l2jfrozen/Config.java	(revision 1118)
+++ head-src/com/l2jfrozen/Config.java	(working copy)
@@ -579,6 +579,13 @@
 	public static boolean ALLOW_AIO_IN_EVENTS;
 	public static boolean ANNOUNCE_CASTLE_LORDS;
 	
+	/** AntiBot */
+	public static boolean ANTIBOT_ENABLE;
+	public static int ANTIBOT_TIME_JAIL;
+	public static int ANTIBOT_TIME_VOTE;
+	public static int ANTIBOT_KILL_MOBS;
+	public static int ANTIBOT_MIN_LEVEL;
+	
 	/** Configuration to allow custom items to be given on character creation */
 	public static boolean CUSTOM_STARTER_ITEMS_ENABLED;
 	public static List<int[]> STARTING_CUSTOM_ITEMS_F = new ArrayList<>();
@@ -683,6 +690,11 @@
 			ALLOW_AIO_USE_CM = Boolean.parseBoolean(otherSettings.getProperty("AllowAioUseClassMaster", "False"));
 			ALLOW_AIO_IN_EVENTS = Boolean.parseBoolean(otherSettings.getProperty("AllowAioInEvents", "False"));
 			ANNOUNCE_CASTLE_LORDS = Boolean.parseBoolean(otherSettings.getProperty("AnnounceCastleLords", "False"));
+			ANTIBOT_ENABLE = Boolean.parseBoolean(otherSettings.getProperty("AntiBotEnable", "true"));
+			ANTIBOT_TIME_JAIL = Integer.parseInt(otherSettings.getProperty("AntiBotTimeJail", "1"));
+			ANTIBOT_TIME_VOTE = Integer.parseInt(otherSettings.getProperty("AntiBotTimeVote", "30"));
+			ANTIBOT_KILL_MOBS = Integer.parseInt(otherSettings.getProperty("AntiBotKillMobs", "1"));
+			ANTIBOT_MIN_LEVEL = Integer.parseInt(otherSettings.getProperty("AntiBotMinLevel", "1"));				
 			if (ENABLE_AIO_SYSTEM) // create map if system is enabled
 			{
 				final String[] AioSkillsSplit = otherSettings.getProperty("AioSkills", "").split(";");
Index: head-src/com/l2jfrozen/gameserver/network/clientpackets/RequestBypassToServer.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/network/clientpackets/RequestBypassToServer.java	(revision 1118)
+++ head-src/com/l2jfrozen/gameserver/network/clientpackets/RequestBypassToServer.java	(working copy)
@@ -20,6 +20,8 @@
  */
 package com.l2jfrozen.gameserver.network.clientpackets;
 
+import java.util.StringTokenizer;
+
 import org.apache.log4j.Logger;
 
 import com.l2jfrozen.Config;
@@ -317,6 +319,18 @@
 			else if (_command.startsWith("OlympiadArenaChange"))
 			{
 				Olympiad.bypassChangeArena(_command, activeChar);
+			}			
+			else if (_command.startsWith("antibot"))
+			{
+				StringTokenizer st = new StringTokenizer(_command);
+				st.nextToken();
+				
+				if (st.hasMoreTokens())
+				{
+					activeChar.checkCode(st.nextToken());
+					return;
+				}
+				activeChar.checkCode("Fail");
 			}
 		}
 		catch (final Exception e)
Edited by Inthedash6

Share this post


Link to post
Share on other sites

i get 1 error..

 

sendPacket(new CreatureSay(0, Say2.HERO_VOICE, "[AntiBot]:", "Congratulations, has passed control."));

 

what should i replace HERO_VOICE with?

 

i'm using l2jfrozen

Share this post


Link to post
Share on other sites

it doesnt work...maybe u can help me by typing here the correct code??

 

check those images to see the errors i get..

1--> https://postimg.org/image/u0hq3nip9/

 

2--> https://postimg.org/image/fsfx56sbf/

Edited by protoftw

Share this post


Link to post
Share on other sites

Then your "frozen" is not frozen. Normally you can't get error as it's correct. You can always remove that Say2.HERO_VOICE and put 17 and 18 instead of Say2.CRITICAL_ANNOUNCE.

Edited by SweeTs

Share this post


Link to post
Share on other sites

U mean sth like that?

 

getActingPlayer().sendPacket(new CreatureSay(0, 17, "[AntiBot]:",

 

instead of 

 

getActingPlayer().sendPacket(new CreatureSay(0, Say2.HERO VOICE, "[AntiBot]:",

 

edit:

 

thank you man ..it works perfect now ..i have just tested it :) hope u have a great night ..

 

dont forget to be nice to ppl

Edited by protoftw

Share this post


Link to post
Share on other sites

look this error

 

com\l2jfrozen\gameserver\datatables\AntiBotTable.java:160: error: try-with-resources is not supported in -source

 

try (FileInputStream fis = new FileInputStream(imagen))

     ^
1 error

Share this post


Link to post
Share on other sites

 

Where neeed to add images? And where need to add end.html and start.html ?

 

data/images/antibot

data/html/antiBot/start.htm

data/html/antiBot/end.htm

Share this post


Link to post
Share on other sites

data/images/antibot

 

data/html/antiBot/start.htm

 

data/html/antiBot/end.htm

 

where do I put them ???

com\l2jfrozen\gameserver\datatables

It's not core side...Add them to your pack.

Edited by protoftw

Share this post


Link to post
Share on other sites

i have problem eclipse

no pack

 

com\l2jfrozen\gameserver\datatables\AntiBotTable.java:160: error: try-with-resources is not supported in -source

 

try (FileInputStream fis = new FileInputStream(imagen))

     ^
1 error

Share this post


Link to post
Share on other sites
On 10/21/2016 at 7:45 PM, protoftw said:

U mean sth like that?

 

getActingPlayer().sendPacket(new CreatureSay(0, 17, "[AntiBot]:",

 

instead of 

 

getActingPlayer().sendPacket(new CreatureSay(0, Say2.HERO VOICE, "[AntiBot]:",

 

edit:

 

thank you man ..it works perfect now ..i have just tested it :) hope u have a great night ..

 

dont forget to be nice to ppl

 

and 18 for Say2.CRITICAL_ANNOUNCE (THANKS FOR ASK THAT :)

 

the code is working but i need the htmls  the links dont work

 

 

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
Sign in to follow this  

  • Recently Browsing   0 members

    No registered users viewing this page.



  • Posts

    • Mob die and  http:// no exp gain
    • First of all, we cannot controll banned users making new accounts. We do what you mentioned junking topics/posts etc from banned members but that doesn't solve anything. And secondly and most important, there are way more serious reasons of bans than flaming, xdem, kara and some other users are banned for flaming, but there are scammers that scam every day and we cannot do a lot of things about it, there are users bulling other members and they're doing it by following rules (doesn't scam, flame, etc) and way more reasons that our forum is what it is right now with zero new shares and zero creativity.   Some users flame or act childish but tbh isn't so much harm than other users bulling and scamming people here. The fact that xdem will write on l2prideful's topics that the server is trash it won't harm his server AT ALL. But users saying the code someone shared is crap, the npc he made is ugly af, etc will harm the people trying to crete new things and share them with everyone.   The point is, we're at a point that we (the staffers) cannot do a lot about these situations, if members won't change their attitude baning them all will end up worst than having them here and won't change a thing. If you remember the old days when tons of people got banned for stupid reasons such as staffer in a similar forum, spaming, flaming, etc (ofc i'm not speaking about scammers) ended up making a dead forum because these were the people that would bring activity into the forum. Now we're trying to bring activity using other ways like hidden content and people still bitching and not following rules at all but no one cares about that, you only care about a harmless post of a guy saying trash a server.
    • My opinion about new accounts > new accounts > new accounts... Update the forum terms of use etc. and type: In case of permanent ban, the member will lose any right to his topics and the administrator / moderators will have all the right to manage your topics.   Then you ban his profile (bye bye feedback's and reputation), junk all his market / server / project topics. (keep all the "useful" stuff that he shared on forum because he will accept the terms of use) and then lets see if he will flame again  
    • HI everyone, i have a small problem with exp. New characters don't get exp. Just exp and drop. Anyone know what's wrong? Thanks
  • Topics

×