Jump to content

Question

Posted (edited)

Hello guys,
There is a bug in my server,which allows players to have multiple classes skills.
For example,Saggitarius with Paladin skills.I know it's related to PHX.
I tried this fix,but it just removed every skill:
 

	public L2Skill addSkill(L2Skill newSkill, boolean store)
	{
		// Add a skill to the L2PcInstance _skills and its Func objects to the calculator set of the L2PcInstance
		L2Skill oldSkill = super.addSkill(newSkill);

		// Add or update a L2PcInstance skill in the character_skills table of the database
		if (store)
			storeSkill(newSkill, oldSkill, -1);

+		if(!SkillTreeTable.getInstance().getAllAvailableSkills(this, getClassId()).contains(newSkill))
+			removeSkill(newSkill,false);
		
		return oldSkill;
	}

I am using acis 320

Edited by StealthyS4m

11 answers to this question

Recommended Posts

  • 0
Posted

consider of adding a check in enterworld..

 

so every time player will log in,it will check his skills.

 

its a lame fix,but I can't provide more tips since you haven't add more informations about this bug(how players are doing it etc).

  • 0
Posted (edited)

You have to create an admincommand or a mySQL query which pick each character raw, take their classes, and verify ids of skills according the class. If there are positive results, you ban their accounts.

 

If you want to make it automatically, create a method fired AFTER player skill loading, and check directly from here. If found, client closes packet + ban account.

 

You have to compare 2 lists of skillIds, basically, availableForClass and currentPlayer. If currentPlayer got a single id which is diferent, you drop it. It's the fastest and easiest way.

 

PS : think about hardcoded skills : nobless, hero, dwarven,...

Edited by Tryskell
  • 0
Posted

Take one unique skill for every class, for example frenzy, rabbit totem, snipe, because there is only one class which can have thiis skill. So if selected played has more than 1 unique skill ban him. As far as i know u cant add one skill using the bug u mentioned, if someone mixed 2 classes he will have complete skillset. So thats the simples solution imo

  • 0
Posted (edited)

Well,I don't want to ban,but I tried one thing.
 

	public void sendSkillList()
	{
		final L2ItemInstance formal = getInventory().getPaperdollItem(Inventory.PAPERDOLL_CHEST);
		final boolean isWearingFormalWear = formal != null && formal.getItem().getBodyPart() == L2Item.SLOT_ALLDRESS;

		boolean isDisabled = false;
		SkillList sl = new SkillList();
+		///////////////////
+		HashMap <Integer,Integer> AvSkills = new HashMap<>();
+		addToListSL(AvSkills, SkillTreeTable.getInstance().getAllowedSkills(getClassId()));
+		addToListS(AvSkills,SkillTable.getHeroSkills());
+		addToListS(AvSkills,SkillTable.getNobleSkills());
+		addToListRSL(AvSkills,SkillTreeTable.getInstance().getAvailableRebirthSkills(this, getClassId()));
+		AvSkills.put(L2Skill.SKILL_CREATE_COMMON,10);
+		AvSkills.put(L2Skill.SKILL_CREATE_DWARVEN,10);
+		AvSkills.put(L2Skill.SKILL_CRYSTALLIZE,10);
+		AvSkills.put(L2Skill.SKILL_DIVINE_INSPIRATION,10);
+		AvSkills.put(L2Skill.SKILL_LUCKY,10);
+		AvSkills.put(L2Skill.SKILL_NPC_RACE,10);
+		////////////////////
		
		for (L2Skill s : getAllSkills())
		{
			if (s == null)
				continue;

			if (s.getId() > 9000 && s.getId() < 9007)
				continue; // Fake skills to change base stats

			if (getClan() != null)
				isDisabled = s.isClanSkill() && getClan().getReputationScore() < 0;

			if (isCursedWeaponEquipped()) // Only Demonic skills are available
				isDisabled = !s.isDemonicSkill();
			else if (isMounted()) // else if, because only ONE state is possible
			{
				if (getMountType() == 1) // Only Strider skills are available
					isDisabled = !s.isStriderSkill();
				else if (getMountType() == 2) // Only Wyvern skills are available
					isDisabled = !s.isFlyingSkill();
			}
			
			
			if (isWearingFormalWear)
				isDisabled = true;
+			if(AvSkills.containsKey(s.getId()))
			sl.addSkill(s.getId(),s.getLevel()<AvSkills.get(s.getId())?s.getLevel():AvSkills.get(s.getId()) , s.isPassive(), isDisabled);//Changed a bit    
		
		}
		
		
		sendPacket(sl);
	}

