Jump to content

Recommended Posts

Posted

Hizzz (again) :P

Before some days one friend ask me to make for his server a mod that's when they reach the ex '5' pvp will gain hero status!

At the start it was with skills but it was unfair for other players so i put a code to check if the hero is by the olympiad or by the pvp!

If The hero was from olympiad he will have the skills if not he will not!

And Today i am glad to say after many tests on our test server is working perfectly!

 

Here's the code:


Index: C:/Users/Home/Desktop/eclipse/workspace/L2JTeon-CORE/java/config/zozoqcustoms.properties
===================================================================
--- C:/Users/Home/Desktop/eclipse/workspace/L2JTeon-CORE/java/config/zozoqcustoms.properties	(revision 0)
+++ C:/Users/Home/Desktop/eclipse/workspace/L2JTeon-CORE/java/config/zozoqcustoms.properties	(revision 0)
@@ -0,0 +1,61 @@
+# -------------------------------
+# Custom Mods for L2Legend Server
+# -------------------------------
+
+# Hero at kills!
+# Added Hero Check for Olympiad Heroes!
+AllowPvpHero = False
+#Give hero skills at pvp hero?
+GivePvpHeroSkills = False
+#Remove Olympiad hero status on death? This is not for ever!
+RemoveOlympiadHero = False
\ No newline at end of file

Index: C:/Users/Home/Desktop/eclipse/workspace/L2JTeon-CORE/java/net/sf/l2j/Config.java
===================================================================
--- C:/Users/Home/Desktop/eclipse/workspace/L2JTeon-CORE/java/net/sf/l2j/Config.java	(revision 666)
+++ C:/Users/Home/Desktop/eclipse/workspace/L2JTeon-CORE/java/net/sf/l2j/Config.java	(working copy)
@@ -73,6 +73,7 @@
	public static final String OLYMPIAD_FILE = "./config/custom/Olympiad.properties";
	public static final String AUGMENT_CONFIG_FILE = "./config/custom/Augment.properties";
	public static final String DEV_CONFIG_FILE = "./config/custom/Dev.properties";
+	public static final String ZOZOQ_FILE = "./config/zozoqcustoms.properties";

	/** Server and Datapack version */
	public static String SERVER_VERSION;
@@ -1449,6 +1450,27 @@
	public static boolean DATABASE_AUTO_CHECK;
	public static boolean DATABASE_AUTO_OPTIMIZE;
	public static boolean DATABASE_AUTO_REPAIR;
+	
+	
+	/**
+	 * TODO: Adding more Features to server!!!
+	 */
+	public static boolean ALLOW_PVP_HERO;
+      public static boolean GIVE_PVP_HERO_SKILLS;
+      public static boolean REMOVE_OLYMPIAD_HERO;

	/**
	 * This class initializes all global variables for configuration.<br>
@@ -1853,6 +1875,35 @@
				e.printStackTrace();
				throw new Error("Failed to Load " + GM_ACCESS_FILE + " File.");
			}
+			// TODO: Adding more Features
+			try
+			{
+				Properties legend = new Properties();
+				InputStream is = new FileInputStream(new File(ZOZOQ_FILE));
+				legend.load(is);
+				is.close();
+				ALLOW_PVP_HERO = Boolean.parseBoolean(legend.getProperty("AllowPvpHero", "False"));
+                              GIVE_PVP_HERO_SKILLS = Boolean.parseBoolean(legend.getProperty("GivePvpHeroSkills", "False"));
+                              REMOVE_OLYMPIAD_HERO = Boolean.parseBoolean(legend.getProperty("RemoveOlympiadHero", "False"));
+			}
+			catch (Exception e)
+			{
+				e.printStackTrace();
+				throw new Error("Failed to Load " + ZOZOQ_FILE + " File.");
+			}
			// id factory
			try
			{

Index: C:/Users/Home/Desktop/eclipse/workspace/L2JTeon-CORE/java/net/sf/l2j/gameserver/model/actor/instance/L2PcInstance.java
===================================================================
--- C:/Users/Home/Desktop/eclipse/workspace/L2JTeon-CORE/java/net/sf/l2j/gameserver/model/actor/instance/L2PcInstance.java	(revision 666)
+++ C:/Users/Home/Desktop/eclipse/workspace/L2JTeon-CORE/java/net/sf/l2j/gameserver/model/actor/instance/L2PcInstance.java	(working copy)
@@ -14,6 +14,7 @@
 */
