Jump to content

Recommended Posts

Posted

This simple code will stop players from healing or buffing monsters and raids

Go at network/clientpackets/RequestMagicSkillUse

	// Check the validity of the skill
	if (skill != null)
	{
		+if (activeChar.getTarget() instanceof L2MonsterInstance)
		+{
		+	switch (skill.getSkillType())
		+	{
		+		case HEAL:
		+		case HEAL_PERCENT:
		+		case BUFF:
		+		{
		+			if (skill.getTargetType()==L2TargetType.TARGET_ONE)
		+			{
		+				return;
		+			}
		+		}
		+	}
		+}
		if ((activeChar.isTransformed() || activeChar.isInStance()) && !activeChar.containsAllowedTransformSkill(skill.getId()))

 

Credits me, thanks for your reports guys, all fixed!

for those with the previus version I recomend change asap

Posted

small note.

 

You don't do this:

		+		case HEAL:
		+			activeChar.sendPacket(ActionFailed.STATIC_PACKET);
		+			return;
		+		case HEAL_PERCENT:
		+			activeChar.sendPacket(ActionFailed.STATIC_PACKET);
		+			return;
		+		case CHAIN_HEAL:
		+			activeChar.sendPacket(ActionFailed.STATIC_PACKET);
		+			return;
		+		case BUFF:
		+			activeChar.sendPacket(ActionFailed.STATIC_PACKET);
		+			return;

 

You do

		+		case HEAL:
		+		case HEAL_PERCENT:
		+		case CHAIN_HEAL:
		+		case BUFF:
		+			activeChar.sendPacket(ActionFailed.STATIC_PACKET);
		+			return;

Cases collapse and run till u tell them to break;

Also it would of been best/safer, if you did it in the Heal skill handler.

Posted

small note.

 

You don't do this:

		+		case HEAL:
		+			activeChar.sendPacket(ActionFailed.STATIC_PACKET);
		+			return;
		+		case HEAL_PERCENT:
		+			activeChar.sendPacket(ActionFailed.STATIC_PACKET);
		+			return;
		+		case CHAIN_HEAL:
		+			activeChar.sendPacket(ActionFailed.STATIC_PACKET);
		+			return;
		+		case BUFF:
		+			activeChar.sendPacket(ActionFailed.STATIC_PACKET);
		+			return;

 

You do

		+		case HEAL:
		+		case HEAL_PERCENT:
		+		case CHAIN_HEAL:
		+		case BUFF:
		+			activeChar.sendPacket(ActionFailed.STATIC_PACKET);
		+			return;

Cases collapse and run till u tell them to break;

Also it would of been best/safer, if you did it in the Heal skill handler.

thanks for the info, updated

Posted

small note.

 

You don't do this:

		+		case HEAL:
		+			activeChar.sendPacket(ActionFailed.STATIC_PACKET);
		+			return;
		+		case HEAL_PERCENT:
		+			activeChar.sendPacket(ActionFailed.STATIC_PACKET);
		+			return;
		+		case CHAIN_HEAL:
		+			activeChar.sendPacket(ActionFailed.STATIC_PACKET);
		+			return;
		+		case BUFF:
		+			activeChar.sendPacket(ActionFailed.STATIC_PACKET);
		+			return;

 

You do

		+		case HEAL:
		+		case HEAL_PERCENT:
		+		case CHAIN_HEAL:
		+		case BUFF:
		+			activeChar.sendPacket(ActionFailed.STATIC_PACKET);
		+			return;

Cases collapse and run till u tell them to break;

Also it would of been best/safer, if you did it in the Heal skill handler.

as you had told me to add these exceptions in skillhandlers didn't work...so it's pointless to add that to skillhandlers :)
Posted

also

from this:

if (activeChar.getTarget() instanceof L2RaidBossInstance || activeChar.getTarget() instanceof L2GrandBossInstance || activeChar.getTarget() instanceof L2MonsterInstance)

you can do this:

if (activeChar.getTarget() instanceof L2MonsterInstance)

because as far as i know, L2RaidBossInstance and L2GrandBossInstance are extending L2MonsterInstance

Posted

also

from this:

if (activeChar.getTarget() instanceof L2RaidBossInstance || activeChar.getTarget() instanceof L2GrandBossInstance || activeChar.getTarget() instanceof L2MonsterInstance)

you can do this:

if (activeChar.getTarget() instanceof L2MonsterInstance)