+	public static void addToListSL(HashMap<Integer,Integer> a,Collection<L2SkillLearn> b){
+		Iterator <L2SkillLearn> itr = b.iterator();
+		while(itr.hasNext()){
+			L2SkillLearn tempSkill = itr.next();
+			a.put(tempSkill.getId(), tempSkill.getLevel());
+		}
+	}
+	public static void addToListRSL(HashMap<Integer,Integer> a, Collection <L2RebirthSkillLearn> b){
+		Iterator <L2RebirthSkillLearn> itr = b.iterator();
+		while(itr.hasNext()){
+			L2RebirthSkillLearn tempSkill = itr.next();
+			a.put(tempSkill.getId(), tempSkill.getLevel());
+		}
+	}
+	public static void addToListS(HashMap<Integer,Integer> a,L2Skill [] b){
+		for(int c = 0;c<b.length;c++){
+			a.put(b[c].getId(), b[c].getLevel());
+		}
+	}
	

This change should check player's skills on login and if there any that shouldn't be there just don't add it,plus it checks levels.What do you guys think?

Edited by StealthyS4m
Guest
This topic is now closed to further replies.


  • Posts

    • Looking to hire a skilled L2J developer or team to build a custom private server for solo play with advanced server-side AI bots. This is NOT for public launch — just a self-hosted project where I can simulate a full L2 experience alone or with a few friends. 🔹 What I Need A private L2J server ( High Five preferred, newer versions can work as well) with bots that: Farm 24/7 on their own (solo or in bot parties) Can be invited into party and follow basic orders (attack, follow, res, heal, etc.) Are able to join Olympiad, fight with proper logic (per class), and rank up Can coordinate for Raid Bosses (check spawn, move, assist, heal, DPS, etc.) Act like real players: town routines, rebuffing, restocking, even chatting if possible Have different roles: tanks, healers, nukers, archers, etc. Can interact through simple in-game commands or NPC interface 🔹 Your Job Set up the server and geodata Integrate a scalable bot system (written in Java or scriptable) Write clean, modular AI behavior (farming, PvP, party play, raid logic, etc.) Allow me to control/assign bots easily (in-game or config) Bonus: basic UI or GM panel for bot config 🔹 Payment Serious budget for serious work PayPal, crypto, or preferred method Project-based or hourly, negotiable Milestone-based OK 🔹 Contact Send me: Your experience with L2J or similar projects Any bot/AI systems you've built before Estimated timeframe Pricing expectations
    • Yeah, it’s wild how much gambling has changed. When I was growing up, even scratch-off tickets felt like a big thing, but now with so many casino apps and betting sites, it’s just everywhere. I know a few people who got caught up in online slots during lockdown and really struggled to stop, just because it was always on their phone.   I stick to in-game stuff like skin trading for games like CS2 or Dota, which to me feels less risky, especially if you know the value of the items. If you’re curious how these trades work or want to see some guides, just visit website—there’s a lot of info about trading without real gambling involved.
    • Yea, his work is amazing, very well done designs, but the timing is not really his thing. I’m waiting for logo and launcher design since December 2024, so 10 days is not really that much lol
    • Discord         :  utchiha_market Telegram        : https://t.me/utchiha_market Auto Buy Store  : https://utchihamkt.mysellauth.com/ Not sure if we’re legit? Check Our server — real reviews, real buyers https://discord.gg/uthciha-servicess  | https://campsite.bio/utchihaamkt  
  • Topics

×
×
  • Create New...

AdBlock Extension Detected!

Our website is made possible by displaying online advertisements to our members.

Please disable AdBlock browser extension first, to be able to use our community.

I've Disabled AdBlock