aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorShauren <shauren.trinity@gmail.com>2024-12-03 17:40:25 +0100
committerShauren <shauren.trinity@gmail.com>2024-12-03 17:40:25 +0100
commit43bf71b3742c6f3ee5f92eb27a6d0c11d1c562c2 (patch)
treed5232fed653f2d3d6ca9f44bf600c43973c60328
parent3c69a40c100f49bb7a348cb729d483e1e8f22947 (diff)
Core/Spells: Implemented TargetAuraType and ExcludeTargetAuraType cast requirements
-rw-r--r--src/server/game/Spells/SpellInfo.cpp6
1 files changed, 6 insertions, 0 deletions
diff --git a/src/server/game/Spells/SpellInfo.cpp b/src/server/game/Spells/SpellInfo.cpp
index 3d56fec4acb..41c9503ab76 100644
--- a/src/server/game/Spells/SpellInfo.cpp
+++ b/src/server/game/Spells/SpellInfo.cpp
@@ -2344,6 +2344,12 @@ SpellCastResult SpellInfo::CheckTarget(WorldObject const* caster, WorldObject co
if (ExcludeTargetAuraSpell && unitTarget->HasAura(ExcludeTargetAuraSpell))
return SPELL_FAILED_TARGET_AURASTATE;
+ if (TargetAuraType && !unitTarget->HasAuraType(TargetAuraType))
+ return SPELL_FAILED_TARGET_AURASTATE;
+
+ if (ExcludeTargetAuraType && unitTarget->HasAuraType(ExcludeTargetAuraType))
+ return SPELL_FAILED_TARGET_AURASTATE;
+
if (unitTarget->HasAuraType(SPELL_AURA_PREVENT_RESURRECTION) && !HasAttribute(SPELL_ATTR7_BYPASS_NO_RESURRECT_AURA))
if (HasEffect(SPELL_EFFECT_SELF_RESURRECT) || HasEffect(SPELL_EFFECT_RESURRECT))
return SPELL_FAILED_TARGET_CANNOT_BE_RESURRECTED;