because as far as i know, L2RaidBossInstance and L2GrandBossInstance are extending L2MonsterInstance

 

I thougth it too, but never tested it, because L2MonsterInstance Extends L2Npc I think, its a little complicated, I will test

Posted

I thougth it too, but never tested it, because L2MonsterInstance Extends L2Npc I think, its a little complicated, I will test

After alot of tests today(becouse i like your idea)

When u get target raidboss/grandraid/monster:

u cant use group heal/chain heal/prayer/servitor heal/AI and alot of buffs which are self...

if you drop chain heal/Buff and MonsterInstance this system will be perfect for raids/epics,big deal that someone will buff him with might or shield,and only group heal and few other skills on target will not work normal.(this is my opinion ofc)

Posted

After alot of tests today(becouse i like your idea)

When u get target raidboss/grandraid/monster:

u cant use group heal/chain heal/prayer/servitor heal/AI and alot of buffs which are self...

if you drop chain heal/Buff and MonsterInstance this system will be perfect for raids/epics,big deal that someone will buff him with might or shield,and only group heal and few other skills on target will not work normal.(this is my opinion ofc)

 

Your report is usefull for me and now I will go fix it, im pretty sure I will solve this bug too, the servitor heal yes its a bug on witch im gonna work on now, but the healer(who is there to use heal and mass heals) is not the one who is supposed to target the monster, but still yes this makes the code faulty and buggy so Im gonna spend more time on this

 

PS I will only fix: SelfBuffs, SelfHeals and any other skill that casts without target

Posted

After alot of tests today(becouse i like your idea)

When u get target raidboss/grandraid/monster:

u cant use group heal/chain heal/prayer/servitor heal/AI and alot of buffs which are self...

if you drop chain heal/Buff and MonsterInstance this system will be perfect for raids/epics,big deal that someone will buff him with might or shield,and only group heal and few other skills on target will not work normal.(this is my opinion ofc)

 

Index: java/net/sf/l2j/gameserver/network/clientpackets/RequestMagicSkillUse.java
===================================================================
--- java/net/sf/l2j/gameserver/network/clientpackets/RequestMagicSkillUse.java	(revision 2)
+++ java/net/sf/l2j/gameserver/network/clientpackets/RequestMagicSkillUse.java	(working copy)
@@ -17,7 +17,10 @@
import net.sf.l2j.gameserver.datatables.SkillTable;
import net.sf.l2j.gameserver.model.L2Skill;
+import net.sf.l2j.gameserver.model.actor.instance.L2MonsterInstance;
import net.sf.l2j.gameserver.model.actor.instance.L2PcInstance;
import net.sf.l2j.gameserver.network.serverpackets.ActionFailed;
@@ -69,6 +72,19 @@
			if (skill.isToggle() && activeChar.isMounted())
				return;

+			if (activeChar.getTarget() instanceof L2MonsterInstance)
+			{
+				switch (skill.getSkillType())
+				{
+					case BUFF:
+						return;
+					case HEAL:
+						return;
+					case HEAL_PERCENT:
+						return;
+				}
+			}
+			
			activeChar.useMagic(skill, _ctrlPressed, _shiftPressed);
		}
		else

Posted

Index: java/net/sf/l2j/gameserver/network/clientpackets/RequestMagicSkillUse.java
===================================================================
--- java/net/sf/l2j/gameserver/network/clientpackets/RequestMagicSkillUse.java	(revision 2)
+++ java/net/sf/l2j/gameserver/network/clientpackets/RequestMagicSkillUse.java	(working copy)
@@ -17,7 +17,10 @@
import net.sf.l2j.gameserver.datatables.SkillTable;
import net.sf.l2j.gameserver.model.L2Skill;
+import net.sf.l2j.gameserver.model.actor.instance.L2MonsterInstance;
import net.sf.l2j.gameserver.model.actor.instance.L2PcInstance;
import net.sf.l2j.gameserver.network.serverpackets.ActionFailed;
@@ -69,6 +72,19 @@
			if (skill.isToggle() && activeChar.is-beep-ted())
				return;

+			if (activeChar.getTarget() instanceof L2MonsterInstance)
+			{
+				switch (skill.getSkillType())
+				{
+					case BUFF:
+						return;
+					case HEAL:
+						return;
+					case HEAL_PERCENT:
+						return;
+				}
+			}
+			
			activeChar.useMagic(skill, _ctrlPressed, _shiftPressed);
		}
		else