package net.sf.l2j.gameserver.model.actor.instance;

import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
@@ -110,6 +111,7 @@
import net.sf.l2j.gameserver.model.L2Skill.SkillTargetType;
import net.sf.l2j.gameserver.model.L2Skill.SkillType;
import net.sf.l2j.gameserver.model.actor.appearance.PcAppearance;
import net.sf.l2j.gameserver.model.actor.knownlist.PcKnownList;
import net.sf.l2j.gameserver.model.actor.stat.PcStat;
import net.sf.l2j.gameserver.model.actor.status.PcStatus;
@@ -121,6 +123,7 @@
import net.sf.l2j.gameserver.model.base.SubClass;
import net.sf.l2j.gameserver.model.entity.Castle;
import net.sf.l2j.gameserver.model.entity.Duel;
+import net.sf.l2j.gameserver.model.entity.Hero;
import net.sf.l2j.gameserver.model.entity.L2Event;
import net.sf.l2j.gameserver.model.entity.Siege;
import net.sf.l2j.gameserver.model.entity.L2JTeonEvents.CTF;
@@ -489,6 +492,12 @@
	private TradeList _buyList;
	/** true if the L2PcInstance is newbie */
	private boolean _newbie;
+	/**Pvp Hero System*/
+	private int pvpHeroSystem = 0;
	private boolean _noble = false;
    private boolean _fakeHero = false;
	private boolean _hero = false;

@@ -4466,6 +4550,51 @@
				}
			}
		}
