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