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);
+}