+	
+			if (Config.ALLOW_PVP_HERO)
+			{
+                              if (Config.REMOVE_OLYMPIAD_HERO)
+                              {
+				       pvpHeroSystem = 0;
+				        if (isHero() && Hero.getInstance().getHeroes() != null && Hero.getInstance().getHeroes().containsKey(getObjectId()))
+				        {
+					       return false;
+				         }
+				         else if (isHero())
+				         {
+					      setHero(false);
+					      Announcements.getInstance().announceToAll(getName()+" lost hero status");
+				         }
+			         }
+                               else
+                               {
+				         if (isHero())
+				         {
+					      setHero(false);
+					      Announcements.getInstance().announceToAll(getName()+" lost hero status");
+				         }
+
		setPvpFlag(0); // Clear the pvp flag
		// Unsummon Cubics
		if (_cubics.size() > 0)
@@ -4770,10 +4899,67 @@
		// Add to attacker and increase its PK counter
		setPvpKills(getPvpKills() + 1);
		updatePvPColor(getPvpKills());
+		
+			if (Config.ALLOW_PVP_HERO)
+			{
+				pvpHeroSystem++;
+				switch(pvpHeroSystem) {
+				case 5:
+                                      if (!isHero())
+					{
+					setHero(true);
+					Announcements.getInstance().announceToAll(getName()+" gain hero status for killing row!");
+					}
+					break;
+					default:
+						;
+				}
+			}
+
		// Send a Server->Client UserInfo packet to attacker with its Karma and PK Counter
		sendPacket(new UserInfo(this));
	}

+
	/**
	 * Get info on pk's from PK table
	 */
@@ -9146,7 +9332,7 @@

	public void setHero(boolean hero)
	{
-			if (hero && _baseClass == _activeClass)
-			{
-				for (L2Skill s : HeroSkillTable.GetHeroSkills())
-					addSkill(s, false); //Dont Save Hero skills to database
-			}
-			else
-			{
-				for (L2Skill s : HeroSkillTable.GetHeroSkills())
-					super.removeSkill(s); //Just Remove skills from nonHero characters
-			}
+		if (!Config.GIVE_PVP_HERO_SKILLS)
+		{
+		if (Hero.getInstance().getHeroes() != null && Hero.getInstance().getHeroes().containsKey(getObjectId()) && hero && _baseClass == _activeClass)
+		{
+			for (L2Skill s : HeroSkillTable.GetHeroSkills())
+				addSkill(s, false); //Dont Save Hero skills to database
+		}
+		else
+		{
+			for (L2Skill s : HeroSkillTable.GetHeroSkills())
+				super.removeSkill(s); //Just Remove skills from nonHero characters
+		}
+		}
+		else
+		{
+			if (hero && _baseClass == _activeClass)
+			{
+				for (L2Skill s : HeroSkillTable.GetHeroSkills())
+					addSkill(s, false); //Dont Save Hero skills to database
+			}
+			else
+			{
+				for (L2Skill s : HeroSkillTable.GetHeroSkills())
+					super.removeSkill(s); //Just Remove skills from nonHero characters
+			}
+                  }
	_hero = hero;

	sendSkillList();


Enjoy!

Credits: Me


I am never but never don't leach other ppl work! So please do not say i stole it!

Oh and is not arleady shares as the other codes is different from mine!

If you want use it if not good!

Friendly ZozOQ

 

Posted

I am working on this! Soon with more configs such remove hero if is from olympiad on death (if they want) and give pvp hero skills!!

EDIT:

Updated!! 2 More Configs!

Posted

No is not only hero glow! You have all the rights of a hero such hero voice! and you can choose if this kind of hero can have hero skills!

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


  • Posts

    • LIVE VERIFICATION? SUMSUB? “IMPOSSIBLE”? ▪ Spoiler: it is possible — if you know who to work with. A client came in with a task to pass **live verification** on **WantToPay**, a Telegram virtual card service. On the platform side — **Sumsub**: liveness check, SMS, manual review. “Fast” and “by eye” simply don’t work here. › What was done: → analyzed the verification scenario and Sumsub requirements → built the correct flow: phone number, email, timing → **completed live verification remotely, without account handover** → handled SMS and confirmation codes → brought the process to final approval ▪ Result: → verification passed → access granted → no flags or repeat requests ▪ Live verification is not luck. It’s scenario-based preparation — not hope. › TG: @mustang_service ( https:// t.me/ mustang_service ) › Channel: Mustang Service ( https:// t.me/ +6RAKokIn5ItmYjEx ) *All data is published with the client’s consent.* #verification #sumsub #livecheck #kyc #case
    • IMPORTANT INFO: In a few days, I will switch to completely new code, written from scratch with a new download system, patch building and management system. The Updater will become true 2026 code with "foolproof systems". I'm going to create a Discord server for customers to request new ideas and features. FIRST CUSTOMERS ARE ALREADY USING THE NEW UPDATER ON LIVE SERVERS! Watch this topic for upcoming info because the new updater is around the corner! Yes, you can still use self-update on the previous updater! No, the new updater won't be compatible with the old patch system! A new build is required, but players who already have game files won't have to download the entire patch again! New templates and updates to existing templates are coming soon! Sneak peek:  
    • i used guytis IL project and source. i found in his project there are 3 Client version source... 1,CliExt_H5   --->this one cant be compiled in VS2005,i did know why..is it for H5 client? 2,CliExtNew  --->this one is IL version ,but when i compiled it and use it.player cant login game,MD5Checksum wrong.i check the source code,but not found any hints. 3,L2Server    --->this one for HB client?im not sure...   so my question is what are the differences between these three versions of cliext.dll?how can i fix the issue of the MD5Checksum not matching problem?   01/29/2026 21:04:11.366, [CCliExt::HandleCheckSum] Invalid Checksum[1130415144] vs [-721420287] packet[dd] len[29] sum[2698] key[30] HWID[] Account[]! 01/29/2026 21:04:11.366, SocketLimiter::UserSocketBadunknownprotocol 11111111111 01/29/2026 21:04:11.366, [usersocket]unknown protocol from ip[113.137.149.115]!      
  • Topics

×
×
  • Create New...

Important Information

This community uses essential cookies to function properly. Non-essential cookies and third-party services are used only with your consent. Read our Privacy Policy and We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue..