|
@@ -18,6 +18,7 @@
|
|
*/
|
|
*/
|
|
package handlers.admincommandhandlers;
|
|
package handlers.admincommandhandlers;
|
|
|
|
|
|
|
|
+import java.util.ArrayList;
|
|
import java.util.Collection;
|
|
import java.util.Collection;
|
|
import java.util.List;
|
|
import java.util.List;
|
|
import java.util.StringTokenizer;
|
|
import java.util.StringTokenizer;
|
|
@@ -28,7 +29,9 @@ import com.l2jserver.gameserver.handler.IAdminCommandHandler;
|
|
import com.l2jserver.gameserver.model.L2World;
|
|
import com.l2jserver.gameserver.model.L2World;
|
|
import com.l2jserver.gameserver.model.actor.L2Character;
|
|
import com.l2jserver.gameserver.model.actor.L2Character;
|
|
import com.l2jserver.gameserver.model.actor.instance.L2PcInstance;
|
|
import com.l2jserver.gameserver.model.actor.instance.L2PcInstance;
|
|
-import com.l2jserver.gameserver.model.effects.L2Effect;
|
|
|
|
|
|
+import com.l2jserver.gameserver.model.effects.AbstractEffect;
|
|
|
|
+import com.l2jserver.gameserver.model.skills.AbnormalType;
|
|
|
|
+import com.l2jserver.gameserver.model.skills.BuffInfo;
|
|
import com.l2jserver.gameserver.model.skills.L2Skill;
|
|
import com.l2jserver.gameserver.model.skills.L2Skill;
|
|
import com.l2jserver.gameserver.network.SystemMessageId;
|
|
import com.l2jserver.gameserver.network.SystemMessageId;
|
|
import com.l2jserver.gameserver.network.serverpackets.NpcHtmlMessage;
|
|
import com.l2jserver.gameserver.network.serverpackets.NpcHtmlMessage;
|
|
@@ -43,35 +46,28 @@ public class AdminBuffs implements IAdminCommandHandler
|
|
private static final String[] ADMIN_COMMANDS =
|
|
private static final String[] ADMIN_COMMANDS =
|
|
{
|
|
{
|
|
"admin_getbuffs",
|
|
"admin_getbuffs",
|
|
|
|
+ "admin_getbuffs_ps",
|
|
"admin_stopbuff",
|
|
"admin_stopbuff",
|
|
"admin_stopallbuffs",
|
|
"admin_stopallbuffs",
|
|
"admin_areacancel",
|
|
"admin_areacancel",
|
|
"admin_removereuse",
|
|
"admin_removereuse",
|
|
"admin_switch_gm_buffs"
|
|
"admin_switch_gm_buffs"
|
|
};
|
|
};
|
|
|
|
+ // Misc
|
|
|
|
+ private static final String FONT_RED1 = "<font color=\"FF0000\">";
|
|
|
|
+ private static final String FONT_RED2 = "</font>";
|
|
|
|
|
|
@Override
|
|
@Override
|
|
public boolean useAdminCommand(String command, L2PcInstance activeChar)
|
|
public boolean useAdminCommand(String command, L2PcInstance activeChar)
|
|
{
|
|
{
|
|
-
|
|
|
|
if (command.startsWith("admin_getbuffs"))
|
|
if (command.startsWith("admin_getbuffs"))
|
|
{
|
|
{
|
|
- StringTokenizer st = new StringTokenizer(command, " ");
|
|
|
|
|
|
+ final StringTokenizer st = new StringTokenizer(command, " ");
|
|
command = st.nextToken();
|
|
command = st.nextToken();
|
|
-
|
|
|
|
if (st.hasMoreTokens())
|
|
if (st.hasMoreTokens())
|
|
{
|
|
{
|
|
- L2PcInstance player = null;
|
|
|
|
- String playername = st.nextToken();
|
|
|
|
-
|
|
|
|
- try
|
|
|
|
- {
|
|
|
|
- player = L2World.getInstance().getPlayer(playername);
|
|
|
|
- }
|
|
|
|
- catch (Exception e)
|
|
|
|
- {
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
|
|
+ final String playername = st.nextToken();
|
|
|
|
+ L2PcInstance player = L2World.getInstance().getPlayer(playername);
|
|
if (player != null)
|
|
if (player != null)
|
|
{
|
|
{
|
|
int page = 1;
|
|
int page = 1;
|
|
@@ -79,15 +75,15 @@ public class AdminBuffs implements IAdminCommandHandler
|
|
{
|
|
{
|
|
page = Integer.parseInt(st.nextToken());
|
|
page = Integer.parseInt(st.nextToken());
|
|
}
|
|
}
|
|
- showBuffs(activeChar, player, page);
|
|
|
|
|
|
+ showBuffs(activeChar, player, page, command.endsWith("_ps"));
|
|
return true;
|
|
return true;
|
|
}
|
|
}
|
|
activeChar.sendMessage("The player " + playername + " is not online.");
|
|
activeChar.sendMessage("The player " + playername + " is not online.");
|
|
return false;
|
|
return false;
|
|
}
|
|
}
|
|
- else if ((activeChar.getTarget() != null) && (activeChar.getTarget() instanceof L2Character))
|
|
|
|
|
|
+ else if ((activeChar.getTarget() != null) && activeChar.getTarget().isCharacter())
|
|
{
|
|
{
|
|
- showBuffs(activeChar, (L2Character) activeChar.getTarget(), 1);
|
|
|
|
|
|
+ showBuffs(activeChar, (L2Character) activeChar.getTarget(), 1, command.endsWith("_ps"));
|
|
return true;
|
|
return true;
|
|
}
|
|
}
|
|
else
|
|
else
|
|
@@ -219,10 +215,7 @@ public class AdminBuffs implements IAdminCommandHandler
|
|
activeChar.sendMessage("There is nothing to switch.");
|
|
activeChar.sendMessage("There is nothing to switch.");
|
|
return false;
|
|
return false;
|
|
}
|
|
}
|
|
- else
|
|
|
|
- {
|
|
|
|
- return true;
|
|
|
|
- }
|
|
|
|
|
|
+ return true;
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|
|
@@ -245,9 +238,18 @@ public class AdminBuffs implements IAdminCommandHandler
|
|
return ADMIN_COMMANDS;
|
|
return ADMIN_COMMANDS;
|
|
}
|
|
}
|
|
|
|
|
|
- public static void showBuffs(L2PcInstance activeChar, L2Character target, int page)
|
|
|
|
|
|
+ public static void showBuffs(L2PcInstance activeChar, L2Character target, int page, boolean passive)
|
|
{
|
|
{
|
|
- final List<L2Effect> effects = target.getAllEffects();
|
|
|
|
|
|
+ final List<BuffInfo> effects = new ArrayList<>();
|
|
|
|
+ if (!passive)
|
|
|
|
+ {
|
|
|
|
+ effects.addAll(target.getEffectList().getEffects());
|
|
|
|
+ }
|
|
|
|
+ else
|
|
|
|
+ {
|
|
|
|
+ effects.addAll(target.getEffectList().getPassives().values());
|
|
|
|
+ }
|
|
|
|
+
|
|
if ((page > ((effects.size() / PAGE_LIMIT) + 1)) || (page < 1))
|
|
if ((page > ((effects.size() / PAGE_LIMIT) + 1)) || (page < 1))
|
|
{
|
|
{
|
|
return;
|
|
return;
|
|
@@ -259,17 +261,21 @@ public class AdminBuffs implements IAdminCommandHandler
|
|
max++;
|
|
max++;
|
|
}
|
|
}
|
|
|
|
|
|
- final StringBuilder html = StringUtil.startAppend(500 + (effects.size() * 200), "<html><table width=\"100%\"><tr><td width=45><button value=\"Main\" action=\"bypass -h admin_admin\" width=45 height=21 back=\"L2UI_ct1.button_df\" fore=\"L2UI_ct1.button_df\"></td><td width=180><center><font color=\"LEVEL\">Effects of ", target.getName(), "</font></td><td width=45><button value=\"Back\" action=\"bypass -h admin_current_player\" width=45 height=21 back=\"L2UI_ct1.button_df\" fore=\"L2UI_ct1.button_df\"></td></tr></table><br><table width=\"100%\"><tr><td width=200>Skill</td><td width=30>Rem. Time</td><td width=70>Action</td><td>In use</td></tr>");
|
|
|
|
|
|
+ final StringBuilder html = StringUtil.startAppend(500 + (effects.size() * 200), "<html><table width=\"100%\"><tr><td width=45><button value=\"Main\" action=\"bypass -h admin_admin\" width=45 height=21 back=\"L2UI_ct1.button_df\" fore=\"L2UI_ct1.button_df\"></td><td width=180><center><font color=\"LEVEL\">Effects of ", target.getName(), "</font></td><td width=45><button value=\"Back\" action=\"bypass -h admin_current_player\" width=45 height=21 back=\"L2UI_ct1.button_df\" fore=\"L2UI_ct1.button_df\"></td></tr></table><br><table width=\"100%\"><tr><td width=200>Skill</td><td width=30>Rem. Time</td><td width=70>Action</td></tr>");
|
|
int start = ((page - 1) * PAGE_LIMIT);
|
|
int start = ((page - 1) * PAGE_LIMIT);
|
|
int end = Math.min(((page - 1) * PAGE_LIMIT) + PAGE_LIMIT, effects.size());
|
|
int end = Math.min(((page - 1) * PAGE_LIMIT) + PAGE_LIMIT, effects.size());
|
|
- for (int i = start; i < end; i++)
|
|
|
|
|
|
+ int count = 0;
|
|
|
|
+ for (BuffInfo info : effects)
|
|
{
|
|
{
|
|
- L2Effect e = effects.get(i);
|
|
|
|
- if (e != null)
|
|
|
|
|
|
+ if ((count >= start) && (count < end))
|
|
{
|
|
{
|
|
- final L2Skill skill = e.getSkill();
|
|
|
|
- StringUtil.append(html, "<tr><td>", skill.getName(), "(", e.getClass().getSimpleName(), ")", "</td><td>", skill.isToggle() ? "T (" + e.getTickCount() + ")" : skill.isPassive() ? "P" : e.getTimeLeft() + "s", "</td><td><button value=\"X\" action=\"bypass -h admin_stopbuff ", Integer.toString(target.getObjectId()), " ", String.valueOf(skill.getId()), "\" width=30 height=21 back=\"L2UI_ct1.button_df\" fore=\"L2UI_ct1.button_df\"></td><td>" + e.isInUse() + "</td></tr>");
|
|
|
|
|
|
+ final L2Skill skill = info.getSkill();
|
|
|
|
+ for (AbstractEffect effect : info.getEffects())
|
|
|
|
+ {
|
|
|
|
+ StringUtil.append(html, "<tr><td>", (!info.isInUse() ? FONT_RED1 : "") + skill.getName(), " Lv ", String.valueOf(skill.getLevel()), " (", effect.getClass().getSimpleName(), ")" + (!info.isInUse() ? FONT_RED2 : ""), "</td><td>", skill.isToggle() ? "T (" + info.getTickCount(effect) + ")" : skill.isPassive() ? "P" : info.getTime() + "s", "</td><td><button value=\"X\" action=\"bypass -h admin_stopbuff ", Integer.toString(target.getObjectId()), " ", String.valueOf(skill.getId()), "\" width=30 height=21 back=\"L2UI_ct1.button_df\" fore=\"L2UI_ct1.button_df\"></td></tr>");
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
+ count++;
|
|
}
|
|
}
|
|
|
|
|
|
html.append("</table><table width=300 bgcolor=444444><tr>");
|
|
html.append("</table><table width=300 bgcolor=444444><tr>");
|
|
@@ -284,7 +290,7 @@ public class AdminBuffs implements IAdminCommandHandler
|
|
}
|
|
}
|
|
else
|
|
else
|
|
{
|
|
{
|
|
- html.append("<td><a action=\"bypass -h admin_getbuffs ");
|
|
|
|
|
|
+ html.append("<td><a action=\"bypass -h admin_getbuffs" + (passive ? "_ps " : " "));
|
|
html.append(target.getName());
|
|
html.append(target.getName());
|
|
html.append(" ");
|
|
html.append(" ");
|
|
html.append(x + 1);
|
|
html.append(x + 1);
|
|
@@ -296,11 +302,32 @@ public class AdminBuffs implements IAdminCommandHandler
|
|
|
|
|
|
html.append("</tr></table>");
|
|
html.append("</tr></table>");
|
|
|
|
|
|
- StringUtil.append(html, "<br><center><button value=\"Remove All\" action=\"bypass -h admin_stopallbuffs ", Integer.toString(target.getObjectId()), "\" width=80 height=21 back=\"L2UI_ct1.button_df\" fore=\"L2UI_ct1.button_df\"></html>");
|
|
|
|
-
|
|
|
|
- final NpcHtmlMessage ms = new NpcHtmlMessage();
|
|
|
|
- ms.setHtml(html.toString());
|
|
|
|
- activeChar.sendPacket(ms);
|
|
|
|
|
|
+ // Buttons
|
|
|
|
+ StringUtil.append(html, "<br><center><button value=\"Refresh\" action=\"bypass -h admin_getbuffs", (passive ? "_ps " : " "), target.getName(), "\" width=80 height=21 back=\"L2UI_ct1.button_df\" fore=\"L2UI_ct1.button_df\">");
|
|
|
|
+ StringUtil.append(html, "<button value=\"Remove All\" action=\"bypass -h admin_stopallbuffs ", Integer.toString(target.getObjectId()), "\" width=80 height=21 back=\"L2UI_ct1.button_df\" fore=\"L2UI_ct1.button_df\"><br>");
|
|
|
|
+ // Legend
|
|
|
|
+ if (!passive)
|
|
|
|
+ {
|
|
|
|
+ StringUtil.append(html, FONT_RED1, "Inactive buffs: ", String.valueOf(target.getEffectList().getHiddenBuffsCount()), FONT_RED2, "<br>");
|
|
|
|
+ }
|
|
|
|
+ StringUtil.append(html, "Total", passive ? " passive" : "", " buff count: ", String.valueOf(effects.size()));
|
|
|
|
+ if ((target.getEffectList().getAllBlockedBuffSlots() != null) && !target.getEffectList().getAllBlockedBuffSlots().isEmpty())
|
|
|
|
+ {
|
|
|
|
+ StringUtil.append(html, "<br>Blocked buff slots: ");
|
|
|
|
+ String slots = "";
|
|
|
|
+ for (AbnormalType slot : target.getEffectList().getAllBlockedBuffSlots())
|
|
|
|
+ {
|
|
|
|
+ slots += slot.toString() + ", ";
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (!slots.isEmpty() && (slots.length() > 3))
|
|
|
|
+ {
|
|
|
|
+ StringUtil.append(html, slots.substring(0, slots.length() - 2));
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ StringUtil.append(html, "</html>");
|
|
|
|
+ // Send the packet
|
|
|
|
+ activeChar.sendPacket(new NpcHtmlMessage(html.toString()));
|
|
|
|
|
|
if (Config.GMAUDIT)
|
|
if (Config.GMAUDIT)
|
|
{
|
|
{
|
|
@@ -321,15 +348,13 @@ public class AdminBuffs implements IAdminCommandHandler
|
|
|
|
|
|
if ((target != null) && (skillId > 0))
|
|
if ((target != null) && (skillId > 0))
|
|
{
|
|
{
|
|
- for (L2Effect e : target.getAllEffects())
|
|
|
|
|
|
+ if (target.isAffectedBySkill(skillId))
|
|
{
|
|
{
|
|
- if ((e != null) && (e.getSkill().getId() == skillId))
|
|
|
|
- {
|
|
|
|
- e.exit();
|
|
|
|
- activeChar.sendMessage("Removed " + e.getSkill().getName() + " level " + e.getSkill().getLevel() + " from " + target.getName() + " (" + objId + ")");
|
|
|
|
- }
|
|
|
|
|
|
+ target.stopSkillEffects(true, skillId);
|
|
|
|
+ activeChar.sendMessage("Removed skill ID: " + skillId + " effects from " + target.getName() + " (" + objId + ").");
|
|
}
|
|
}
|
|
- showBuffs(activeChar, target, 1);
|
|
|
|
|
|
+
|
|
|
|
+ showBuffs(activeChar, target, 1, false);
|
|
if (Config.GMAUDIT)
|
|
if (Config.GMAUDIT)
|
|
{
|
|
{
|
|
GMAudit.auditGMAction(activeChar.getName() + " [" + activeChar.getObjectId() + "]", "stopbuff", target.getName() + " (" + objId + ")", Integer.toString(skillId));
|
|
GMAudit.auditGMAction(activeChar.getName() + " [" + activeChar.getObjectId() + "]", "stopbuff", target.getName() + " (" + objId + ")", Integer.toString(skillId));
|
|
@@ -352,7 +377,7 @@ public class AdminBuffs implements IAdminCommandHandler
|
|
{
|
|
{
|
|
target.stopAllEffects();
|
|
target.stopAllEffects();
|
|
activeChar.sendMessage("Removed all effects from " + target.getName() + " (" + objId + ")");
|
|
activeChar.sendMessage("Removed all effects from " + target.getName() + " (" + objId + ")");
|
|
- showBuffs(activeChar, target, 1);
|
|
|
|
|
|
+ showBuffs(activeChar, target, 1, false);
|
|
if (Config.GMAUDIT)
|
|
if (Config.GMAUDIT)
|
|
{
|
|
{
|
|
GMAudit.auditGMAction(activeChar.getName() + " [" + activeChar.getObjectId() + "]", "stopallbuffs", target.getName() + " (" + objId + ")", "");
|
|
GMAudit.auditGMAction(activeChar.getName() + " [" + activeChar.getObjectId() + "]", "stopallbuffs", target.getName() + " (" + objId + ")", "");
|