Replaced RewardRequest with PlayerAction flood protector.

This commit is contained in:
MobiusDevelopment
2022-01-25 14:41:08 +00:00
parent f53c5067eb
commit 4c83aba88e
40 changed files with 100 additions and 1087 deletions

View File

@ -1,36 +0,0 @@
/*
* 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 <http://www.gnu.org/licenses/>.
*/
package org.l2jmobius.gameserver.model.actor.request;
import org.l2jmobius.gameserver.model.actor.Player;
/**
* @author Mobius
*/
public class RewardRequest extends AbstractRequest
{
public RewardRequest(Player player)
{
super(player);
}
@Override
public boolean isUsing(int objectId)
{
return false;
}
}

View File

@ -19,16 +19,11 @@ package org.l2jmobius.gameserver.network.clientpackets.pledgeV2;
import java.util.Collection;
import org.l2jmobius.commons.network.PacketReader;
import org.l2jmobius.commons.threads.ThreadPool;
import org.l2jmobius.gameserver.data.xml.DailyMissionData;
import org.l2jmobius.gameserver.model.DailyMissionDataHolder;
import org.l2jmobius.gameserver.model.actor.Player;
import org.l2jmobius.gameserver.model.actor.request.RewardRequest;
import org.l2jmobius.gameserver.network.Disconnection;
import org.l2jmobius.gameserver.network.GameClient;
import org.l2jmobius.gameserver.network.PacketLogger;
import org.l2jmobius.gameserver.network.clientpackets.IClientIncomingPacket;
import org.l2jmobius.gameserver.network.serverpackets.ServerClose;
import org.l2jmobius.gameserver.network.serverpackets.pledgeV2.ExPledgeMissionInfo;
import org.l2jmobius.gameserver.network.serverpackets.pledgeV2.ExPledgeMissionRewardCount;
@ -49,21 +44,17 @@ public class RequestExPledgeMissionReward implements IClientIncomingPacket
@Override
public void run(GameClient client)
{
if (!client.getFloodProtectors().canPerformPlayerAction())
{
return;
}
final Player player = client.getPlayer();
if ((player == null) || (player.getClan() == null))
{
return;
}
if (player.hasRequest(RewardRequest.class))
{
PacketLogger.warning("Kicked " + player + " for spamming " + getClass().getSimpleName());
Disconnection.of(player).defaultSequence(ServerClose.STATIC_PACKET);
return;
}
player.addRequest(new RewardRequest(player));
final Collection<DailyMissionDataHolder> reward = DailyMissionData.getInstance().getDailyMissionData(_id);
if ((reward != null) && !reward.isEmpty())
{
@ -71,10 +62,5 @@ public class RequestExPledgeMissionReward implements IClientIncomingPacket
client.sendPacket(new ExPledgeMissionRewardCount(player));
client.sendPacket(new ExPledgeMissionInfo(player));
}
ThreadPool.schedule(() ->
{
player.removeRequest(RewardRequest.class);
}, 50);
}
}