From fdd96aadce8b461ff37d0771556dbaefab15d2ca Mon Sep 17 00:00:00 2001 From: Ovahlord Date: Fri, 30 Oct 2020 15:15:16 +0100 Subject: [PATCH] Scripts/TwilightHighlands: scripted first three Crucible of Carnage arena events --- .../world/4.3.4/2020_10_30_00_world.sql | 164 ++++++++++ .../eastern_kingdoms_script_loader.cpp | 2 + .../zone_twilight_highlands.cpp | 309 ++++++++++++++++++ 3 files changed, 475 insertions(+) create mode 100644 sql/updates/world/4.3.4/2020_10_30_00_world.sql create mode 100644 src/server/scripts/EasternKingdoms/zone_twilight_highlands.cpp diff --git a/sql/updates/world/4.3.4/2020_10_30_00_world.sql b/sql/updates/world/4.3.4/2020_10_30_00_world.sql new file mode 100644 index 00000000000..3d21958b00a --- /dev/null +++ b/sql/updates/world/4.3.4/2020_10_30_00_world.sql @@ -0,0 +1,164 @@ + +UPDATE `creature_template` SET `ScriptName`= 'npc_th_gurgthock' WHERE `entry`= 46935; +UPDATE `creature_template` SET `unit_flags`= 33554432, `unit_flags2`= 34816, `flags_extra`= 128 WHERE `entry`= 48549; + +DELETE FROM `creature_text` WHERE `CreatureID` IN (46935, 46945, 46946); +INSERT INTO `creature_text` (`CreatureID`, `GroupID`, `ID`, `Text`, `Type`, `Language`, `Probability`, `Emote`, `Duration`, `Sound`, `BroadcastTextId`, `comment`) VALUES +-- Hurp Derp +(46935, 0, 0, 'The grand Crucible of Carnage awaits, $n. Remember, once a battle starts you have to stay in the arena. WIN OR DIE!', 12, 0, 100, 1, 0, 0, 46988, 'Gurgthock to Player'), +(46935, 1, 0, 'Here we are once again, ladies and gentlemen. The epic struggle between life and death in the Crucible of Carnage! For this round we have $n versus... a really fat ogre? Wait, seriously?! That\'s all we could come up with on short notice? What am I paying you for? ', 14, 0, 100, 22, 0, 0, 46989, 'Gurgthock to Player'), +(46935, 2, 0, 'Whatever, let the fight begin!', 14, 0, 100, 22, 0, 0, 46990, 'Gurgthock to Player'), +(46935, 3, 0, 'W-W-W-WINNER! We have a winner! Good job and stuff!', 14, 0, 100, 15, 0, 0, 46998, 'Gurgthock to Player'), +-- Second Quest (Alliance) +(46935, 4, 0, 'The battle is about to begin! $n vs. the vicious Dragonmaw, Torg Drakeflayer! I THINK he\'s vicious anyway - hard to tell. I just let him because they let us take over their old arena here. Here\'s hoping for some blood!', 14, 0, 100, 22, 0, 0, 46991, 'Gurgthock to Player'), +(46935, 5, 0, 'OOOOOOOH! Check that mess out! Amazing win! Way to stick it through him!', 14, 0, 100, 22, 0, 0, 48556, 'Gurgthock to Player'), +-- Second Quest (Horde) +(46935, 6, 0, 'I\'ve got a LITTLE somethin\' special for ya this time, folks! You aren\'t half the man of this half-man! $N vs. the vicious Wildhammer... SULLY KNEECAPPER!!!', 14, 0, 100, 22, 0, 0, 46992, 'Gurgthock to Player'), +(46935, 7, 0, 'This match is sure to be SHORT! Okay, okay, I\'m done. Let the bloodbath begin!', 12, 0, 100, 22, 0, 0, 46993, 'Gurgthock to Player'), +(46935, 8, 0, 'Bah, couldn\'t you have dragged it out a bit! People don\'t pay me when you make it look that easy! Add some theatrics to it, will ya?!', 14, 0, 100, 22, 0, 0, 48557, 'Gurgthock to Player'), +-- Torg Drakeflayer +(46945, 0, 0, 'All of the highlands belong to the Dragonmaw, even this pit!', 14, 0, 100, 22, 0, 0, 46969, 'Torg Drakeflayer'), +(46945, 1, 0, 'Pitiful meat bags! Feel the full force of the Dragonmaw!', 14, 0, 100, 0, 0, 0, 47651, 'Torg Drakeflayer'), +-- Sully Kneecapper +(46946, 0, 0, 'My little sister could best the lot of ya. This ain\'t no arena. This is a nursery!', 14, 0, 100, 22, 0, 0, 46970, 'Sully Kneecapper to Player'), +(46946, 1, 0, 'Perhaps ye filthy animals would like another taste o the dirt!', 14, 0, 100, 0, 0, 0, 47652, 'Sully Kneecapper'); + +UPDATE `quest_template_addon` SET `SpecialFlags`= 2 WHERE `ID` IN (27863, 27864, 27865); +UPDATE `quest_template_addon` SET `PrevQuestId`= 27863 WHERE `ID` IN (27864, 27865); + +DELETE FROM `creature` WHERE `guid`= 383348; +DELETE FROM `creature_addon` WHERE `guid`= 383348; + +DELETE FROM `spell_script_names` WHERE `ScriptName` IN +('spell_th_grab_targeting', +'spell_th_charge'); + +INSERT INTO `spell_script_names` (`spell_id`, `ScriptName`) VALUES +(94999, 'spell_th_grab_targeting'), +(88540, 'spell_th_charge'); + +-- Creature Hurp'derp 46944 SAI +SET @ENTRY := 46944; +UPDATE `creature_template` SET `AIName`="SmartAI" WHERE `entry`= @ENTRY; +DELETE FROM `smart_scripts` WHERE `entryorguid`=@ENTRY AND `source_type`=0; +INSERT INTO `smart_scripts` (`entryorguid`, `source_type`, `id`, `link`, `event_type`, `event_phase_mask`, `event_chance`, `event_flags`, `event_param1`, `event_param2`, `event_param3`, `event_param4`, `action_type`, `action_param1`, `action_param2`, `action_param3`, `action_param4`, `action_param5`, `action_param6`, `target_type`, `target_param1`, `target_param2`, `target_param3`, `target_x`, `target_y`, `target_z`, `target_o`, `comment`) VALUES +(@ENTRY, 0, 0, 0, 0, 0, 100, 0, 8000, 10000, 11000, 12000, 11, 88482, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, "Update (In Combat) 8000 min and 10000 max ms (repeat 11000 min 12000 max ms) - Self: Cast spell 88482 on Self // "), +(@ENTRY, 0, 1, 0, 0, 0, 100, 0, 15000, 15000, 30000, 30000, 11, 83016, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, "Update (In Combat) 15000 min and 15000 max ms (repeat 30000 min 30000 max ms) - Self: Cast spell 83016 on Self // "), +(@ENTRY, 0, 2, 0, 7, 0, 100, 0, 0, 0, 0, 0, 41, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, "On evade - Self: Despawn instantly // "); + +UPDATE `creature_template` SET `DamageModifier`= 30, `BaseVariance`= 0.5, `mechanic_immune_mask`= 650854271 WHERE `entry`= 46944; + +-- Creature Torg Drakeflayer 46945 SAI +SET @ENTRY := 46945; +UPDATE `creature_template` SET `AIName`="SmartAI" WHERE `entry`= @ENTRY; +DELETE FROM `smart_scripts` WHERE `entryorguid`=@ENTRY AND `source_type`=0; +INSERT INTO `smart_scripts` (`entryorguid`, `source_type`, `id`, `link`, `event_type`, `event_phase_mask`, `event_chance`, `event_flags`, `event_param1`, `event_param2`, `event_param3`, `event_param4`, `action_type`, `action_param1`, `action_param2`, `action_param3`, `action_param4`, `action_param5`, `action_param6`, `target_type`, `target_param1`, `target_param2`, `target_param3`, `target_x`, `target_y`, `target_z`, `target_o`, `comment`) VALUES +(@ENTRY, 0, 0, 0, 34, 0, 100, 0, 16, 1, 0, 0, 80, 4694500, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, "On movement of type EFFECT_MOTION_TYPE inform, point 1 - Start timed action list id #4694500 // "), +(@ENTRY, 0, 1, 0, 0, 0, 100, 0, 7000, 7000, 21000, 22000, 11, 80182, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, "Update (In Combat) 7000 min and 7000 max ms (repeat 21000 min 22000 max ms) - Self: Cast spell 80182 on Victim // "), +(@ENTRY, 0, 2, 0, 0, 0, 100, 0, 21000, 21000, 31000, 31000, 11, 94999, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, "Update (In Combat) 21000 min and 21000 max ms (repeat 31000 min 31000 max ms) - Self: Cast spell 94999 on Self // "), +(@ENTRY, 0, 3, 4, 7, 0, 100, 0, 0, 0, 0, 0, 41, 0, 0, 0, 0, 0, 0, 12, 0, 0, 0, 0, 0, 0, 0, "On evade - storedTarget[0]: Despawn instantly // "), +(@ENTRY, 0, 4, 0, 61, 0, 100, 0, 0, 0, 0, 0, 41, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, " Linked - Self: Despawn instantly // "), +(@ENTRY, 0, 5, 0, 17, 0, 100, 0, 47476, 0, 0, 0, 64, 0, 0, 0, 0, 0, 0, 7, 0, 0, 0, 0, 0, 0, 0, "On summoned unit Gloomwing (47476) - Self: Target_0 = Action invoker // "), +(@ENTRY, 0, 6, 0, 4, 0, 100, 0, 0, 0, 0, 0, 45, 1, 0, 0, 0, 0, 0, 12, 0, 0, 0, 0, 0, 0, 0, "On aggro - storedTarget[0]: Set creature data #1 to 0 // "), +(@ENTRY, 0, 7, 0, 27, 0, 100, 0, 0, 0, 0, 0, 1, 1, 1000, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, "On passenger boarded (vehicle) - Self: Talk 1 // "), +(@ENTRY, 0, 8, 0, 52, 0, 100, 0, 1, 46945, 0, 0, 11, 88540, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, "When text 1 said by creature Torg Drakeflayer (46945) is over - Self: Cast spell 88540 on Self // "), +(@ENTRY, 0, 9, 0, 6, 0, 100, 0, 0, 0, 0, 0, 41, 0, 0, 0, 0, 0, 0, 12, 0, 0, 0, 0, 0, 0, 0, "On death - storedTarget[0]: Despawn instantly // "), +(@ENTRY, 0, 10, 0, 63, 0, 100, 0, 0, 0, 0, 0, 12, 47476, 8, 0, 0, 0, 0, 8, 0, 0, 0, -4180.601, -5147.3, 26.7149, 0, "When just created - Self: Summon creature Gloomwing (47476) at (-4180.601, -5147.3, 26.7149, 0) // "); + +-- TimedActionList 4694500 SAI +SET @ENTRY := 4694500; +DELETE FROM `smart_scripts` WHERE `entryorguid`=@ENTRY AND `source_type`=9; +INSERT INTO `smart_scripts` (`entryorguid`, `source_type`, `id`, `link`, `event_type`, `event_phase_mask`, `event_chance`, `event_flags`, `event_param1`, `event_param2`, `event_param3`, `event_param4`, `action_type`, `action_param1`, `action_param2`, `action_param3`, `action_param4`, `action_param5`, `action_param6`, `target_type`, `target_param1`, `target_param2`, `target_param3`, `target_x`, `target_y`, `target_z`, `target_o`, `comment`) VALUES +(@ENTRY, 9, 0, 0, 0, 0, 100, 0, 2000, 2000, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, "Update (In Combat) 2000 min and 2000 max ms (repeat 0 min 0 max ms) - Self: Talk 0 // "), +(@ENTRY, 9, 1, 0, 0, 0, 100, 0, 2500, 2500, 0, 0, 69, 0, 0, 0, 0, 0, 0, 8, 0, 0, 0, -4182.37, -5148.59, -7.621854, 0, "Update (In Combat) 2500 min and 2500 max ms (repeat 0 min 0 max ms) - Self: Move to position (-4182.37, -5148.59, -7.621854, 0) (point id 0) // "), +(@ENTRY, 9, 2, 0, 0, 0, 100, 0, 0, 0, 0, 0, 19, 768, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, "Update (In Combat) 0 min and 0 max ms (repeat 0 min 0 max ms) - Self: Remove UNIT_FLAGS to UNIT_FLAG_IMMUNE_TO_PC, UNIT_FLAG_IMMUNE_TO_NPC // "); + +UPDATE `creature_template` SET `DamageModifier`= 30, `BaseVariance`= 0.5, `mechanic_immune_mask`= 650854271, `unit_flags`= 33600, `VehicleId`= 1269 WHERE `entry`= 46945; + +-- Creature Gloomwing 47476 SAI +SET @ENTRY := 47476; +UPDATE `creature_template` SET `AIName`="SmartAI" WHERE `entry`= @ENTRY; +DELETE FROM `smart_scripts` WHERE `entryorguid`=@ENTRY AND `source_type`=0; +INSERT INTO `smart_scripts` (`entryorguid`, `source_type`, `id`, `link`, `event_type`, `event_phase_mask`, `event_chance`, `event_flags`, `event_param1`, `event_param2`, `event_param3`, `event_param4`, `action_type`, `action_param1`, `action_param2`, `action_param3`, `action_param4`, `action_param5`, `action_param6`, `target_type`, `target_param1`, `target_param2`, `target_param3`, `target_x`, `target_y`, `target_z`, `target_o`, `comment`) VALUES +(@ENTRY, 0, 0, 0, 63, 0, 100, 0, 0, 0, 0, 0, 8, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, "When just created - Self: Set react state to REACT_PASSIVE // "), +(@ENTRY, 0, 1, 0, 60, 1, 100, 0, 1000, 2000, 1000, 4000, 11, 88515, 0, 0, 0, 0, 0, 23, 0, 0, 0, 0, 0, 0, 0, "Every 10000 and 4000 ms (for the first time, timer between 1000 and 2000 ms) - Self: Cast spell 88515 on Owner/Summoner // "), +(@ENTRY, 0, 2, 0, 38, 0, 100, 0, 1, 0, 0, 0, 22, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, "On data 1 set to 0 - Self: Set event phase to 1 // "); + +DELETE FROM `waypoint_data` WHERE `id`= 47476 * 10; +INSERT INTO `waypoint_data` (`id`, `point`, `position_x`, `position_y`, `position_z`, `orientation`, `velocity`) VALUES +(47476 * 10, 1, -4180.6006, -5147.3003, 26.714905, 0, 0), +(47476 * 10, 2, -4160.6006, -5147.3003, 26.714905, 0, 0), +(47476 * 10, 3, -4166.4585, -5161.4424, 26.714905, 0, 0), +(47476 * 10, 4, -4180.6006, -5167.3003, 26.714905, 0, 0), +(47476 * 10, 5, -4194.7427, -5161.4424, 26.714905, 0, 0), +(47476 * 10, 6, -4200.6006, -5147.3003, 26.714905, 0, 0), +(47476 * 10, 7, -4194.7427, -5133.158 , 26.714905, 0, 0), +(47476 * 10, 8, -4180.6006, -5127.3003, 26.714905, 0, 0), +(47476 * 10, 9, -4166.4585, -5133.158 , 26.714905, 0, 0); + +UPDATE `creature_template` SET `MovementType`= 3 WHERE `entry`= 47476; +UPDATE `creature_template_addon` SET `cyclicSplinePathId` = 474760 WHERE `entry`= 47476; + +-- Creature Sully Kneecapper 46946 SAI +SET @ENTRY := 46946; +UPDATE `creature_template` SET `AIName`="SmartAI" WHERE `entry`= @ENTRY; +DELETE FROM `smart_scripts` WHERE `entryorguid`=@ENTRY AND `source_type`=0; +INSERT INTO `smart_scripts` (`entryorguid`, `source_type`, `id`, `link`, `event_type`, `event_phase_mask`, `event_chance`, `event_flags`, `event_param1`, `event_param2`, `event_param3`, `event_param4`, `action_type`, `action_param1`, `action_param2`, `action_param3`, `action_param4`, `action_param5`, `action_param6`, `target_type`, `target_param1`, `target_param2`, `target_param3`, `target_x`, `target_y`, `target_z`, `target_o`, `comment`) VALUES +(@ENTRY, 0, 0, 1, 63, 0, 100, 0, 0, 0, 0, 0, 59, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, "When just created - Self: Set walk // "), +(@ENTRY, 0, 1, 0, 61, 0, 100, 0, 0, 0, 0, 0, 80, 4694600, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, " Linked - Start timed action list id #4694600 // "), +(@ENTRY, 0, 2, 3, 7, 0, 100, 0, 0, 0, 0, 0, 41, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, "On evade - Self: Despawn instantly // "), +(@ENTRY, 0, 3, 0, 61, 0, 100, 0, 0, 0, 0, 0, 41, 0, 0, 0, 0, 0, 0, 12, 0, 0, 0, 0, 0, 0, 0, " Linked - storedTarget[0]: Despawn instantly // "), +(@ENTRY, 0, 4, 0, 17, 0, 100, 0, 47482, 0, 0, 0, 64, 0, 0, 0, 0, 0, 0, 7, 0, 0, 0, 0, 0, 0, 0, "On summoned unit Jora ""Nobbly"" Wildwing (47482) - Self: Target_0 = Action invoker // "), +(@ENTRY, 0, 5, 0, 6, 0, 100, 0, 0, 0, 0, 0, 41, 0, 0, 0, 0, 0, 0, 12, 0, 0, 0, 0, 0, 0, 0, "On death - storedTarget[0]: Despawn instantly // "), +(@ENTRY, 0, 6, 0, 4, 0, 100, 0, 0, 0, 0, 0, 12, 47482, 8, 0, 0, 0, 0, 8, 0, 0, 0, -4181.449, -5146.95, 26.49864, 0.09909387, "On aggro - Self: Summon creature Jora ""Nobbly"" Wildwing (47482) at (-4181.449, -5146.95, 26.49864, 0.09909387) // "), +(@ENTRY, 0, 7, 0, 27, 0, 100, 0, 0, 0, 0, 0, 1, 1, 1000, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, "On passenger boarded (vehicle) - Self: Talk 1 // "), +(@ENTRY, 0, 8, 0, 52, 0, 100, 0, 1, 46946, 0, 0, 11, 88540, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, "When text 1 said by creature Sully Kneecapper (46946) is over - Self: Cast spell 88540 on Self // "), +(@ENTRY, 0, 9, 0, 0, 0, 100, 0, 20000, 20000, 30000, 30000, 11, 88288, 0, 0, 0, 0, 0, 5, 0, 0, 0, 0, 0, 0, 0, "Update (In Combat) 20000 min and 20000 max ms (repeat 30000 min 30000 max ms) - Self: Cast spell 88288 on Random hostile // "), +(@ENTRY, 0, 10, 0, 0, 0, 100, 0, 8000, 8000, 17000, 20000, 11, 80182, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, "Update (In Combat) 8000 min and 8000 max ms (repeat 17000 min 20000 max ms) - Self: Cast spell 80182 on Victim // "); + +-- TimedActionList 4694600 SAI +SET @ENTRY := 4694600; +DELETE FROM `smart_scripts` WHERE `entryorguid`=@ENTRY AND `source_type`=9; +INSERT INTO `smart_scripts` (`entryorguid`, `source_type`, `id`, `link`, `event_type`, `event_phase_mask`, `event_chance`, `event_flags`, `event_param1`, `event_param2`, `event_param3`, `event_param4`, `action_type`, `action_param1`, `action_param2`, `action_param3`, `action_param4`, `action_param5`, `action_param6`, `target_type`, `target_param1`, `target_param2`, `target_param3`, `target_x`, `target_y`, `target_z`, `target_o`, `comment`) VALUES +(@ENTRY, 9, 0, 0, 0, 0, 100, 0, 0, 0, 0, 0, 69, 0, 0, 0, 0, 0, 0, 8, 0, 0, 0, -4226.931, -5139.33, -7.67494, 0, "Update (In Combat) 0 min and 0 max ms (repeat 0 min 0 max ms) - Self: Move to position (-4226.931, -5139.33, -7.67494, 0) (point id 0) // "), +(@ENTRY, 9, 1, 0, 0, 0, 100, 0, 2400, 2400, 0, 0, 69, 0, 0, 0, 0, 0, 0, 8, 0, 0, 0, -4212.342, -5148.628, -7.67494, 0, "Update (In Combat) 2400 min and 2400 max ms (repeat 0 min 0 max ms) - Self: Move to position (-4212.342, -5148.628, -7.67494, 0) (point id 0) // "), +(@ENTRY, 9, 2, 0, 0, 0, 100, 0, 7300, 7300, 0, 0, 69, 0, 0, 0, 0, 0, 0, 8, 0, 0, 0, -4196.002, -5154.196, -7.621854, 0, "Update (In Combat) 7300 min and 7300 max ms (repeat 0 min 0 max ms) - Self: Move to position (-4196.002, -5154.196, -7.621854, 0) (point id 0) // "), +(@ENTRY, 9, 3, 0, 0, 0, 100, 0, 7200, 7200, 0, 0, 69, 0, 0, 0, 0, 0, 0, 8, 0, 0, 0, -4182.594, -5148.137, -7.621854, 0, "Update (In Combat) 7200 min and 7200 max ms (repeat 0 min 0 max ms) - Self: Move to position (-4182.594, -5148.137, -7.621854, 0) (point id 0) // "), +(@ENTRY, 9, 4, 0, 0, 0, 100, 0, 8500, 8500, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, "Update (In Combat) 8500 min and 8500 max ms (repeat 0 min 0 max ms) - Self: Talk 0 // "), +(@ENTRY, 9, 5, 0, 0, 0, 100, 0, 2300, 2300, 0, 0, 19, 768, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, "Update (In Combat) 2300 min and 2300 max ms (repeat 0 min 0 max ms) - Self: Remove UNIT_FLAGS to UNIT_FLAG_IMMUNE_TO_PC, UNIT_FLAG_IMMUNE_TO_NPC // "); + +UPDATE `creature_template` SET `DamageModifier`= 30, `BaseVariance`= 0.5, `mechanic_immune_mask`= 650854271, `unit_flags`= 33600, `VehicleId`= 1269 WHERE `entry`= 46946; + +-- Creature Jora "Nobbly" Wildwing 47482 SAI +SET @ENTRY := 47482; +UPDATE `creature_template` SET `AIName`="SmartAI" WHERE `entry`= @ENTRY; +DELETE FROM `smart_scripts` WHERE `entryorguid`=@ENTRY AND `source_type`=0; +INSERT INTO `smart_scripts` (`entryorguid`, `source_type`, `id`, `link`, `event_type`, `event_phase_mask`, `event_chance`, `event_flags`, `event_param1`, `event_param2`, `event_param3`, `event_param4`, `action_type`, `action_param1`, `action_param2`, `action_param3`, `action_param4`, `action_param5`, `action_param6`, `target_type`, `target_param1`, `target_param2`, `target_param3`, `target_x`, `target_y`, `target_z`, `target_o`, `comment`) VALUES +(@ENTRY, 0, 0, 0, 63, 0, 100, 0, 0, 0, 0, 0, 8, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, "When just created - Self: Set react state to REACT_PASSIVE // "), +(@ENTRY, 0, 1, 0, 60, 0, 100, 0, 1000, 2000, 1000, 4000, 11, 88530, 0, 0, 0, 0, 0, 23, 0, 0, 0, 0, 0, 0, 0, "Every 1000 and 4000 ms (for the first time, timer between 1000 and 2000 ms) - Self: Cast spell 88530 on Owner/Summoner // "); + +DELETE FROM `waypoint_data` WHERE `id`= 47482 * 10; +INSERT INTO `waypoint_data` (`id`, `point`, `position_x`, `position_y`, `position_z`, `orientation`, `velocity`) VALUES +(47482 * 10, 1, -4185.9097, -5127.3003, 26.498642, 0, 0), +(47482 * 10, 2, -4171.7676, -5133.158, 26.498642, 0, 0), +(47482 * 10, 3, -4165.9097, -5147.3003, 26.498642, 0, 0), +(47482 * 10, 4, -4171.7676, -5161.4424, 26.498642, 0, 0), +(47482 * 10, 5, -4185.9097, -5167.3003, 26.498642, 0, 0), +(47482 * 10, 6, -4200.052, -5161.4424, 26.498642, 0, 0), +(47482 * 10, 7, -4205.9097, -5147.3003, 26.498642, 0, 0), +(47482 * 10, 8, -4200.052, -5133.158, 26.498642, 0, 0); + +DELETE FROM `creature_template_movement` WHERE `CreatureId`= 47482; +INSERT INTO `creature_template_movement` (`CreatureId`, `Flight`) VALUES +(47482, 1); + +UPDATE `creature_template_addon` SET `cyclicSplinePathId`= 474820 WHERE `entry`= 47482; + +UPDATE `creature_template` SET `VehicleId`= 613, `MovementType`= 3 WHERE `entry`= 47482; +DELETE FROM `npc_spellclick_spells` WHERE `npc_entry`= 47482; +INSERT INTO `npc_spellclick_spells` (`npc_entry`, `spell_id`, `cast_flags`, `user_type`) VALUES +(47482, 46598, 1, 0); + +DELETE FROM `vehicle_template_accessory` WHERE `entry`= 47482; +INSERT INTO `vehicle_template_accessory` (`entry`, `accessory_entry`, `seat_id`, `minion`, `description`, `summonType`, `summonTimer`) VALUES +(47482, 37977, 0, 1, '', 6, 0); diff --git a/src/server/scripts/EasternKingdoms/eastern_kingdoms_script_loader.cpp b/src/server/scripts/EasternKingdoms/eastern_kingdoms_script_loader.cpp index e53e1485524..3bb5084bcec 100644 --- a/src/server/scripts/EasternKingdoms/eastern_kingdoms_script_loader.cpp +++ b/src/server/scripts/EasternKingdoms/eastern_kingdoms_script_loader.cpp @@ -239,6 +239,7 @@ void AddSC_stormwind_city(); void AddSC_swamp_of_sorrows(); void AddSC_tirisfal_glades(); void AddSC_tol_barad(); +void AddSC_twilight_highlands(); void AddSC_undercity(); void AddSC_western_plaguelands(); void AddSC_westfall(); @@ -471,6 +472,7 @@ void AddEasternKingdomsScripts() AddSC_swamp_of_sorrows(); AddSC_tirisfal_glades(); AddSC_tol_barad(); + AddSC_twilight_highlands(); AddSC_undercity(); AddSC_western_plaguelands(); AddSC_westfall(); diff --git a/src/server/scripts/EasternKingdoms/zone_twilight_highlands.cpp b/src/server/scripts/EasternKingdoms/zone_twilight_highlands.cpp new file mode 100644 index 00000000000..3f84fa89e8b --- /dev/null +++ b/src/server/scripts/EasternKingdoms/zone_twilight_highlands.cpp @@ -0,0 +1,309 @@ +/* + * This file is part of the TrinityCore Project. See AUTHORS file for Copyright information + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License as published by the + * Free Software Foundation; either version 2 of the License, or (at your + * option) any later version. + * + * This program is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for + * more details. + * + * You should have received a copy of the GNU General Public License along + * with this program. If not, see . + */ + +#include "ScriptMgr.h" +#include "ScriptedCreature.h" +#include "MotionMaster.h" +#include "ObjectAccessor.h" +#include "Player.h" +#include "Group.h" +#include "Spell.h" +#include "SpellScript.h" + +enum Points +{ + POINT_NONE = 0, + POINT_ID_TORG_DRAKEFLAYER_INTRO = 1, + POINT_ID_SULLY_KNEECAPPER_INTRO = 1, +}; + +enum TwilightHightlandsArena +{ + // Quests + QUEST_ID_COC_THE_BLOODEYE_BRUISER = 27863, + QUEST_ID_COC_THE_DEADLY_DRAGONMAW = 27864, + QUEST_ID_COC_THE_WAYWARD_WILDHAMMER = 27865, + + // Events + EVENT_SAY_REMEMBER = 1, + EVENT_ANNOUNCE_BATTLE_1, + EVENT_SUMMON_HURP_DERP, + + EVENT_ANNOUNCE_BATTLE_2_ALLIANCE, + EVENT_SUMMON_TORG_DRAKEFLAYER, + + EVENT_ANNOUNCE_BATTLE_2_HORDE, + EVENT_SUMMON_SULLY_KNEECAPPER, + + + // Texts + SAY_REMEMBER = 0, + // Hurp'Derp + SAY_INTRO_BATTLE_1 = 1, + SAY_START_BATTLE_1 = 2, + SAY_HURP_DERP_DEFEATED = 3, + // Torg Drakeflayer + SAY_INTRO_BATTLE_2_ALLIANCE = 4, + SAY_TORG_DRAKEFLAYER_DEFEATED = 5, + // Sully Kneedcapper + SAY_INTRO_BATTLE_2_HORDE = 6, + SAY_START_BATTLE_2_HORDE = 7, + SAY_SULLY_KNEECAPPER_DEFEATED = 8, + + // Creatures + NPC_HURP_DERP = 46944, + NPC_TORG_DRAKEFLAYER = 46945, + NPC_SULLY_KNEECAPPER = 46946 +}; + +Position const HurpDerpSpawnPosition = { -4133.8647f, -5192.587f, -9.481462f, 2.447715520858764648f }; +Position const HurpDerpMovePosition = { -4182.394f, -5148.4478f, -7.7360706f }; +Position const TorgDrakeflayerSpawnPosition = { -4136.02f, -5137.94f, 40.58253f, 3.379617214202880859 }; +Position const TorgDrakeflayerJumpPosition = { -4168.87f, -5145.91f, -7.73344f }; +Position const SullyKneecapperSpawnPosition = { -4235.0522f, -5133.8877f, -4.938032f, 5.69227f }; + +// 46935 - Gurgthock +struct npc_th_gurgthock : public ScriptedAI +{ + npc_th_gurgthock(Creature* creature) : ScriptedAI(creature) { } + + void QuestAccept(Player* player, Quest const* quest) override + { + if (!_playerGUID.IsEmpty()) + return; + + _playerGUID = player->GetGUID(); + me->setActive(true); + me->RemoveFlag(UNIT_NPC_FLAGS, UNIT_NPC_FLAG_QUESTGIVER); + _events.ScheduleEvent(EVENT_SAY_REMEMBER, 1ms); + + switch (quest->GetQuestId()) + { + case QUEST_ID_COC_THE_BLOODEYE_BRUISER: + _events.ScheduleEvent(EVENT_ANNOUNCE_BATTLE_1, 8s + 500ms); + break; + case QUEST_ID_COC_THE_DEADLY_DRAGONMAW: + _events.ScheduleEvent(EVENT_ANNOUNCE_BATTLE_2_ALLIANCE, 8s + 500ms); + break; + case QUEST_ID_COC_THE_WAYWARD_WILDHAMMER: + _events.ScheduleEvent(EVENT_ANNOUNCE_BATTLE_2_HORDE, 6s); + break; + default: + break; + } + } + + void SummonedCreatureDies(Creature* summon, Unit* killer) override + { + // Summon has been defeated. Enable Questgiver and complete quest for killer's group + summon->DespawnOrUnsummon(3s); + + switch (summon->GetEntry()) + { + case NPC_HURP_DERP: + Talk(SAY_HURP_DERP_DEFEATED, killer); + CompleteQuest(summon, QUEST_ID_COC_THE_BLOODEYE_BRUISER); + break; + case NPC_TORG_DRAKEFLAYER: + Talk(SAY_TORG_DRAKEFLAYER_DEFEATED, killer); + CompleteQuest(summon, QUEST_ID_COC_THE_DEADLY_DRAGONMAW); + break; + case NPC_SULLY_KNEECAPPER: + Talk(SAY_SULLY_KNEECAPPER_DEFEATED, killer); + CompleteQuest(summon, QUEST_ID_COC_THE_WAYWARD_WILDHAMMER); + break; + default: + break; + } + + me->setActive(false); + me->SetFlag(UNIT_NPC_FLAGS, UNIT_NPC_FLAG_QUESTGIVER); + _playerGUID.Clear(); + } + + void SummonedCreatureDespawn(Creature* summon) override + { + // Summon has entered evade mode. Fail quest and reset quest giver + if (summon->IsAlive()) + { + switch (summon->GetEntry()) + { + case NPC_HURP_DERP: + FailQuest(summon, QUEST_ID_COC_THE_BLOODEYE_BRUISER); + break; + case NPC_TORG_DRAKEFLAYER: + FailQuest(summon, QUEST_ID_COC_THE_DEADLY_DRAGONMAW); + break; + case NPC_SULLY_KNEECAPPER: + FailQuest(summon, QUEST_ID_COC_THE_WAYWARD_WILDHAMMER); + break; + default: + break; + } + + me->setActive(false); + me->SetFlag(UNIT_NPC_FLAGS, UNIT_NPC_FLAG_QUESTGIVER); + _playerGUID.Clear(); + } + } + + void UpdateAI(uint32 diff) override + { + _events.Update(diff); + + while (uint32 eventId = _events.ExecuteEvent()) + { + switch (eventId) + { + case EVENT_SAY_REMEMBER: + if (Unit const* player = ObjectAccessor::GetUnit(*me, _playerGUID)) + Talk(SAY_REMEMBER, player); + break; + case EVENT_ANNOUNCE_BATTLE_1: + if (Unit const* player = ObjectAccessor::GetUnit(*me, _playerGUID)) + Talk(SAY_INTRO_BATTLE_1, player); + _events.ScheduleEvent(EVENT_SUMMON_HURP_DERP, 8s); + break; + case EVENT_SUMMON_HURP_DERP: + Talk(SAY_START_BATTLE_1); + if (Creature* hurpDerp = DoSummon(NPC_HURP_DERP, HurpDerpSpawnPosition)) + { + hurpDerp->SetHomePosition(HurpDerpMovePosition); + hurpDerp->GetMotionMaster()->MovePoint(POINT_NONE, HurpDerpMovePosition); + } + break; + case EVENT_ANNOUNCE_BATTLE_2_ALLIANCE: + if (Unit const* player = ObjectAccessor::GetUnit(*me, _playerGUID)) + Talk(SAY_INTRO_BATTLE_2_ALLIANCE, player); + _events.ScheduleEvent(EVENT_SUMMON_TORG_DRAKEFLAYER, 6s); + break; + case EVENT_SUMMON_TORG_DRAKEFLAYER: + if (Creature* torg = DoSummon(NPC_TORG_DRAKEFLAYER, TorgDrakeflayerSpawnPosition)) + { + torg->SetHomePosition(TorgDrakeflayerJumpPosition); + torg->GetMotionMaster()->MoveJump(TorgDrakeflayerJumpPosition, 11.5f, 16.f, POINT_ID_TORG_DRAKEFLAYER_INTRO); + } + break; + case EVENT_ANNOUNCE_BATTLE_2_HORDE: + if (Unit const* player = ObjectAccessor::GetUnit(*me, _playerGUID)) + Talk(SAY_INTRO_BATTLE_2_HORDE, player); + _events.ScheduleEvent(EVENT_SUMMON_SULLY_KNEECAPPER, 6s); + break; + case EVENT_SUMMON_SULLY_KNEECAPPER: + Talk(SAY_START_BATTLE_2_HORDE); + DoSummon(NPC_SULLY_KNEECAPPER, SullyKneecapperSpawnPosition); + break; + default: + break; + } + } + } + +private: + EventMap _events; + ObjectGuid _playerGUID; + + void CompleteQuest(Creature const* defeatedBoss, uint32 questId) + { + Unit* unit = ObjectAccessor::GetUnit(*me, _playerGUID); + if (!unit || !unit->IsPlayer()) + return; + + Player* player = unit->ToPlayer(); + player->GroupEventHappens(questId, defeatedBoss); + } + + void FailQuest(Creature* const boss, uint32 questId) + { + Unit* unit = ObjectAccessor::GetUnit(*me, _playerGUID); + if (!unit || !unit->IsPlayer()) + return; + + Player* player = unit->ToPlayer(); + + if (Group* group = player->GetGroup()) + { + for (GroupReference* itr = group->GetFirstMember(); itr != nullptr; itr = itr->next()) + { + Player* member = itr->GetSource(); + if (member && member->IsAtGroupRewardDistance(boss) && !player->GetCorpse()) + member->FailQuest(questId); + } + } + else + player->FailQuest(questId); + } +}; + +// 94999 - Grab Targetting +class spell_th_grab_targeting : public SpellScript +{ + void FilterTargets(std::list& targets) + { + targets.remove_if([this](WorldObject const* target) + { + Unit const* unit = target->ToUnit(); + return (!unit || !unit->IsInCombatWith(GetCaster())); + }); + + if (targets.size() > 1) + Trinity::Containers::RandomResize(targets, 1); + } + + void HandleDummyEffect(SpellEffIndex /*effIndex*/) + { + Unit* caster = GetCaster(); + if (!caster) + return; + + caster->CastSpell(GetHitUnit(), GetEffectValue(), true); + } + + void Register() override + { + OnObjectAreaTargetSelect.Register(&spell_th_grab_targeting::FilterTargets, EFFECT_0, TARGET_UNIT_SRC_AREA_ENEMY); + OnEffectHitTarget.Register(&spell_th_grab_targeting::HandleDummyEffect, EFFECT_0, SPELL_EFFECT_DUMMY); + } +}; + +std::array ChargeDestinations = +{ + Position(-4204.6f, -5180.2f, -8.61639f), + Position(-4194.45f, -5104.34f, -7.22446f) +}; + +// 88540 - Charge +class spell_th_charge : public SpellScript +{ + void SetDest(SpellDestination& dest) + { + // While the target type indicates a nearby entry target, there is no sniffable unit target at given coordinates. + dest.Relocate(Trinity::Containers::SelectRandomContainerElement(ChargeDestinations)); + } + + void Register() override + { + OnDestinationTargetSelect.Register(&spell_th_charge::SetDest, EFFECT_0, TARGET_DEST_NEARBY_ENTRY); + } +}; + +void AddSC_twilight_highlands() +{ + RegisterCreatureAI(npc_th_gurgthock); + RegisterSpellScript(spell_th_grab_targeting); + RegisterSpellScript(spell_th_charge); +}