mirror of
https://github.com/TrinityCore/TrinityCore.git
synced 2026-01-21 17:54:48 +01:00
Scripts/Icecrown Citadel: Fixed possible exploits with Deathbringer Saurfang
This commit is contained in:
@@ -193,6 +193,7 @@ enum Actions
|
||||
ACTION_CHARGE = -3781302,
|
||||
ACTION_START_OUTRO = -3781303,
|
||||
ACTION_DESPAWN = -3781304,
|
||||
ACTION_INTERRUPT_INTRO = -3781305,
|
||||
ACTION_MARK_OF_THE_FALLEN_CHAMPION = -72293,
|
||||
};
|
||||
|
||||
@@ -284,8 +285,15 @@ class boss_deathbringer_saurfang : public CreatureScript
|
||||
me->setActive(true);
|
||||
DoZoneInCombat();
|
||||
|
||||
events.Reset();
|
||||
events.SetPhase(PHASE_COMBAT);
|
||||
me->RemoveFlag(UNIT_FIELD_FLAGS, UNIT_FLAG_OOC_NOT_ATTACKABLE);
|
||||
if (!introDone)
|
||||
{
|
||||
DoCast(me, SPELL_GRIP_OF_AGONY);
|
||||
if (Creature* creature = ObjectAccessor::GetCreature(*me, instance->GetData64(DATA_SAURFANG_EVENT_NPC)))
|
||||
creature->AI()->DoAction(ACTION_INTERRUPT_INTRO);
|
||||
}
|
||||
introDone = true;
|
||||
|
||||
Talk(SAY_AGGRO);
|
||||
@@ -510,6 +518,8 @@ class boss_deathbringer_saurfang : public CreatureScript
|
||||
events.ScheduleEvent(EVENT_INTRO_HORDE_2, 5000, 0, PHASE_INTRO_H);
|
||||
break;
|
||||
case ACTION_CONTINUE_INTRO:
|
||||
if (introDone)
|
||||
return;
|
||||
events.ScheduleEvent(EVENT_INTRO_ALLIANCE_6, 6500+500, 0, PHASE_INTRO_A);
|
||||
events.ScheduleEvent(EVENT_INTRO_FINISH, 8000, 0, PHASE_INTRO_A);
|
||||
|
||||
@@ -564,44 +574,56 @@ class npc_high_overlord_saurfang_icc : public CreatureScript
|
||||
|
||||
void DoAction(const int32 action)
|
||||
{
|
||||
if (action == ACTION_START_EVENT)
|
||||
switch (action)
|
||||
{
|
||||
// Prevent crashes
|
||||
if (events.GetPhaseMask() & PHASE_INTRO_MASK)
|
||||
return;
|
||||
|
||||
GetCreatureListWithEntryInGrid(guardList, me, NPC_SE_KOR_KRON_REAVER, 20.0f);
|
||||
guardList.sort(Trinity::ObjectDistanceOrderPred(me));
|
||||
uint32 x = 1;
|
||||
for (std::list<Creature*>::iterator itr = guardList.begin(); itr != guardList.end(); ++x, ++itr)
|
||||
(*itr)->AI()->SetData(0, x);
|
||||
|
||||
me->RemoveFlag(UNIT_NPC_FLAGS, UNIT_NPC_FLAG_GOSSIP);
|
||||
Talk(SAY_INTRO_HORDE_1);
|
||||
events.SetPhase(PHASE_INTRO_H);
|
||||
events.ScheduleEvent(EVENT_INTRO_HORDE_3, 18500, 0, PHASE_INTRO_H);
|
||||
if (instance)
|
||||
case ACTION_START_EVENT:
|
||||
{
|
||||
deathbringerSaurfangGUID = instance->GetData64(DATA_DEATHBRINGER_SAURFANG);
|
||||
instance->HandleGameObject(instance->GetData64(GO_SAURFANG_S_DOOR), true);
|
||||
// Prevent crashes
|
||||
if (events.GetPhaseMask() & PHASE_INTRO_MASK)
|
||||
return;
|
||||
|
||||
GetCreatureListWithEntryInGrid(guardList, me, NPC_SE_KOR_KRON_REAVER, 20.0f);
|
||||
guardList.sort(Trinity::ObjectDistanceOrderPred(me));
|
||||
uint32 x = 1;
|
||||
for (std::list<Creature*>::iterator itr = guardList.begin(); itr != guardList.end(); ++x, ++itr)
|
||||
(*itr)->AI()->SetData(0, x);
|
||||
|
||||
me->RemoveFlag(UNIT_NPC_FLAGS, UNIT_NPC_FLAG_GOSSIP);
|
||||
Talk(SAY_INTRO_HORDE_1);
|
||||
events.SetPhase(PHASE_INTRO_H);
|
||||
events.ScheduleEvent(EVENT_INTRO_HORDE_3, 18500, 0, PHASE_INTRO_H);
|
||||
if (instance)
|
||||
{
|
||||
deathbringerSaurfangGUID = instance->GetData64(DATA_DEATHBRINGER_SAURFANG);
|
||||
instance->HandleGameObject(instance->GetData64(GO_SAURFANG_S_DOOR), true);
|
||||
}
|
||||
if (Creature* deathbringer = ObjectAccessor::GetCreature(*me, deathbringerSaurfangGUID))
|
||||
deathbringer->AI()->DoAction(PHASE_INTRO_H);
|
||||
break;
|
||||
}
|
||||
if (Creature* deathbringer = ObjectAccessor::GetCreature(*me, deathbringerSaurfangGUID))
|
||||
deathbringer->AI()->DoAction(PHASE_INTRO_H);
|
||||
}
|
||||
else if (action == ACTION_START_OUTRO)
|
||||
{
|
||||
me->RemoveAurasDueToSpell(SPELL_GRIP_OF_AGONY);
|
||||
Talk(SAY_OUTRO_HORDE_1);
|
||||
events.ScheduleEvent(EVENT_OUTRO_HORDE_2, 10000); // say
|
||||
events.ScheduleEvent(EVENT_OUTRO_HORDE_3, 18000); // say
|
||||
events.ScheduleEvent(EVENT_OUTRO_HORDE_4, 24000); // cast
|
||||
events.ScheduleEvent(EVENT_OUTRO_HORDE_5, 30000); // move
|
||||
me->RemoveUnitMovementFlag(MOVEMENTFLAG_LEVITATING);
|
||||
me->SendMovementFlagUpdate();
|
||||
me->Relocate(me->GetPositionX(), me->GetPositionY(), 539.2917f);
|
||||
me->SendMonsterMove(me->GetPositionX(), me->GetPositionY(), 539.2917f, SPLINEFLAG_FALLING, 0, 0.0f);
|
||||
for (std::list<Creature*>::iterator itr = guardList.begin(); itr != guardList.end(); ++itr)
|
||||
(*itr)->AI()->DoAction(ACTION_DESPAWN);
|
||||
case ACTION_START_OUTRO:
|
||||
{
|
||||
me->RemoveAurasDueToSpell(SPELL_GRIP_OF_AGONY);
|
||||
Talk(SAY_OUTRO_HORDE_1);
|
||||
events.ScheduleEvent(EVENT_OUTRO_HORDE_2, 10000); // say
|
||||
events.ScheduleEvent(EVENT_OUTRO_HORDE_3, 18000); // say
|
||||
events.ScheduleEvent(EVENT_OUTRO_HORDE_4, 24000); // cast
|
||||
events.ScheduleEvent(EVENT_OUTRO_HORDE_5, 30000); // move
|
||||
me->RemoveUnitMovementFlag(MOVEMENTFLAG_LEVITATING);
|
||||
me->SendMovementFlagUpdate();
|
||||
me->Relocate(me->GetPositionX(), me->GetPositionY(), 539.2917f);
|
||||
me->SendMonsterMove(me->GetPositionX(), me->GetPositionY(), 539.2917f, SPLINEFLAG_FALLING, 0, 0.0f);
|
||||
for (std::list<Creature*>::iterator itr = guardList.begin(); itr != guardList.end(); ++itr)
|
||||
(*itr)->AI()->DoAction(ACTION_DESPAWN);
|
||||
break;
|
||||
}
|
||||
case ACTION_INTERRUPT_INTRO:
|
||||
events.Reset();
|
||||
for (std::list<Creature*>::iterator itr = guardList.begin(); itr != guardList.end(); ++itr)
|
||||
(*itr)->AI()->DoAction(ACTION_DESPAWN);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -619,34 +641,36 @@ class npc_high_overlord_saurfang_icc : public CreatureScript
|
||||
if (type != POINT_MOTION_TYPE)
|
||||
return;
|
||||
|
||||
if (id == POINT_FIRST_STEP)
|
||||
switch (id)
|
||||
{
|
||||
me->RemoveUnitMovementFlag(MOVEMENTFLAG_WALKING);
|
||||
Talk(SAY_INTRO_HORDE_3);
|
||||
events.ScheduleEvent(EVENT_INTRO_HORDE_5, 15500, 0, PHASE_INTRO_H);
|
||||
events.ScheduleEvent(EVENT_INTRO_HORDE_6, 29500, 0, PHASE_INTRO_H);
|
||||
events.ScheduleEvent(EVENT_INTRO_HORDE_7, 43800, 0, PHASE_INTRO_H);
|
||||
events.ScheduleEvent(EVENT_INTRO_HORDE_8, 47000, 0, PHASE_INTRO_H);
|
||||
if (Creature* deathbringer = ObjectAccessor::GetCreature(*me, deathbringerSaurfangGUID))
|
||||
deathbringer->AI()->DoAction(ACTION_CONTINUE_INTRO);
|
||||
}
|
||||
else if (id == POINT_CORPSE)
|
||||
{
|
||||
if (Creature* deathbringer = ObjectAccessor::GetCreature(*me, deathbringerSaurfangGUID))
|
||||
{
|
||||
deathbringer->CastSpell(me, SPELL_RIDE_VEHICLE, true); // for the packet logs.
|
||||
deathbringer->SetFlag(UNIT_FIELD_FLAGS, UNIT_FLAG_NOT_SELECTABLE);
|
||||
deathbringer->setDeathState(ALIVE);
|
||||
deathbringer->EnterVehicle(vehicle, 0);
|
||||
}
|
||||
events.ScheduleEvent(EVENT_OUTRO_HORDE_5, 1000); // move
|
||||
events.ScheduleEvent(EVENT_OUTRO_HORDE_6, 4000); // say
|
||||
}
|
||||
else if (id == POINT_FINAL)
|
||||
{
|
||||
if (Creature* deathbringer = ObjectAccessor::GetCreature(*me, deathbringerSaurfangGUID))
|
||||
deathbringer->DespawnOrUnsummon();
|
||||
me->DespawnOrUnsummon();
|
||||
case POINT_FIRST_STEP:
|
||||
me->RemoveUnitMovementFlag(MOVEMENTFLAG_WALKING);
|
||||
Talk(SAY_INTRO_HORDE_3);
|
||||
events.ScheduleEvent(EVENT_INTRO_HORDE_5, 15500, 0, PHASE_INTRO_H);
|
||||
events.ScheduleEvent(EVENT_INTRO_HORDE_6, 29500, 0, PHASE_INTRO_H);
|
||||
events.ScheduleEvent(EVENT_INTRO_HORDE_7, 43800, 0, PHASE_INTRO_H);
|
||||
events.ScheduleEvent(EVENT_INTRO_HORDE_8, 47000, 0, PHASE_INTRO_H);
|
||||
if (Creature* deathbringer = ObjectAccessor::GetCreature(*me, deathbringerSaurfangGUID))
|
||||
deathbringer->AI()->DoAction(ACTION_CONTINUE_INTRO);
|
||||
break;
|
||||
case POINT_CORPSE:
|
||||
if (Creature* deathbringer = ObjectAccessor::GetCreature(*me, deathbringerSaurfangGUID))
|
||||
{
|
||||
deathbringer->CastSpell(me, SPELL_RIDE_VEHICLE, true); // for the packet logs.
|
||||
deathbringer->SetFlag(UNIT_FIELD_FLAGS, UNIT_FLAG_NOT_SELECTABLE);
|
||||
deathbringer->setDeathState(ALIVE);
|
||||
deathbringer->EnterVehicle(vehicle, 0);
|
||||
}
|
||||
events.ScheduleEvent(EVENT_OUTRO_HORDE_5, 1000); // move
|
||||
events.ScheduleEvent(EVENT_OUTRO_HORDE_6, 4000); // say
|
||||
break;
|
||||
case POINT_FINAL:
|
||||
if (Creature* deathbringer = ObjectAccessor::GetCreature(*me, deathbringerSaurfangGUID))
|
||||
deathbringer->DespawnOrUnsummon();
|
||||
me->DespawnOrUnsummon();
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -761,40 +785,50 @@ class npc_muradin_bronzebeard_icc : public CreatureScript
|
||||
|
||||
void DoAction(const int32 action)
|
||||
{
|
||||
if (action == ACTION_START_EVENT)
|
||||
switch (action)
|
||||
{
|
||||
// Prevent crashes
|
||||
if (events.GetPhaseMask() & PHASE_INTRO_MASK)
|
||||
return;
|
||||
|
||||
events.SetPhase(PHASE_INTRO_A);
|
||||
GetCreatureListWithEntryInGrid(guardList, me, NPC_SE_SKYBREAKER_MARINE, 20.0f);
|
||||
guardList.sort(Trinity::ObjectDistanceOrderPred(me));
|
||||
uint32 x = 1;
|
||||
for (std::list<Creature*>::iterator itr = guardList.begin(); itr != guardList.end(); ++x, ++itr)
|
||||
(*itr)->AI()->SetData(0, x);
|
||||
|
||||
me->RemoveFlag(UNIT_NPC_FLAGS, UNIT_NPC_FLAG_GOSSIP);
|
||||
Talk(SAY_INTRO_ALLIANCE_1);
|
||||
events.ScheduleEvent(EVENT_INTRO_ALLIANCE_4, 2500+17500+9500, 0, PHASE_INTRO_A);
|
||||
if (instance)
|
||||
case ACTION_START_EVENT:
|
||||
{
|
||||
deathbringerSaurfangGUID = instance->GetData64(DATA_DEATHBRINGER_SAURFANG);
|
||||
instance->HandleGameObject(instance->GetData64(GO_SAURFANG_S_DOOR), true);
|
||||
// Prevent crashes
|
||||
if (events.GetPhaseMask() & PHASE_INTRO_MASK)
|
||||
return;
|
||||
|
||||
events.SetPhase(PHASE_INTRO_A);
|
||||
GetCreatureListWithEntryInGrid(guardList, me, NPC_SE_SKYBREAKER_MARINE, 20.0f);
|
||||
guardList.sort(Trinity::ObjectDistanceOrderPred(me));
|
||||
uint32 x = 1;
|
||||
for (std::list<Creature*>::iterator itr = guardList.begin(); itr != guardList.end(); ++x, ++itr)
|
||||
(*itr)->AI()->SetData(0, x);
|
||||
|
||||
me->RemoveFlag(UNIT_NPC_FLAGS, UNIT_NPC_FLAG_GOSSIP);
|
||||
Talk(SAY_INTRO_ALLIANCE_1);
|
||||
events.ScheduleEvent(EVENT_INTRO_ALLIANCE_4, 2500+17500+9500, 0, PHASE_INTRO_A);
|
||||
if (instance)
|
||||
{
|
||||
deathbringerSaurfangGUID = instance->GetData64(DATA_DEATHBRINGER_SAURFANG);
|
||||
instance->HandleGameObject(instance->GetData64(GO_SAURFANG_S_DOOR), true);
|
||||
}
|
||||
if (Creature* deathbringer = ObjectAccessor::GetCreature(*me, deathbringerSaurfangGUID))
|
||||
deathbringer->AI()->DoAction(PHASE_INTRO_A);
|
||||
break;
|
||||
}
|
||||
if (Creature* deathbringer = ObjectAccessor::GetCreature(*me, deathbringerSaurfangGUID))
|
||||
deathbringer->AI()->DoAction(PHASE_INTRO_A);
|
||||
}
|
||||
else if (action == ACTION_START_OUTRO)
|
||||
{
|
||||
me->RemoveAurasDueToSpell(SPELL_GRIP_OF_AGONY);
|
||||
Talk(SAY_OUTRO_ALLIANCE_1);
|
||||
me->RemoveUnitMovementFlag(MOVEMENTFLAG_LEVITATING);
|
||||
me->SendMovementFlagUpdate();
|
||||
me->Relocate(me->GetPositionX(), me->GetPositionY(), 539.2917f);
|
||||
me->SendMonsterMove(me->GetPositionX(), me->GetPositionY(), 539.2917f, SPLINEFLAG_FALLING, 0, 0.0f);
|
||||
for (std::list<Creature*>::iterator itr = guardList.begin(); itr != guardList.end(); ++itr)
|
||||
(*itr)->AI()->DoAction(ACTION_DESPAWN);
|
||||
case ACTION_START_OUTRO:
|
||||
{
|
||||
me->RemoveAurasDueToSpell(SPELL_GRIP_OF_AGONY);
|
||||
Talk(SAY_OUTRO_ALLIANCE_1);
|
||||
me->RemoveUnitMovementFlag(MOVEMENTFLAG_LEVITATING);
|
||||
me->SendMovementFlagUpdate();
|
||||
me->Relocate(me->GetPositionX(), me->GetPositionY(), 539.2917f);
|
||||
me->SendMonsterMove(me->GetPositionX(), me->GetPositionY(), 539.2917f, SPLINEFLAG_FALLING, 0, 0.0f);
|
||||
for (std::list<Creature*>::iterator itr = guardList.begin(); itr != guardList.end(); ++itr)
|
||||
(*itr)->AI()->DoAction(ACTION_DESPAWN);
|
||||
break;
|
||||
}
|
||||
case ACTION_INTERRUPT_INTRO:
|
||||
events.Reset();
|
||||
for (std::list<Creature*>::iterator itr = guardList.begin(); itr != guardList.end(); ++itr)
|
||||
(*itr)->AI()->DoAction(ACTION_DESPAWN);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -887,13 +921,13 @@ class npc_saurfang_event : public CreatureScript
|
||||
{
|
||||
npc_saurfang_eventAI(Creature* creature) : ScriptedAI(creature)
|
||||
{
|
||||
uiNPCindex = 0;
|
||||
npcIndex = 0;
|
||||
}
|
||||
|
||||
void SetData(uint32 type, uint32 data)
|
||||
{
|
||||
ASSERT(!type && data && data < 6);
|
||||
uiNPCindex = data;
|
||||
npcIndex = data;
|
||||
}
|
||||
|
||||
void SpellHit(Unit* /*caster*/, SpellEntry const* spell)
|
||||
@@ -901,21 +935,20 @@ class npc_saurfang_event : public CreatureScript
|
||||
if (spell->Id == SPELL_GRIP_OF_AGONY)
|
||||
{
|
||||
me->AddUnitMovementFlag(MOVEMENTFLAG_LEVITATING);
|
||||
me->GetMotionMaster()->MovePoint(POINT_CHOKE, chokePos[uiNPCindex]);
|
||||
me->GetMotionMaster()->MovePoint(POINT_CHOKE, chokePos[npcIndex]);
|
||||
}
|
||||
}
|
||||
|
||||
void DoAction(const int32 action)
|
||||
{
|
||||
if (action == ACTION_CHARGE && uiNPCindex)
|
||||
me->GetMotionMaster()->MoveCharge(chargePos[uiNPCindex].GetPositionX(), chargePos[uiNPCindex].GetPositionY(), chargePos[uiNPCindex].GetPositionZ(), 13.0f, POINT_CHARGE);
|
||||
if (action == ACTION_CHARGE && npcIndex)
|
||||
me->GetMotionMaster()->MoveCharge(chargePos[npcIndex].GetPositionX(), chargePos[npcIndex].GetPositionY(), chargePos[npcIndex].GetPositionZ(), 13.0f, POINT_CHARGE);
|
||||
else if (action == ACTION_DESPAWN)
|
||||
me->DespawnOrUnsummon();
|
||||
}
|
||||
|
||||
private:
|
||||
EventMap events;
|
||||
uint32 uiNPCindex;
|
||||
uint32 npcIndex;
|
||||
};
|
||||
|
||||
CreatureAI* GetAI(Creature* creature) const
|
||||
|
||||
Reference in New Issue
Block a user