diff --git a/L2J_Mobius_Underground/dist/db_installer/sql/game/grandboss_data.sql b/L2J_Mobius_Underground/dist/db_installer/sql/game/grandboss_data.sql index b20e84e8a4..27ff367d22 100644 --- a/L2J_Mobius_Underground/dist/db_installer/sql/game/grandboss_data.sql +++ b/L2J_Mobius_Underground/dist/db_installer/sql/game/grandboss_data.sql @@ -20,5 +20,6 @@ INSERT IGNORE INTO `grandboss_data` (`boss_id`,`loc_x`,`loc_y`,`loc_z`,`heading` (29028, -105200, -253104, -15264, 0, 62041918, 2248572), -- Valakas (29068, 185708, 114298, -8221,32768, 62802301, 1998000), -- Antharas (29118, 0, 0, 0, 0, 4109288, 1220547), -- Beleth -(25286, 185080, -12613, -5499, 16550, 233660596, 43380), -- Anakim +(25286, 185080, -12613, -5499, 16550, 556345880, 86847), -- Anakim +(25283, 185062, -9605, -5499, 15640, 486021997, 79600), -- Lilith (26124, 0, 0, 0, 0, 13945521, 50920); -- Kelbim \ No newline at end of file diff --git a/L2J_Mobius_Underground/dist/game/config/GrandBoss.ini b/L2J_Mobius_Underground/dist/game/config/GrandBoss.ini index b311b23dcb..9d21a359df 100644 --- a/L2J_Mobius_Underground/dist/game/config/GrandBoss.ini +++ b/L2J_Mobius_Underground/dist/game/config/GrandBoss.ini @@ -122,4 +122,26 @@ AnakimMaxPlayers = 120 AnakimMinPlayerLvl = 90 # Maximum players Level for enter to Anakim. Retail: 94 -AnakimMaxPlayerLvl = 94 \ No newline at end of file +AnakimMaxPlayerLvl = 94 + +# --------------------------------------------------------------------------- +# Lilith +# --------------------------------------------------------------------------- + +# Interval time of Lilith. Value is hour. Range 1-480. Retail: 96 +IntervalOfAnakimSpawn = 96 + +# Random interval. Range 1-192. Retail: 12 +RandomOfLilithSpawn = 12 + +# Minimal count of players for enter to Lilith. Retail: 98 +LilithMinPlayers = 98 + +# Maximum count of players for enter to Lilith. Retail: 120 +LilithMaxPlayers = 120 + +# Minimum players Level for enter to Lilith. Retail: 85 +LilithMinPlayerLvl = 85 + +# Maximum players Level for enter to Lilith. Retail: 89 +lilithMaxPlayerLvl = 89 \ No newline at end of file diff --git a/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31110.html b/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31110.html new file mode 100644 index 0000000000..a64077c0bc --- /dev/null +++ b/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31110.html @@ -0,0 +1,4 @@ +Gatekeeper Ziggurat:
A human-like voice comes from a glowing blue orb:
+ + \ No newline at end of file diff --git a/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31118-01.html b/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31118-01.html new file mode 100644 index 0000000000..76433419b7 --- /dev/null +++ b/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31118-01.html @@ -0,0 +1,4 @@ +Gatekeeper Ziggurat:
+A human-like voice comes from a glowing blue orb:
+Someone already went in, and Lilith disappeared soon after. There is no point in entering right now. + \ No newline at end of file diff --git a/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31118-02.html b/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31118-02.html new file mode 100644 index 0000000000..6d726dc361 --- /dev/null +++ b/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31118-02.html @@ -0,0 +1,3 @@ +Gatekeeper Ziggurat:
+(A command channel needs at least %min% members to challenge Lilith.) + \ No newline at end of file diff --git a/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31118-03.html b/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31118-03.html new file mode 100644 index 0000000000..3a6589712f --- /dev/null +++ b/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31118-03.html @@ -0,0 +1,4 @@ +Gatekeeper Ziggurat:
+You are overcome by a voice, a voice so powerful you are helpless as it speaks:
+(The players who belong to an association can only enter through the Association Leader.) + \ No newline at end of file diff --git a/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31118-04.html b/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31118-04.html new file mode 100644 index 0000000000..1afe14429f --- /dev/null +++ b/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31118-04.html @@ -0,0 +1,3 @@ +Gatekeeper Ziggurat:
+(A command channel members level must be %minlvl% - %maxlvl% to challenge Lilith.) + \ No newline at end of file diff --git a/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31118.html b/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31118.html new file mode 100644 index 0000000000..7e6d8fa1f8 --- /dev/null +++ b/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31118.html @@ -0,0 +1,7 @@ +Gatekeeper Ziggurat:
+A human voice seems to emanate from a shining, blue globe:
+Behold the gateway to the Forbidden Sacred Area! My job is to guard it, and you cannot pass without my permission.
+ + + + \ No newline at end of file diff --git a/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31124.html b/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31124.html new file mode 100644 index 0000000000..0d50e22faf --- /dev/null +++ b/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/31124.html @@ -0,0 +1,5 @@ +Gatekeeper Ziggurat:
+A human voice seems to emanate from a shining, blue globe:
+Behold the gateway to the Forbidden Sacred Area! My job is to guard it, and you cannot pass without my permission.
+ + \ No newline at end of file diff --git a/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/Lilith.java b/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/Lilith.java new file mode 100644 index 0000000000..7926cd997f --- /dev/null +++ b/L2J_Mobius_Underground/dist/game/data/scripts/ai/bosses/Lilith/Lilith.java @@ -0,0 +1,682 @@ +/* + * This file is part of the L2J Mobius project. + * + * 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 3 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 . + */ +package ai.bosses.Lilith; + +import java.util.ArrayList; +import java.util.List; + +import com.l2jmobius.Config; +import com.l2jmobius.commons.util.CommonUtil; +import com.l2jmobius.commons.util.Rnd; +import com.l2jmobius.gameserver.ai.CtrlIntention; +import com.l2jmobius.gameserver.data.xml.impl.SkillData; +import com.l2jmobius.gameserver.instancemanager.GrandBossManager; +import com.l2jmobius.gameserver.instancemanager.MapRegionManager; +import com.l2jmobius.gameserver.instancemanager.ZoneManager; +import com.l2jmobius.gameserver.model.L2Object; +import com.l2jmobius.gameserver.model.L2Party; +import com.l2jmobius.gameserver.model.L2Spawn; +import com.l2jmobius.gameserver.model.Location; +import com.l2jmobius.gameserver.model.StatsSet; +import com.l2jmobius.gameserver.model.TeleportWhereType; +import com.l2jmobius.gameserver.model.actor.L2Attackable; +import com.l2jmobius.gameserver.model.actor.L2Character; +import com.l2jmobius.gameserver.model.actor.L2Npc; +import com.l2jmobius.gameserver.model.actor.instance.L2GrandBossInstance; +import com.l2jmobius.gameserver.model.actor.instance.L2PcInstance; +import com.l2jmobius.gameserver.model.holders.SpawnHolder; +import com.l2jmobius.gameserver.model.quest.QuestTimer; +import com.l2jmobius.gameserver.model.skills.AbnormalType; +import com.l2jmobius.gameserver.model.skills.Skill; +import com.l2jmobius.gameserver.model.zone.L2ZoneType; +import com.l2jmobius.gameserver.network.serverpackets.NpcHtmlMessage; + +import ai.AbstractNpcAI; + +/** + * Lilith AI
+ * @author LasTravel
+ * @URL http://boards.lineage2.com/showpost.php?p=3386784&postcount=6
+ * @video https://www.youtube.com/watch?v=H3MuIwUjjD4 + */ +public class Lilith extends AbstractNpcAI +{ + // Status + private static final int ALIVE = 0; + private static final int WAITING = 1; + private static final int FIGHTING = 2; + private static final int DEAD = 3; + // NPCs + private static final int LILITH = 25283; + private static final int REMNANT = 19490; + private static final int ENTER_CUBIC = 31118; + private static final int EXIST_CUBIC = 31124; + private static final int LILITH_CUBIC = 31110; + //@formatter:off + private static final int[] LILITH_MINIONS = {25284, 25285}; + private static final int[] NECRO_MOBS = {21178, 21179, 21180, 21181, 21182, 21183, 21184, 21185, 21186}; + //@formatter:on + private static final int[] ALL_MOBS = + { + LILITH, + LILITH_MINIONS[0], + LILITH_MINIONS[1], + NECRO_MOBS[0], + NECRO_MOBS[1], + NECRO_MOBS[2], + NECRO_MOBS[3], + NECRO_MOBS[4], + NECRO_MOBS[5], + NECRO_MOBS[6], + NECRO_MOBS[7], + NECRO_MOBS[8], + REMNANT + }; + // Spawns + private static final List SPAWNS = new ArrayList<>(); + static + { + SPAWNS.add(new SpawnHolder(21179, -16469, 13406, -4905, 32815, false)); + SPAWNS.add(new SpawnHolder(21178, -16756, 13397, -4905, 33094, false)); + SPAWNS.add(new SpawnHolder(21182, -16995, 13398, -4905, 32724, false)); + SPAWNS.add(new SpawnHolder(21180, -17261, 13395, -4905, 32885, false)); + SPAWNS.add(new SpawnHolder(21180, -16474, 13678, -4905, 32864, false)); + SPAWNS.add(new SpawnHolder(21181, -16739, 13675, -4905, 32886, false)); + SPAWNS.add(new SpawnHolder(21186, -16991, 13672, -4905, 32892, false)); + SPAWNS.add(new SpawnHolder(21186, -17263, 13675, -4905, 32652, false)); + SPAWNS.add(new SpawnHolder(21180, -15271, 13463, -4905, 16550, false)); + SPAWNS.add(new SpawnHolder(21178, -15273, 13750, -4905, 16456, false)); + SPAWNS.add(new SpawnHolder(21185, -15275, 13998, -4905, 16468, false)); + SPAWNS.add(new SpawnHolder(21186, -15279, 14256, -4905, 16545, false)); + SPAWNS.add(new SpawnHolder(21183, -15604, 13454, -4905, 16662, false)); + SPAWNS.add(new SpawnHolder(21183, -15608, 13738, -4905, 16530, false)); + SPAWNS.add(new SpawnHolder(21185, -15597, 14014, -4905, 15968, false)); + SPAWNS.add(new SpawnHolder(21180, -15599, 14258, -4905, 16469, false)); + SPAWNS.add(new SpawnHolder(21185, -14242, 13505, -4903, 65400, false)); + SPAWNS.add(new SpawnHolder(21181, -14720, 13505, -4903, 32767, false)); + SPAWNS.add(new SpawnHolder(21183, -14477, 13321, -4903, 49151, false)); + SPAWNS.add(new SpawnHolder(21182, -14480, 13500, -4903, 18259, false)); + SPAWNS.add(new SpawnHolder(21183, -14482, 13734, -4903, 16473, false)); + SPAWNS.add(new SpawnHolder(21184, -13146, 13508, -4903, 42, false)); + SPAWNS.add(new SpawnHolder(21179, -13625, 13506, -4903, 32426, false)); + SPAWNS.add(new SpawnHolder(21179, -13390, 13261, -4903, 48922, false)); + SPAWNS.add(new SpawnHolder(21181, -13390, 13752, -4903, 15915, false)); + SPAWNS.add(new SpawnHolder(21185, -13379, 13508, -4903, 49621, false)); + SPAWNS.add(new SpawnHolder(21178, -13422, 15555, -4905, 65425, false)); + SPAWNS.add(new SpawnHolder(21186, -13152, 15548, -4905, 65265, false)); + SPAWNS.add(new SpawnHolder(21186, -12894, 15544, -4905, 65374, false)); + SPAWNS.add(new SpawnHolder(21186, -12614, 15540, -4905, 65387, false)); + SPAWNS.add(new SpawnHolder(21185, -13404, 15224, -4905, 65263, false)); + SPAWNS.add(new SpawnHolder(21181, -13156, 15224, -4905, 0, false)); + SPAWNS.add(new SpawnHolder(21179, -12896, 15223, -4905, 65495, false)); + SPAWNS.add(new SpawnHolder(21184, -12624, 15220, -4905, 1401, false)); + SPAWNS.add(new SpawnHolder(21186, -11492, 15690, -4905, 48932, false)); + SPAWNS.add(new SpawnHolder(21179, -11488, 15432, -4905, 49313, false)); + SPAWNS.add(new SpawnHolder(21178, -11490, 15132, -4905, 49082, false)); + SPAWNS.add(new SpawnHolder(21185, -11497, 14893, -4905, 48846, false)); + SPAWNS.add(new SpawnHolder(21182, -11485, 14647, -4905, 49660, false)); + SPAWNS.add(new SpawnHolder(21185, -11476, 14397, -4905, 49527, false)); + SPAWNS.add(new SpawnHolder(21182, -11079, 15682, -4905, 49406, false)); + SPAWNS.add(new SpawnHolder(21186, -11076, 15417, -4905, 49270, false)); + SPAWNS.add(new SpawnHolder(21184, -11079, 15152, -4905, 49033, false)); + SPAWNS.add(new SpawnHolder(21181, -11077, 14912, -4905, 49238, false)); + SPAWNS.add(new SpawnHolder(21184, -11075, 14670, -4905, 49238, false)); + SPAWNS.add(new SpawnHolder(21180, -11073, 14347, -4905, 49707, false)); + SPAWNS.add(new SpawnHolder(21186, -8787, 13273, -4903, 49053, false)); + SPAWNS.add(new SpawnHolder(21178, -8785, 13753, -4903, 16351, false)); + SPAWNS.add(new SpawnHolder(21182, -9026, 13498, -4903, 33142, false)); + SPAWNS.add(new SpawnHolder(21184, -8520, 13506, -4903, 151, false)); + SPAWNS.add(new SpawnHolder(21182, -8784, 13501, -4903, 33079, false)); + SPAWNS.add(new SpawnHolder(21179, -13393, 18350, -4903, 16498, false)); + SPAWNS.add(new SpawnHolder(21181, -13389, 17881, -4903, 49681, false)); + SPAWNS.add(new SpawnHolder(21180, -13635, 18105, -4903, 33289, false)); + SPAWNS.add(new SpawnHolder(21184, -13397, 18111, -4903, 0, false)); + SPAWNS.add(new SpawnHolder(21186, -13062, 18115, -4903, 64741, false)); + SPAWNS.add(new SpawnHolder(21179, -12597, 18131, -4905, 49273, false)); + SPAWNS.add(new SpawnHolder(21182, -12593, 17897, -4905, 49330, false)); + SPAWNS.add(new SpawnHolder(21180, -12594, 17606, -4905, 49116, false)); + SPAWNS.add(new SpawnHolder(21180, -12595, 17367, -4905, 49108, false)); + SPAWNS.add(new SpawnHolder(21182, -12269, 18143, -4905, 48851, false)); + SPAWNS.add(new SpawnHolder(21180, -12270, 17872, -4905, 49113, false)); + SPAWNS.add(new SpawnHolder(21183, -12274, 17612, -4905, 48991, false)); + SPAWNS.add(new SpawnHolder(21183, -12279, 17337, -4905, 51622, false)); + SPAWNS.add(new SpawnHolder(21185, -13395, 19509, -4903, 17094, false)); + SPAWNS.add(new SpawnHolder(21180, -13388, 18895, -4903, 49301, false)); + SPAWNS.add(new SpawnHolder(21184, -13114, 19198, -4903, 65211, false)); + SPAWNS.add(new SpawnHolder(21182, -13383, 19196, -4903, 32845, false)); + SPAWNS.add(new SpawnHolder(21181, -13711, 19197, -4903, 32519, false)); + SPAWNS.add(new SpawnHolder(21181, -14781, 19199, -4903, 33074, false)); + SPAWNS.add(new SpawnHolder(21183, -14188, 19205, -4903, 867, false)); + SPAWNS.add(new SpawnHolder(21181, -14495, 19193, -4903, 32351, false)); + SPAWNS.add(new SpawnHolder(21180, -14481, 19503, -4903, 15913, false)); + SPAWNS.add(new SpawnHolder(21178, -14475, 18881, -4903, 49151, false)); + SPAWNS.add(new SpawnHolder(21183, -14477, 17797, -4903, 49700, false)); + SPAWNS.add(new SpawnHolder(21181, -14481, 18417, -4903, 16947, false)); + SPAWNS.add(new SpawnHolder(21185, -14178, 18110, -4903, 66, false)); + SPAWNS.add(new SpawnHolder(21181, -14476, 18110, -4903, 32767, false)); + SPAWNS.add(new SpawnHolder(21186, -14793, 18109, -4903, 32800, false)); + SPAWNS.add(new SpawnHolder(21182, -16404, 15929, -4905, 15862, false)); + SPAWNS.add(new SpawnHolder(21178, -16401, 16194, -4905, 16265, false)); + SPAWNS.add(new SpawnHolder(21185, -16402, 16472, -4905, 16421, false)); + SPAWNS.add(new SpawnHolder(21184, -16405, 16721, -4905, 16509, false)); + SPAWNS.add(new SpawnHolder(21185, -16409, 16966, -4905, 16554, false)); + SPAWNS.add(new SpawnHolder(21185, -16415, 17223, -4905, 16627, false)); + SPAWNS.add(new SpawnHolder(21180, -16794, 15936, -4905, 16009, false)); + SPAWNS.add(new SpawnHolder(21182, -16786, 16208, -4905, 16077, false)); + SPAWNS.add(new SpawnHolder(21182, -16775, 16485, -4905, 15970, false)); + SPAWNS.add(new SpawnHolder(21180, -16781, 16725, -4905, 16644, false)); + SPAWNS.add(new SpawnHolder(21180, -16774, 17008, -4905, 16126, false)); + SPAWNS.add(new SpawnHolder(21184, -16773, 17266, -4905, 16343, false)); + SPAWNS.add(new SpawnHolder(21186, -19088, 18401, -4903, 16653, false)); + SPAWNS.add(new SpawnHolder(21182, -19089, 17842, -4903, 49586, false)); + SPAWNS.add(new SpawnHolder(21186, -19339, 18108, -4903, 32845, false)); + SPAWNS.add(new SpawnHolder(21183, -19092, 18111, -4903, 62852, false)); + SPAWNS.add(new SpawnHolder(21179, -18810, 18106, -4903, 65351, false)); + SPAWNS.add(new SpawnHolder(21183, -19085, 19523, -4903, 16324, false)); + SPAWNS.add(new SpawnHolder(21180, -19086, 18927, -4903, 49134, false)); + SPAWNS.add(new SpawnHolder(21183, -18789, 19197, -4903, 65226, false)); + SPAWNS.add(new SpawnHolder(21183, -19078, 19200, -4903, 32659, false)); + SPAWNS.add(new SpawnHolder(21178, -19367, 19195, -4903, 32767, false)); + SPAWNS.add(new SpawnHolder(21183, -16217, 19163, -4905, 15989, false)); + SPAWNS.add(new SpawnHolder(21184, -16208, 19432, -4905, 15967, false)); + SPAWNS.add(new SpawnHolder(21184, -16208, 19683, -4905, 16383, false)); + SPAWNS.add(new SpawnHolder(21186, -16207, 19949, -4905, 16344, false)); + SPAWNS.add(new SpawnHolder(21180, -16532, 19180, -4905, 16218, false)); + SPAWNS.add(new SpawnHolder(21178, -16531, 19459, -4905, 16346, false)); + SPAWNS.add(new SpawnHolder(21181, -16531, 19704, -4905, 16383, false)); + SPAWNS.add(new SpawnHolder(21186, -16525, 19943, -4905, 16122, false)); + SPAWNS.add(new SpawnHolder(21179, -19123, 19994, -4905, 0, false)); + SPAWNS.add(new SpawnHolder(21179, -18858, 19996, -4905, 78, false)); + SPAWNS.add(new SpawnHolder(21179, -18608, 19996, -4905, 0, false)); + SPAWNS.add(new SpawnHolder(21180, -18326, 19999, -4905, 110, false)); + SPAWNS.add(new SpawnHolder(21179, -19088, 20318, -4905, 175, false)); + SPAWNS.add(new SpawnHolder(21179, -18842, 20318, -4905, 0, false)); + SPAWNS.add(new SpawnHolder(21178, -18579, 20318, -4905, 0, false)); + SPAWNS.add(new SpawnHolder(21184, -18313, 20320, -4905, 78, false)); + SPAWNS.add(new SpawnHolder(21179, -18920, 21182, -4905, 15992, false)); + SPAWNS.add(new SpawnHolder(21184, -18918, 21455, -4905, 16307, false)); + SPAWNS.add(new SpawnHolder(21180, -18930, 21719, -4905, 16857, false)); + SPAWNS.add(new SpawnHolder(21186, -18937, 21972, -4905, 16672, false)); + SPAWNS.add(new SpawnHolder(21183, -19239, 21188, -4905, 16562, false)); + SPAWNS.add(new SpawnHolder(21183, -19244, 21447, -4905, 16585, false)); + SPAWNS.add(new SpawnHolder(21186, -19245, 21729, -4905, 16420, false)); + SPAWNS.add(new SpawnHolder(21182, -19240, 21994, -4905, 18219, false)); + SPAWNS.add(new SpawnHolder(21181, -17843, 23849, -4905, 49203, false)); + SPAWNS.add(new SpawnHolder(21181, -17842, 23583, -4905, 49191, false)); + SPAWNS.add(new SpawnHolder(21184, -17843, 23310, -4905, 49113, false)); + SPAWNS.add(new SpawnHolder(21186, -17842, 23055, -4905, 49192, false)); + SPAWNS.add(new SpawnHolder(21186, -17522, 23833, -4905, 48646, false)); + SPAWNS.add(new SpawnHolder(21183, -17526, 23552, -4905, 49003, false)); + SPAWNS.add(new SpawnHolder(21178, -17532, 23281, -4905, 48921, false)); + SPAWNS.add(new SpawnHolder(21178, -17526, 23019, -4905, 49390, false)); + SPAWNS.add(new SpawnHolder(21183, -19079, 24048, -4903, 16704, false)); + SPAWNS.add(new SpawnHolder(21185, -19090, 23519, -4903, 49362, false)); + SPAWNS.add(new SpawnHolder(21185, -19356, 23804, -4903, 32408, false)); + SPAWNS.add(new SpawnHolder(21182, -19093, 23808, -4903, 65106, false)); + SPAWNS.add(new SpawnHolder(21185, -18777, 23810, -4903, 347, false)); + SPAWNS.add(new SpawnHolder(21180, -14131, 23807, -4903, 64686, false)); + SPAWNS.add(new SpawnHolder(21179, -14769, 23804, -4903, 34020, false)); + SPAWNS.add(new SpawnHolder(21183, -14479, 23507, -4903, 50019, false)); + SPAWNS.add(new SpawnHolder(21178, -14479, 23799, -4903, 16383, false)); + SPAWNS.add(new SpawnHolder(21184, -14471, 24087, -4903, 15031, false)); + SPAWNS.add(new SpawnHolder(21178, -13060, 23806, -4903, 108, false)); + SPAWNS.add(new SpawnHolder(21181, -13392, 23807, -4903, 30946, false)); + SPAWNS.add(new SpawnHolder(21186, -13691, 23807, -4903, 32767, false)); + SPAWNS.add(new SpawnHolder(21179, -13393, 24098, -4903, 15393, false)); + SPAWNS.add(new SpawnHolder(21179, -13390, 23480, -4903, 47204, false)); + SPAWNS.add(new SpawnHolder(21178, -12589, 23863, -4905, 48374, false)); + SPAWNS.add(new SpawnHolder(21183, -12591, 23560, -4905, 49083, false)); + SPAWNS.add(new SpawnHolder(21181, -12578, 23295, -4905, 49663, false)); + SPAWNS.add(new SpawnHolder(21182, -12582, 23026, -4905, 48996, false)); + SPAWNS.add(new SpawnHolder(21183, -12268, 23817, -4905, 49887, false)); + SPAWNS.add(new SpawnHolder(21185, -12270, 23573, -4905, 49066, false)); + SPAWNS.add(new SpawnHolder(21186, -12277, 23280, -4905, 48902, false)); + SPAWNS.add(new SpawnHolder(21184, -12272, 23061, -4905, 49390, false)); + SPAWNS.add(new SpawnHolder(21186, -11412, 23638, -4905, 65163, false)); + SPAWNS.add(new SpawnHolder(21180, -11156, 23641, -4905, 122, false)); + SPAWNS.add(new SpawnHolder(21184, -10897, 23653, -4905, 482, false)); + SPAWNS.add(new SpawnHolder(21180, -10636, 23651, -4905, 65456, false)); + SPAWNS.add(new SpawnHolder(21180, -11386, 23958, -4905, 529, false)); + SPAWNS.add(new SpawnHolder(21179, -11126, 23964, -4905, 240, false)); + SPAWNS.add(new SpawnHolder(21180, -10857, 23968, -4905, 155, false)); + SPAWNS.add(new SpawnHolder(21178, -10608, 23966, -4905, 65452, false)); + SPAWNS.add(new SpawnHolder(21183, -8540, 23806, -4903, 65438, false)); + SPAWNS.add(new SpawnHolder(21180, -9103, 23804, -4903, 32907, false)); + SPAWNS.add(new SpawnHolder(21186, -8790, 24102, -4903, 16731, false)); + SPAWNS.add(new SpawnHolder(21180, -8774, 23809, -4903, 50950, false)); + SPAWNS.add(new SpawnHolder(21180, -8784, 23493, -4903, 47854, false)); + SPAWNS.add(new SpawnHolder(21180, -8758, 22562, -4905, 32767, false)); + SPAWNS.add(new SpawnHolder(21182, -9037, 22562, -4905, 32767, false)); + SPAWNS.add(new SpawnHolder(21183, -9297, 22554, -4905, 32012, false)); + SPAWNS.add(new SpawnHolder(21183, -9536, 22554, -4905, 32767, false)); + SPAWNS.add(new SpawnHolder(21180, -8761, 22246, -4905, 32767, false)); + SPAWNS.add(new SpawnHolder(21182, -9007, 22247, -4905, 32725, false)); + SPAWNS.add(new SpawnHolder(21181, -9275, 22240, -4905, 33040, false)); + SPAWNS.add(new SpawnHolder(21183, -9545, 22231, -4905, 33115, false)); + SPAWNS.add(new SpawnHolder(21183, -8787, 18829, -4903, 49288, false)); + SPAWNS.add(new SpawnHolder(21184, -8785, 19512, -4903, 17015, false)); + SPAWNS.add(new SpawnHolder(21178, -8516, 19196, -4903, 147, false)); + SPAWNS.add(new SpawnHolder(21180, -8774, 19194, -4903, 32465, false)); + SPAWNS.add(new SpawnHolder(21180, -9151, 19200, -4903, 33236, false)); + SPAWNS.add(new SpawnHolder(21184, -8781, 17784, -4903, 49334, false)); + SPAWNS.add(new SpawnHolder(21183, -8778, 18444, -4903, 16507, false)); + SPAWNS.add(new SpawnHolder(21183, -8527, 18116, -4903, 65299, false)); + SPAWNS.add(new SpawnHolder(21183, -8784, 18110, -4903, 32767, false)); + SPAWNS.add(new SpawnHolder(21184, -9116, 18107, -4903, 32862, false)); + SPAWNS.add(new SpawnHolder(21180, -8775, 16859, -4905, 33548, false)); + SPAWNS.add(new SpawnHolder(21186, -9021, 16865, -4905, 32513, false)); + SPAWNS.add(new SpawnHolder(21185, -9288, 16862, -4905, 33196, false)); + SPAWNS.add(new SpawnHolder(21179, -9547, 16871, -4905, 32405, false)); + SPAWNS.add(new SpawnHolder(21185, -8760, 16543, -4905, 32517, false)); + SPAWNS.add(new SpawnHolder(21180, -9068, 16540, -4905, 32869, false)); + SPAWNS.add(new SpawnHolder(21183, -9305, 16548, -4905, 32416, false)); + SPAWNS.add(new SpawnHolder(21181, -9581, 16562, -4905, 32239, false)); + SPAWNS.add(new SpawnHolder(21180, -11386, 17976, -4905, 64074, false)); + SPAWNS.add(new SpawnHolder(21181, -11129, 17977, -4905, 40, false)); + SPAWNS.add(new SpawnHolder(21183, -10864, 17977, -4905, 0, false)); + SPAWNS.add(new SpawnHolder(21181, -10610, 17973, -4905, 65371, false)); + SPAWNS.add(new SpawnHolder(21184, -11383, 18238, -4905, 481, false)); + SPAWNS.add(new SpawnHolder(21181, -11129, 18248, -4905, 410, false)); + SPAWNS.add(new SpawnHolder(21179, -10861, 18255, -4905, 142, false)); + SPAWNS.add(new SpawnHolder(21183, -10629, 18264, -4905, 436, false)); + SPAWNS.add(new SpawnHolder(21186, -11468, 21371, -4905, 49558, false)); + SPAWNS.add(new SpawnHolder(21185, -11475, 21103, -4905, 48879, false)); + SPAWNS.add(new SpawnHolder(21180, -11466, 20854, -4905, 49528, false)); + SPAWNS.add(new SpawnHolder(21185, -11468, 20567, -4905, 49079, false)); + SPAWNS.add(new SpawnHolder(21185, -11462, 20304, -4905, 49389, false)); + SPAWNS.add(new SpawnHolder(21183, -11446, 20056, -4905, 49823, false)); + SPAWNS.add(new SpawnHolder(21182, -11081, 21367, -4905, 48668, false)); + SPAWNS.add(new SpawnHolder(21183, -11094, 21069, -4905, 48697, false)); + SPAWNS.add(new SpawnHolder(21181, -11088, 20812, -4905, 49395, false)); + SPAWNS.add(new SpawnHolder(21185, -11081, 20553, -4905, 49433, false)); + SPAWNS.add(new SpawnHolder(21178, -11087, 20281, -4905, 48921, false)); + SPAWNS.add(new SpawnHolder(21178, -11077, 20010, -4905, 49536, false)); + SPAWNS.add(new SpawnHolder(21183, -13405, 20920, -4905, 64568, false)); + SPAWNS.add(new SpawnHolder(21181, -13146, 20928, -4905, 322, false)); + SPAWNS.add(new SpawnHolder(21178, -12901, 20923, -4905, 65323, false)); + SPAWNS.add(new SpawnHolder(21184, -12637, 20927, -4905, 158, false)); + SPAWNS.add(new SpawnHolder(21185, -13437, 21244, -4905, 47, false)); + SPAWNS.add(new SpawnHolder(21183, -13125, 21245, -4905, 33, false)); + SPAWNS.add(new SpawnHolder(21178, -12876, 21257, -4905, 502, false)); + SPAWNS.add(new SpawnHolder(21183, -12647, 21242, -4905, 64853, false)); + SPAWNS.add(new SpawnHolder(21183, -16669, 21115, -4905, 496, false)); + SPAWNS.add(new SpawnHolder(21179, -16395, 21117, -4905, 76, false)); + SPAWNS.add(new SpawnHolder(21182, -16106, 21119, -4905, 72, false)); + SPAWNS.add(new SpawnHolder(21179, -15871, 21117, -4905, 65447, false)); + SPAWNS.add(new SpawnHolder(21181, -15595, 21120, -4905, 113, false)); + SPAWNS.add(new SpawnHolder(21183, -15317, 21135, -4905, 562, false)); + SPAWNS.add(new SpawnHolder(21186, -16649, 21512, -4905, 635, false)); + SPAWNS.add(new SpawnHolder(21185, -16403, 21506, -4905, 65281, false)); + SPAWNS.add(new SpawnHolder(21179, -16124, 21500, -4905, 65311, false)); + SPAWNS.add(new SpawnHolder(21185, -15846, 21499, -4905, 64349, false)); + SPAWNS.add(new SpawnHolder(21182, -15591, 21510, -4905, 449, false)); + SPAWNS.add(new SpawnHolder(21184, -15331, 21510, -4905, 0, false)); + SPAWNS.add(new SpawnHolder(21186, -19128, 14749, -4905, 65123, false)); + SPAWNS.add(new SpawnHolder(21185, -18842, 14750, -4905, 36, false)); + SPAWNS.add(new SpawnHolder(21181, -18584, 14748, -4905, 65455, false)); + SPAWNS.add(new SpawnHolder(21180, -18321, 14746, -4905, 65456, false)); + SPAWNS.add(new SpawnHolder(21185, -19101, 15060, -4905, 65437, false)); + SPAWNS.add(new SpawnHolder(21184, -18821, 15071, -4905, 409, false)); + SPAWNS.add(new SpawnHolder(21184, -18583, 15069, -4905, 65448, false)); + SPAWNS.add(new SpawnHolder(21183, -18303, 15070, -4905, 37, false)); + SPAWNS.add(new SpawnHolder(21186, -14450, 16357, -4905, 32120, false)); + SPAWNS.add(new SpawnHolder(21184, -14736, 16367, -4905, 32403, false)); + SPAWNS.add(new SpawnHolder(21178, -14975, 16370, -4905, 32637, false)); + SPAWNS.add(new SpawnHolder(21184, -15234, 16378, -4905, 32445, false)); + SPAWNS.add(new SpawnHolder(21186, -14424, 16069, -4905, 33302, false)); + SPAWNS.add(new SpawnHolder(21178, -14706, 16066, -4905, 32878, false)); + SPAWNS.add(new SpawnHolder(21183, -14996, 16061, -4905, 32947, false)); + SPAWNS.add(new SpawnHolder(21184, -15242, 16055, -4905, 33022, false)); + } + // Skill + private static final Skill REMANT_TELE = SkillData.getInstance().getSkill(23303, 1); + // Misc + private static final Location ENTER_LOC = new Location(-19361, 13504, -4906); + private static final Location ENTER_LILITH_LOC = new Location(184449, -9032, -5499); + private static final L2ZoneType BOSS_ZONE = ZoneManager.getInstance().getZoneById(12005); + private static final L2ZoneType PRE_LILITH_ZONE = ZoneManager.getInstance().getZoneById(12006); + // Others + private static List _spawns = new ArrayList<>(); + private static List _remnants = new ArrayList<>(); + private static long _lastAction; + private static L2Npc _lilithBoss; + + public Lilith() + { + addTalkId(ENTER_CUBIC, EXIST_CUBIC, LILITH_CUBIC); + addStartNpc(ENTER_CUBIC, EXIST_CUBIC, LILITH_CUBIC); + addFirstTalkId(ENTER_CUBIC, EXIST_CUBIC, LILITH_CUBIC); + addSpellFinishedId(REMNANT); + addAttackId(ALL_MOBS); + addKillId(ALL_MOBS); + addSkillSeeId(ALL_MOBS); + + // Unlock + final StatsSet info = GrandBossManager.getInstance().getStatsSet(LILITH); + final long time = info.getLong("respawn_time") - System.currentTimeMillis(); + if (time > 0) + { + startQuestTimer("unlock_lilith", time, null, null); + } + } + + @Override + public String onAdvEvent(String event, L2Npc npc, L2PcInstance player) + { + switch (event) + { + case "unlock_lilith": + { + GrandBossManager.getInstance().setBossStatus(LILITH, ALIVE); + break; + } + case "check_activity_task": + { + if ((_lastAction + 900000) < System.currentTimeMillis()) + { + GrandBossManager.getInstance().setBossStatus(LILITH, ALIVE); + for (L2Character charInside : BOSS_ZONE.getCharactersInside()) + { + if (charInside != null) + { + if (charInside.isNpc()) + { + charInside.deleteMe(); + } + else if (charInside.isPlayer()) + { + charInside.teleToLocation(MapRegionManager.getInstance().getTeleToLocation(charInside, TeleportWhereType.TOWN)); + } + } + } + startQuestTimer("end_lilith", 2000, null, null); + } + else + { + startQuestTimer("check_activity_task", 60000, null, null); + } + break; + } + case "spawn_remant": + { + L2Npc randomSpawn = null; + if (npc == null) + { + for (int i = 0; i < 2; i++) + { + randomSpawn = _spawns.get(Rnd.get(_spawns.size())); + if (randomSpawn != null) + { + L2Npc remnant = addSpawn(REMNANT, randomSpawn.getX(), randomSpawn.getY(), randomSpawn.getZ(), randomSpawn.getHeading(), true, 0, false, 0); + _remnants.add(remnant); + } + } + } + else + { + randomSpawn = _spawns.get(Rnd.get(_spawns.size())); + if (randomSpawn != null) + { + npc.teleToLocation(randomSpawn.getX(), randomSpawn.getY(), randomSpawn.getZ()); + _spawns.add(npc); + } + } + break; + } + case "cancel_timers": + { + QuestTimer activityTimer = getQuestTimer("check_activity_task", null, null); + if (activityTimer != null) + { + activityTimer.cancel(); + } + + QuestTimer forceEnd = getQuestTimer("end_lilith", null, null); + if (forceEnd != null) + { + forceEnd.cancel(); + } + break; + } + case "end_lilith": + { + notifyEvent("cancel_timers", null, null); + if (_lilithBoss != null) + { + _lilithBoss.deleteMe(); + } + BOSS_ZONE.oustAllPlayers(); + PRE_LILITH_ZONE.oustAllPlayers(); + for (L2Npc spawn : _spawns) + { + if (spawn != null) + { + spawn.deleteMe(); + } + } + _spawns.clear(); + for (L2Npc remnant : _remnants) + { + if (remnant == null) + { + continue; + } + remnant.deleteMe(); + } + if (GrandBossManager.getInstance().getBossStatus(LILITH) != DEAD) + { + GrandBossManager.getInstance().setBossStatus(LILITH, ALIVE); + } + break; + } + case "exist": + { + player.teleToLocation(TeleportWhereType.TOWN); + break; + } + } + return super.onAdvEvent(event, npc, player); + } + + @Override + public String onTalk(L2Npc npc, L2PcInstance player) + { + if ((npc.getId() == ENTER_CUBIC) || (npc.getId() == LILITH_CUBIC)) + { + int _lilithStatus = GrandBossManager.getInstance().getBossStatus(LILITH); + if ((npc.getId() == ENTER_CUBIC) && (_lilithStatus > ALIVE)) + { + return "31118-01.html"; + } + if (!player.isInParty()) + { + final NpcHtmlMessage packet = new NpcHtmlMessage(npc.getObjectId()); + packet.setHtml(getHtm(player.getHtmlPrefix(), "31118-02.html")); + packet.replace("%min%", Integer.toString(Config.LILITH_MIN_PLAYERS)); + player.sendPacket(packet); + return null; + } + final L2Party party = player.getParty(); + final boolean isInCC = party.isInCommandChannel(); + final List members = (isInCC) ? party.getCommandChannel().getMembers() : party.getMembers(); + final boolean isPartyLeader = (isInCC) ? party.getCommandChannel().isLeader(player) : party.isLeader(player); + if (!isPartyLeader) + { + return "31118-03.html"; + } + else if ((((L2Character) members).getParty().getLevel() < Config.LILITH_MIN_PLAYER_LVL) || (((L2Character) members).getParty().getLevel() > Config.LILITH_MAX_PLAYER_LVL)) + { + final NpcHtmlMessage packet = new NpcHtmlMessage(npc.getObjectId()); + packet.setHtml(getHtm(player.getHtmlPrefix(), "31118-04.html")); + packet.replace("%minlvl%", Integer.toString(Config.LILITH_MIN_PLAYER_LVL)); + packet.replace("%maxlvl%", Integer.toString(Config.LILITH_MAX_PLAYER_LVL)); + player.sendPacket(packet); + return null; + } + else if ((members.size() < Config.LILITH_MIN_PLAYERS) || (members.size() > Config.LILITH_MAX_PLAYERS)) + { + final NpcHtmlMessage packet = new NpcHtmlMessage(npc.getObjectId()); + packet.setHtml(getHtm(player.getHtmlPrefix(), "31118-02.html")); + packet.replace("%min%", Integer.toString(Config.LILITH_MIN_PLAYERS)); + player.sendPacket(packet); + return null; + } + else + { + for (L2PcInstance member : members) + { + if (member.isInsideRadius(npc, 1000, true, false) && (npc.getId() == ENTER_CUBIC)) + { + member.teleToLocation(ENTER_LOC, true); + } + else if (member.isInsideRadius(npc, 1000, true, false) && (npc.getId() == LILITH_CUBIC)) + { + member.teleToLocation(ENTER_LILITH_LOC, true); + } + } + } + if ((_lilithStatus == ALIVE) && (npc.getId() == ENTER_CUBIC)) + { + GrandBossManager.getInstance().setBossStatus(LILITH, WAITING); + _spawns.clear(); + for (SpawnHolder spawn : SPAWNS) + { + _spawns.add(addSpawn(spawn.getNpcId(), spawn.getLocation())); + } + _remnants.clear(); + notifyEvent("spawn_remant", null, null); + _lastAction = System.currentTimeMillis(); + startQuestTimer("check_activity_task", 60000, null, null, true); + } + else if ((_lilithStatus == WAITING) && (npc.getId() == LILITH_CUBIC)) + { + GrandBossManager.getInstance().setBossStatus(LILITH, FIGHTING); + // Spawn the rb + _lilithBoss = addSpawn(LILITH, 185062, -9605, -5499, 15640, false, 0); + GrandBossManager.getInstance().addBoss((L2GrandBossInstance) _lilithBoss); + startQuestTimer("end_lilith", 60 * 60000, null, null); // 1h + } + } + return super.onTalk(npc, player); + } + + @Override + public String onAttack(L2Npc npc, L2PcInstance attacker, int damage, boolean isPet) + { + _lastAction = System.currentTimeMillis(); + if (npc.isMinion() || npc.isRaid()) // Lilith and minions + { + // Anti BUGGERS + if (!BOSS_ZONE.isInsideZone(attacker)) // Character attacking out of zone + { + attacker.doDie(null); + } + if (!BOSS_ZONE.isInsideZone(npc)) // Npc moved out of the zone + { + L2Spawn spawn = npc.getSpawn(); + if (spawn != null) + { + npc.teleToLocation(spawn.getX(), spawn.getY(), spawn.getZ()); + } + } + } + if (npc.getId() == REMNANT) + { + if (npc.getCurrentHp() < (npc.getMaxHp() * 0.30)) + { + if (!npc.isCastingNow() && (Rnd.get(100) > 95)) + { + npc.doCast(REMANT_TELE); + } + } + } + + return super.onAttack(npc, attacker, damage, isPet); + } + + @Override + public String onKill(L2Npc npc, L2PcInstance killer, boolean isPet) + { + if (npc.getId() == LILITH) + { + notifyEvent("cancel_timers", null, null); + addSpawn(EXIST_CUBIC, 185062, -9605, -5499, 15640, false, 900000); // 15min + + GrandBossManager.getInstance().setBossStatus(LILITH, DEAD); + // TODO Retail Raid Respawn time: Thursday (21:00) and Saturday (14:00). + final long respawnTime = (Config.LILITH_SPAWN_INTERVAL + getRandom(-Config.LILITH_SPAWN_RANDOM, Config.LILITH_SPAWN_RANDOM)) * 3600000; + final StatsSet info = GrandBossManager.getInstance().getStatsSet(LILITH); + info.set("respawn_time", System.currentTimeMillis() + respawnTime); + GrandBossManager.getInstance().setStatsSet(LILITH, info); + + startQuestTimer("unlock_lilith", respawnTime, null, null); + startQuestTimer("end_lilith", 900000, null, null); + } + else if (npc.getId() == REMNANT) + { + _remnants.remove(npc); + if (_remnants.isEmpty()) + { + addSpawn(LILITH_CUBIC, -19410, 23805, -4903, 62917, false, 60 * 60000, false, 0); + } + } + return super.onKill(npc, killer, isPet); + } + + @Override + public String onSpellFinished(L2Npc npc, L2PcInstance player, Skill skill) + { + if ((npc.getId() == REMNANT) && PRE_LILITH_ZONE.isInsideZone(npc)) + { + if (skill == REMANT_TELE) + { + notifyEvent("spawn_remant", npc, null); + } + } + return super.onSpellFinished(npc, player, skill); + } + + @Override + public String onSkillSee(L2Npc npc, L2PcInstance caster, Skill skill, L2Object[] targets, boolean isPet) + { + if (CommonUtil.contains(LILITH_MINIONS, npc.getId()) && (Rnd.get(2) == 1)) + { + if (skill.getAbnormalType() == AbnormalType.HP_RECOVER) + { + if (!npc.isCastingNow() && (npc.getTarget() != npc) && (npc.getTarget() != caster) && (npc.getTarget() != _lilithBoss)) + { + ((L2Attackable) npc).clearAggroList(); + npc.setTarget(caster); + ((L2Attackable) npc).addDamageHate(caster, 500, 99999); + npc.getAI().setIntention(CtrlIntention.AI_INTENTION_ATTACK, caster); + } + } + } + return super.onSkillSee(npc, caster, skill, targets, isPet); + } + + @Override + public String onFirstTalk(L2Npc npc, L2PcInstance player) + { + return npc.getId() + ".html"; + } + + public static void main(String[] args) + { + new Lilith(); + } +} \ No newline at end of file diff --git a/L2J_Mobius_Underground/dist/game/data/spawns/DarkElf/CatacombOfDarkOmens.xml b/L2J_Mobius_Underground/dist/game/data/spawns/DarkElf/CatacombOfDarkOmens.xml new file mode 100644 index 0000000000..143f4a088e --- /dev/null +++ b/L2J_Mobius_Underground/dist/game/data/spawns/DarkElf/CatacombOfDarkOmens.xml @@ -0,0 +1,9 @@ + + + + + + + + + \ No newline at end of file diff --git a/L2J_Mobius_Underground/dist/game/data/stats/npcs/25200-25299.xml b/L2J_Mobius_Underground/dist/game/data/stats/npcs/25200-25299.xml index e931c26337..a985669cca 100644 --- a/L2J_Mobius_Underground/dist/game/data/stats/npcs/25200-25299.xml +++ b/L2J_Mobius_Underground/dist/game/data/stats/npcs/25200-25299.xml @@ -3825,12 +3825,12 @@ - + - - + + @@ -3840,9 +3840,9 @@ FEMALE - - - + + + @@ -3887,16 +3887,12 @@ - - - - @@ -3908,11 +3904,6 @@ - - - - - @@ -3928,6 +3919,9 @@ + + + diff --git a/L2J_Mobius_Underground/dist/game/data/zones/custom_script.xml b/L2J_Mobius_Underground/dist/game/data/zones/custom_script.xml index 5ade5b6930..92b043acb8 100644 --- a/L2J_Mobius_Underground/dist/game/data/zones/custom_script.xml +++ b/L2J_Mobius_Underground/dist/game/data/zones/custom_script.xml @@ -789,4 +789,16 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/L2J_Mobius_Underground/java/com/l2jmobius/Config.java b/L2J_Mobius_Underground/java/com/l2jmobius/Config.java index aac88fa2a1..eddd5281a4 100644 --- a/L2J_Mobius_Underground/java/com/l2jmobius/Config.java +++ b/L2J_Mobius_Underground/java/com/l2jmobius/Config.java @@ -995,6 +995,7 @@ public final class Config public static int KELBIM_MAX_PLAYERS; public static int KELBIM_SPAWN_INTERVAL; public static int KELBIM_SPAWN_RANDOM; + // Anakim public static int ANAKIM_MIN_PLAYERS; public static int ANAKIM_MAX_PLAYERS; @@ -1003,6 +1004,14 @@ public final class Config public static int ANAKIM_MIN_PLAYER_LVL; public static int ANAKIM_MAX_PLAYER_LVL; + // Lilith + public static int LILITH_MIN_PLAYERS; + public static int LILITH_MAX_PLAYERS; + public static int LILITH_SPAWN_INTERVAL; + public static int LILITH_SPAWN_RANDOM; + public static int LILITH_MIN_PLAYER_LVL; + public static int LILITH_MAX_PLAYER_LVL; + // Gracia Seeds Settings public static int SOD_TIAT_KILL_COUNT; public static long SOD_STAGE_2_LENGTH; @@ -2407,6 +2416,13 @@ public final class Config ANAKIM_MIN_PLAYER_LVL = GrandBossSettings.getInt("AnakimMinPlayerLvl", 90); ANAKIM_MAX_PLAYER_LVL = GrandBossSettings.getInt("AnakimMaxPlayerLvl", 94); + LILITH_MIN_PLAYERS = GrandBossSettings.getInt("lilithMinPlayers", 98); + LILITH_MAX_PLAYERS = GrandBossSettings.getInt("lilithMaxPlayers", 120); + LILITH_SPAWN_INTERVAL = GrandBossSettings.getInt("IntervalOflilithSpawn", 192); + LILITH_SPAWN_RANDOM = GrandBossSettings.getInt("RandomOflilithSpawn", 148); + LILITH_MIN_PLAYER_LVL = GrandBossSettings.getInt("lilithMinPlayerLvl", 85); + LILITH_MAX_PLAYER_LVL = GrandBossSettings.getInt("lilithMaxPlayerLvl", 89); + // Gracia Seeds final PropertiesParser GraciaSeedsSettings = new PropertiesParser(GRACIASEEDS_CONFIG_FILE);