I cant see any diffrence tho

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

    • 亲爱的朋友们! 我们非常高兴地与您分享来自 SocNet 团队的两条好消息! 1. 我们的 SMM 面板更新啦! 我们已全面审查并更新了可用服务列表 —— 现在面板中仅包含最相关、最稳定且真正有效的解决方案。 强烈推荐您立即体验全新升级的服务! ➡ 针对新客户的特别优惠:创建一个支持工单,主题填写 “Get Trial Balance”,即可获得 $1 余额,用于测试我们的任何 SMM 面板服务。 2. 我们的 Telegram Stars 机器人重大更新! 经过大量改进工作,我们很高兴向您展示全新版本的 SocNet Telegram Stars Bot,这是我们在过去一个月中精心开发的成果: ➡ 新增支持通过俄罗斯银行卡支付,并具备自动支付验证功能。 ➡ 实现自动汇率调整 —— 价格始终保持市场最低,包括 Split。 ➡ 新增独特的“礼物老虎机”游戏,每个人都有机会公平赢取丰厚奖品:Telegram Stars、Premium、高价值礼物、SOCNET.STORE 余额以及来自我们合作伙伴的更多惊喜。 感谢您一直以来的支持!✨ 加入我们 —— 每周我们都会在 Telegram 频道举办 Telegram Stars 和其他奖品的抽奖活动! SOCNET 商店有效链接: 数字商品商店(网站):前往 商店 Telegram 机器人:前往 – 通过 Telegram 消息应用轻松访问商店。 Telegram Stars 购买机器人:前往 – 快速、便捷地购买 Telegram Stars。 SMM 面板:前往 – 推广您的社交媒体账户。 我们为您准备了当前平台的优惠与特别活动清单: 1. 优惠码 OCTOBER2025(8% 折扣)—— 在九月期间于我们的商店(网站或机器人)购物时使用! 您还可以使用首次购买优惠码 SOCNET(15% 折扣)。 2. 获得 $1 商店余额或 10–20% 折扣 —— 只需在网站注册后,按照以下格式发布您的用户名:“SEND ME BONUS, MY USERNAME IS...” —— 在我们的论坛帖子中留言即可! 3. 获得 $1 SMM 面板首次试用余额 —— 只需在网站(支持中心)创建主题为 “Get Trial Bonus” 的工单。 4. 每周在我们的 Telegram 频道以及 Telegram Stars 购买机器人中都会举行 Telegram Stars 抽奖活动! 新闻动态: ➡ Telegram 频道:https://t.me/accsforyou_shop ➡ WhatsApp 频道:https://chat.whatsapp.com/K8rBy500nA73z27PxgaJUw?mode=ems_copy_t ➡ Discord 服务器:https://discord.gg/y9AStFFsrh 联系方式与支持: ➡ Telegram:https://t.me/socnet_support ➡ WhatsApp:https://wa.me/79051904467 ➡ Discord:socnet_support ➡ ✉ 邮箱:solomonbog@socnet.store
    • 亲爱的朋友们! 我们非常高兴地与您分享来自 SocNet 团队的两条好消息! 1. 我们的 SMM 面板更新啦! 我们已全面审查并更新了可用服务列表 —— 现在面板中仅包含最相关、最稳定且真正有效的解决方案。 强烈推荐您立即体验全新升级的服务! ➡ 针对新客户的特别优惠:创建一个支持工单,主题填写 “Get Trial Balance”,即可获得 $1 余额,用于测试我们的任何 SMM 面板服务。 2. 我们的 Telegram Stars 机器人重大更新! 经过大量改进工作,我们很高兴向您展示全新版本的 SocNet Telegram Stars Bot,这是我们在过去一个月中精心开发的成果: ➡ 新增支持通过俄罗斯银行卡支付,并具备自动支付验证功能。 ➡ 实现自动汇率调整 —— 价格始终保持市场最低,包括 Split。 ➡ 新增独特的“礼物老虎机”游戏,每个人都有机会公平赢取丰厚奖品:Telegram Stars、Premium、高价值礼物、SOCNET.STORE 余额以及来自我们合作伙伴的更多惊喜。 感谢您一直以来的支持!✨ 加入我们 —— 每周我们都会在 Telegram 频道举办 Telegram Stars 和其他奖品的抽奖活动! SOCNET 商店有效链接: 数字商品商店(网站):前往 商店 Telegram 机器人:前往 – 通过 Telegram 消息应用轻松访问商店。 Telegram Stars 购买机器人:前往 – 快速、便捷地购买 Telegram Stars。 SMM 面板:前往 – 推广您的社交媒体账户。 我们为您准备了当前平台的优惠与特别活动清单: 1. 优惠码 OCTOBER2025(8% 折扣)—— 在九月期间于我们的商店(网站或机器人)购物时使用! 您还可以使用首次购买优惠码 SOCNET(15% 折扣)。 2. 获得 $1 商店余额或 10–20% 折扣 —— 只需在网站注册后,按照以下格式发布您的用户名:“SEND ME BONUS, MY USERNAME IS...” —— 在我们的论坛帖子中留言即可! 3. 获得 $1 SMM 面板首次试用余额 —— 只需在网站(支持中心)创建主题为 “Get Trial Bonus” 的工单。 4. 每周在我们的 Telegram 频道以及 Telegram Stars 购买机器人中都会举行 Telegram Stars 抽奖活动! 新闻动态: ➡ Telegram 频道:https://t.me/accsforyou_shop ➡ WhatsApp 频道:https://chat.whatsapp.com/K8rBy500nA73z27PxgaJUw?mode=ems_copy_t ➡ Discord 服务器:https://discord.gg/y9AStFFsrh 联系方式与支持: ➡ Telegram:https://t.me/socnet_support ➡ WhatsApp:https://wa.me/79051904467 ➡ Discord:socnet_support ➡ ✉ 邮箱:solomonbog@socnet.store
    • 亲爱的朋友们! 我们非常高兴地与您分享来自 SocNet 团队的两条好消息! 1. 我们的 SMM 面板更新啦! 我们已全面审查并更新了可用服务列表 —— 现在面板中仅包含最相关、最稳定且真正有效的解决方案。 强烈推荐您立即体验全新升级的服务! ➡ 针对新客户的特别优惠:创建一个支持工单,主题填写 “Get Trial Balance”,即可获得 $1 余额,用于测试我们的任何 SMM 面板服务。 2. 我们的 Telegram Stars 机器人重大更新! 经过大量改进工作,我们很高兴向您展示全新版本的 SocNet Telegram Stars Bot,这是我们在过去一个月中精心开发的成果: ➡ 新增支持通过俄罗斯银行卡支付,并具备自动支付验证功能。 ➡ 实现自动汇率调整 —— 价格始终保持市场最低,包括 Split。 ➡ 新增独特的“礼物老虎机”游戏,每个人都有机会公平赢取丰厚奖品:Telegram Stars、Premium、高价值礼物、SOCNET.STORE 余额以及来自我们合作伙伴的更多惊喜。 感谢您一直以来的支持!✨ 加入我们 —— 每周我们都会在 Telegram 频道举办 Telegram Stars 和其他奖品的抽奖活动! SOCNET 商店有效链接: 数字商品商店(网站):前往 商店 Telegram 机器人:前往 – 通过 Telegram 消息应用轻松访问商店。 Telegram Stars 购买机器人:前往 – 快速、便捷地购买 Telegram Stars。 SMM 面板:前往 – 推广您的社交媒体账户。 我们为您准备了当前平台的优惠与特别活动清单: 1. 优惠码 OCTOBER2025(8% 折扣)—— 在九月期间于我们的商店(网站或机器人)购物时使用! 您还可以使用首次购买优惠码 SOCNET(15% 折扣)。 2. 获得 $1 商店余额或 10–20% 折扣 —— 只需在网站注册后,按照以下格式发布您的用户名:“SEND ME BONUS, MY USERNAME IS...” —— 在我们的论坛帖子中留言即可! 3. 获得 $1 SMM 面板首次试用余额 —— 只需在网站(支持中心)创建主题为 “Get Trial Bonus” 的工单。 4. 每周在我们的 Telegram 频道以及 Telegram Stars 购买机器人中都会举行 Telegram Stars 抽奖活动! 新闻动态: ➡ Telegram 频道:https://t.me/accsforyou_shop ➡ WhatsApp 频道:https://chat.whatsapp.com/K8rBy500nA73z27PxgaJUw?mode=ems_copy_t ➡ Discord 服务器:https://discord.gg/y9AStFFsrh 联系方式与支持: ➡ Telegram:https://t.me/socnet_support ➡ WhatsApp:https://wa.me/79051904467 ➡ Discord:socnet_support ➡ ✉ 邮箱:solomonbog@socnet.store
  • 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