Package com.l2jfrozen.gameserver.network.clientpackets

Source Code of com.l2jfrozen.gameserver.network.clientpackets.Say2

/*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2, 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, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
* 02111-1307, USA.
*
* http://www.gnu.org/copyleft/gpl.html
*/
package com.l2jfrozen.gameserver.network.clientpackets;

import java.nio.BufferUnderflowException;
import java.util.Collection;
import java.util.StringTokenizer;
import java.util.logging.Level;
import java.util.logging.LogRecord;
import java.util.logging.Logger;

import com.l2jfrozen.Config;
import com.l2jfrozen.gameserver.datatables.csv.MapRegionTable;
import com.l2jfrozen.gameserver.handler.IVoicedCommandHandler;
import com.l2jfrozen.gameserver.handler.VoicedCommandHandler;
import com.l2jfrozen.gameserver.managers.PetitionManager;
import com.l2jfrozen.gameserver.model.L2Character;
import com.l2jfrozen.gameserver.model.L2Object;
import com.l2jfrozen.gameserver.model.L2World;
import com.l2jfrozen.gameserver.model.actor.instance.L2PcInstance;
import com.l2jfrozen.gameserver.network.SystemChatChannelId;
import com.l2jfrozen.gameserver.network.SystemMessageId;
import com.l2jfrozen.gameserver.network.serverpackets.CreatureSay;
import com.l2jfrozen.gameserver.network.serverpackets.SocialAction;
import com.l2jfrozen.gameserver.network.serverpackets.SystemMessage;
import com.l2jfrozen.gameserver.powerpak.PowerPak;
import com.l2jfrozen.gameserver.powerpak.PowerPakConfig;
import com.l2jfrozen.gameserver.util.Util;

public final class Say2 extends L2GameClientPacket
{
  private static Logger _log = Logger.getLogger(Say2.class.getName());
  private static Logger _logChat = Logger.getLogger("chat");

  public final static int ALL = 0;
  public final static int SHOUT = 1; //!
  public final static int TELL = 2;
  public final static int PARTY = 3; //#
  public final static int CLAN = 4; //@
  public final static int GM = 5; ////gmchat
  public final static int PETITION_PLAYER = 6; // used for petition
  public final static int PETITION_GM = 7; //* used for petition
  public final static int TRADE = 8; //+
  public final static int ALLIANCE = 9; //$
  public final static int ANNOUNCEMENT = 10; ////announce
  public final static int PARTYROOM_ALL = 16; //(Red)
  public final static int PARTYROOM_COMMANDER = 15; //(Yellow)
  public final static int HERO_VOICE = 17; //%
  public final static int CRITICAL_ANNOUNCE = 18;

  private final static String[] CHAT_NAMES =
  {
      "ALL ", "SHOUT", "TELL ", "PARTY", "CLAN ", "GM   ", "PETITION_PLAYER", "PETITION_GM", "TRADE", "ALLIANCE", "ANNOUNCEMENT", //10
      "WILLCRASHCLIENT:)",
      "FAKEALL?",
      "FAKEALL?",
      "FAKEALL?",
      "PARTYROOM_ALL",
      "PARTYROOM_COMMANDER",
      "CRITICAL_ANNOUNCE",
      "HERO_VOICE" 
  };

  private String _text;
  private int _type;
  private SystemChatChannelId _type2Check;
  private String _target;

  @Override
  protected void readImpl()
  {
    _text = readS();
    try
    {
      _type = readD();
      _type2Check = SystemChatChannelId.getChatType(_type);
     
    }
    catch(BufferUnderflowException e)
    {
      if(Config.ENABLE_ALL_EXCEPTIONS)
        e.printStackTrace();
     
      _type = CHAT_NAMES.length;
      _type2Check = SystemChatChannelId.CHAT_NONE;
    }
    _target = _type == TELL ? readS() : null;
  }

  @Override
  protected void runImpl()
  {
    if(Config.DEBUG)
    {
      _log.info("Say2: Msg Type = '" + _type + "' Text = '" + _text + "'.");
    }

    if(_type < 0 || _type >= CHAT_NAMES.length)
    {
      _log.warning("Say2: Invalid type: " + _type);
      return;
    }
   
    L2PcInstance activeChar = getClient().getActiveChar();
   
    // Anti-PHX Announce
    if (_type2Check == SystemChatChannelId.CHAT_NONE
        || _type2Check == SystemChatChannelId.CHAT_ANNOUNCE
        || _type2Check == SystemChatChannelId.CHAT_CRITICAL_ANNOUNCE
        || _type2Check == SystemChatChannelId.CHAT_SYSTEM
        || _type2Check == SystemChatChannelId.CHAT_CUSTOM
        || (_type2Check == SystemChatChannelId.CHAT_GM_PET && !activeChar.isGM()))
    {
       _log.warning("[Anti-PHX Announce] Illegal Chat channel was used by character: [" + activeChar.getName() + "]");
       return;
    }
   
    if(activeChar == null)
    {
      _log.warning("[Say2.java] Active Character is null.");
      return;
    }
   
    if( activeChar.isChatBanned() && !activeChar.isGM() && _type != CLAN && _type != ALLIANCE && _type != PARTY)
    {
      activeChar.sendMessage("You may not chat while a chat ban is in effect.");
      return;
    }

    if(activeChar.isInJail() && Config.JAIL_DISABLE_CHAT)
    {
      if(_type == TELL || _type == SHOUT || _type == TRADE || _type == HERO_VOICE)
      {
        activeChar.sendMessage("You can not chat with players outside of the jail.");
        return;
      }
    }
   
    if (!getClient().getFloodProtectors().getSayAction().tryPerformAction("Say2"))
    {
      activeChar.sendMessage("You cannot speak too fast.");
      return;
    }
   
    if(activeChar.isCursedWeaponEquiped() && (_type == TRADE || _type == SHOUT))
    {
      activeChar.sendMessage("Shout and trade chatting cannot be used while possessing a cursed weapon.");
      return;
    }

    if(_type == PETITION_PLAYER && activeChar.isGM())
    {
      _type = PETITION_GM;
    }

    if(_text.length() > Config.MAX_CHAT_LENGTH)
    {
      if(Config.DEBUG)
      {
        _log.info("Say2: Msg Type = '" + _type + "' Text length more than " + Config.MAX_CHAT_LENGTH + " truncate them.");
      }
      _text = _text.substring(0, Config.MAX_CHAT_LENGTH);
      //return;
    }

    if(Config.LOG_CHAT)
    {
      LogRecord record = new LogRecord(Level.INFO, _text);
      record.setLoggerName("chat");

      if(_type == TELL)
      {
        record.setParameters(new Object[]
        {
            CHAT_NAMES[_type], "[" + activeChar.getName() + " to " + _target + "]"
        });
      }
      else
      {
        record.setParameters(new Object[]
        {
            CHAT_NAMES[_type], "[" + activeChar.getName() + "]"
        });
      }

      _logChat.log(record);
    }

    if (Config.L2WALKER_PROTEC && _type == TELL && checkBot(_text))
    {
      Util.handleIllegalPlayerAction(activeChar, "Client Emulator Detect: Player " + activeChar.getName() + " using l2walker.", Config.DEFAULT_PUNISH);
      return;
    }
    _text = _text.replaceAll("//cfg", "atay");
   
    if(PowerPakConfig.ENABLE_SAY_SOCIAL_ACTIONS && !activeChar.isAlikeDead() && !activeChar.isDead()){
      if ((_text.equalsIgnoreCase("hello")
          || _text.equalsIgnoreCase("hey")
          || _text.equalsIgnoreCase("aloha")
          || _text.equalsIgnoreCase("alo")
          || _text.equalsIgnoreCase("ciao")
          || _text.equalsIgnoreCase("hi"))
          && (!activeChar.isRunning()
              || !activeChar.isAttackingNow()
              || !activeChar.isCastingNow()
              || !activeChar.isCastingPotionNow()))
        activeChar.broadcastPacket(new SocialAction(activeChar.getObjectId(), 2));
     
      if ((_text.equalsIgnoreCase("lol")
          || _text.equalsIgnoreCase("haha")
          || _text.equalsIgnoreCase("xaxa")
          || _text.equalsIgnoreCase("ghgh")
          || _text.equalsIgnoreCase("jaja"))
          && (!activeChar.isRunning() || !activeChar.isAttackingNow() || !activeChar.isCastingNow() || !activeChar.isCastingPotionNow()))
        activeChar.broadcastPacket(new SocialAction(activeChar.getObjectId(), 10));
       
      if ((_text.equalsIgnoreCase("yes")
          || _text.equalsIgnoreCase("si")
          || _text.equalsIgnoreCase("yep"))
          && (!activeChar.isRunning() || !activeChar.isAttackingNow() || !activeChar.isCastingNow()|| !activeChar.isCastingPotionNow()))
        activeChar.broadcastPacket(new SocialAction(activeChar.getObjectId(), 6));
     
      if ((_text.equalsIgnoreCase("no")
          || _text.equalsIgnoreCase("nop")
          || _text.equalsIgnoreCase("nope"))
          && (!activeChar.isRunning() || !activeChar.isAttackingNow() || !activeChar.isCastingNow()|| !activeChar.isCastingPotionNow()))
        activeChar.broadcastPacket(new SocialAction(activeChar.getObjectId(), 5));
   
    }
   
    // by Azagthtot
    PowerPak.getInstance().chatHandler(activeChar, _type, _text);
    //CreatureSay cs = new CreatureSay(activeChar.getObjectId(),_type, activeChar.getName(), _text);

    L2Object saymode = activeChar.getSayMode();
    if(saymode != null)
    {
      String name = saymode.getName();
      int actor = saymode.getObjectId();
      _type = 0;
      Collection<L2Object> list = saymode.getKnownList().getKnownObjects().values();

      CreatureSay cs = new CreatureSay(actor, _type, name, _text);
      for(L2Object obj : list)
      {
        if(obj == null || !(obj instanceof L2Character))
        {
          continue;
        }
        L2Character chara = (L2Character) obj;
        chara.sendPacket(cs);
      }
      return;
    }
   
    CreatureSay cs = new CreatureSay(activeChar.getObjectId(), _type, activeChar.getName(), _text);
    switch(_type)
    {
      case TELL:
        L2PcInstance receiver = L2World.getInstance().getPlayer(_target);
       
        if(receiver == null){
         
          SystemMessage sm = new SystemMessage(SystemMessageId.S1_IS_NOT_ONLINE);
          sm.addString(_target);
          activeChar.sendPacket(sm);
          sm = null;
          return;
         
        }
       
        if (!receiver.getBlockList().isInBlockList(activeChar.getName())
          || activeChar.isGM())
        {
          if(receiver.isAway())
          {
            activeChar.sendMessage("Player is Away try again later.");
          }

          if(Config.JAIL_DISABLE_CHAT && receiver.isInJail())
          {
            activeChar.sendMessage("Player is in jail.");
            return;
          }

          if(receiver.isChatBanned() && !activeChar.isGM())
          {
            activeChar.sendMessage("Player is chat banned.");
            return;
          }

         
          if (receiver.isOffline())
          {
            activeChar.sendMessage("Player is in offline mode.");
            return;
          }
         
         
          if(!receiver.getMessageRefusal())
          {
            receiver.sendPacket(cs);
            activeChar.sendPacket(new CreatureSay(activeChar.getObjectId(), _type, "->" + receiver.getName(), _text));
          }
          else
          {
            activeChar.sendPacket(new SystemMessage(SystemMessageId.THE_PERSON_IS_IN_MESSAGE_REFUSAL_MODE));
          }
        }
        else if(receiver.getBlockList().isInBlockList(activeChar.getName()))
        {
          SystemMessage sm = new SystemMessage(SystemMessageId.S1_HAS_ADDED_YOU_TO_IGNORE_LIST);
          sm.addString(_target);
          activeChar.sendPacket(sm);
          sm = null;
        }
       
        break;
      case SHOUT:
       
        // Flood protect Say
        if (!getClient().getFloodProtectors().getGlobalChat().tryPerformAction("global chat"))
          return;

               if(Config.DEFAULT_GLOBAL_CHAT.equalsIgnoreCase("on") || Config.DEFAULT_GLOBAL_CHAT.equalsIgnoreCase("gm") && activeChar.isGM())
               {
                  int region = MapRegionTable.getInstance().getMapRegion(activeChar.getX(), activeChar.getY());
                  for(L2PcInstance player : L2World.getInstance().getAllPlayers())
                  {
                     if(region == MapRegionTable.getInstance().getMapRegion(player.getX(), player.getY()))
                     {
              // Like L2OFF if player is blocked can't read the message
              if(!player.getBlockList().isInBlockList(activeChar.getName()))                 
                           player.sendPacket(cs);
                     }
                  }
               }
               else if(Config.DEFAULT_GLOBAL_CHAT.equalsIgnoreCase("GLOBAL"))
               {
                  if(Config.GLOBAL_CHAT_WITH_PVP)
                  {
                     if((activeChar.getPvpKills() < Config.GLOBAL_PVP_AMOUNT) && !activeChar.isGM())
                     {
                        activeChar.sendMessage("You must have at least " + Config.GLOBAL_PVP_AMOUNT+ " pvp kills in order to speak in global chat");
                        return;
                     }
                     for(L2PcInstance player : L2World.getInstance().getAllPlayers())
                     {
              // Like L2OFF if player is blocked can't read the message
              if(!player.getBlockList().isInBlockList(activeChar.getName()))
                           player.sendPacket(cs);
                     }
                  }
                  else
                  {
                     for(L2PcInstance player : L2World.getInstance().getAllPlayers())
                     {
              // Like L2OFF if player is blocked can't read the message
              if(!player.getBlockList().isInBlockList(activeChar.getName()))
                           player.sendPacket(cs);
                     }
                  }
               }
               break;
            case TRADE:
              if (!getClient().getFloodProtectors().getTradeChat().tryPerformAction("trade chat"))
            return;
             
               if(Config.DEFAULT_TRADE_CHAT.equalsIgnoreCase("ON"))
               {
                  if(Config.TRADE_CHAT_WITH_PVP)
                  {
                     if((activeChar.getPvpKills() <= Config.TRADE_PVP_AMOUNT) && !activeChar.isGM())
                     {
                        activeChar.sendMessage("You must have at least " + Config.TRADE_PVP_AMOUNT+ "  pvp kills in order to speak in trade chat");
                        return;
                     }
                     for(L2PcInstance player : L2World.getInstance().getAllPlayers())
                     {
              // Like L2OFF if player is blocked can't read the message
              if(!player.getBlockList().isInBlockList(activeChar.getName()))
                           player.sendPacket(cs);
                     }
                  }
                  else
                  {
                     for(L2PcInstance player : L2World.getInstance().getAllPlayers())
                     {
              // Like L2OFF if player is blocked can't read the message
              if(!player.getBlockList().isInBlockList(activeChar.getName()))
                           player.sendPacket(cs);
                     }
                  }
               }
               else if(Config.DEFAULT_TRADE_CHAT.equalsIgnoreCase("limited"))
               {
                
          if(Config.TRADE_CHAT_IS_NOOBLE)
          {
            if(!activeChar.isNoble() && !activeChar.isGM())
            {
              activeChar.sendMessage("Only Nobless Players Can Use This Chat");
              return;
            }
           
            int region = MapRegionTable.getInstance().getMapRegion(activeChar.getX(), activeChar.getY());
            for(L2PcInstance player : L2World.getInstance().getAllPlayers())
            {
              if(region == MapRegionTable.getInstance().getMapRegion(player.getX(), player.getY()))
              {
                // Like L2OFF if player is blocked can't read the message
                if(!player.getBlockList().isInBlockList(activeChar.getName()))
                   player.sendPacket(cs);
              }
            }
           
          }
          else
          {
            int region = MapRegionTable.getInstance().getMapRegion(activeChar.getX(), activeChar.getY());
            for(L2PcInstance player : L2World.getInstance().getAllPlayers())
            {
              if(region == MapRegionTable.getInstance().getMapRegion(player.getX(), player.getY()))
              {
                // Like L2OFF if player is blocked can't read the message
                if(!player.getBlockList().isInBlockList(activeChar.getName()))
                   player.sendPacket(cs);
              }
            }
          }

         
               }
               break;
      case ALL:
        if(_text.startsWith("."))
        { 
          StringTokenizer st = new StringTokenizer(_text);
          IVoicedCommandHandler vch;
          String command = "";
          String target = "";

          if(st.countTokens() > 1)
          {
            command = st.nextToken().substring(1);
            target = _text.substring(command.length() + 2);
            vch = VoicedCommandHandler.getInstance().getVoicedCommandHandler(command);
          }
          else
          {
            command = _text.substring(1);
            if(Config.DEBUG)
            {
              _log.info("Command: " + command);
            }
            vch = VoicedCommandHandler.getInstance().getVoicedCommandHandler(command);
          }

          if(vch != null)
          {
            vch.useVoicedCommand(command, activeChar, target);
            break;
          }
        }
       
        for(L2PcInstance player : activeChar.getKnownList().getKnownPlayers().values())
        {
          if(player != null && activeChar.isInsideRadius(player, 1250, false, true))
          {
            // Like L2OFF if player is blocked can't read the message
            if(!player.getBlockList().isInBlockList(activeChar.getName()))
              player.sendPacket(cs);
          }
        }
        activeChar.sendPacket(cs);
       
        break;
      case CLAN:
        if(activeChar.getClan() != null)
        {
          activeChar.getClan().broadcastToOnlineMembers(cs);
        }
        break;
      case ALLIANCE:
        if(activeChar.getClan() != null)
        {
          activeChar.getClan().broadcastToOnlineAllyMembers(cs);
        }
        break;
      case PARTY:
        if(activeChar.isInParty())
        {
          activeChar.getParty().broadcastToPartyMembers(cs);
        }
        break;
      case PETITION_PLAYER:
      case PETITION_GM:
        if(!PetitionManager.getInstance().isPlayerInConsultation(activeChar))
        {
          activeChar.sendPacket(new SystemMessage(SystemMessageId.YOU_ARE_NOT_IN_PETITION_CHAT));
          break;
        }

        PetitionManager.getInstance().sendActivePetitionMessage(activeChar, _text);
        break;
      case PARTYROOM_ALL:
        if(activeChar.isInParty())
        {
          if(activeChar.getParty().isInCommandChannel() && activeChar.getParty().isLeader(activeChar))
          {
            activeChar.getParty().getCommandChannel().broadcastCSToChannelMembers(cs, activeChar);
          }
        }
        break;
      case PARTYROOM_COMMANDER:
        if(activeChar.isInParty())
        {
          if(activeChar.getParty().isInCommandChannel() && activeChar.getParty().getCommandChannel().getChannelLeader().equals(activeChar))
          {
            activeChar.getParty().getCommandChannel().broadcastCSToChannelMembers(cs, activeChar);
          }
        }
        break;
      case HERO_VOICE:
        if(activeChar.isGM())
        {
          for(L2PcInstance player : L2World.getInstance().getAllPlayers()){
           
            if(player==null)
              continue;
           
              player.sendPacket(cs)
          }   
        }
        else if(activeChar.isHero())
        {
          // Flood protect Hero Voice
          if (!getClient().getFloodProtectors().getHeroVoice().tryPerformAction("hero voice"))
            return;

          for(L2PcInstance player : L2World.getInstance().getAllPlayers()){
           
            if(player==null)
              continue;
           
            // Like L2OFF if player is blocked can't read the message
            if(!player.getBlockList().isInBlockList(activeChar.getName()))
              player.sendPacket(cs);         
          }           
        }
        break;
    }
  }
 
  private static final String[] WALKER_COMMAND_LIST = { "USESKILL", "USEITEM", "BUYITEM", "SELLITEM", "SAVEITEM", "LOADITEM", "MSG", "SET", "DELAY", "LABEL", "JMP", "CALL",
    "RETURN", "MOVETO", "NPCSEL", "NPCDLG", "DLGSEL", "CHARSTATUS", "POSOUTRANGE", "POSINRANGE", "GOHOME", "SAY", "EXIT", "PAUSE", "STRINDLG", "STRNOTINDLG", "CHANGEWAITTYPE",
    "FORCEATTACK", "ISMEMBER", "REQUESTJOINPARTY", "REQUESTOUTPARTY", "QUITPARTY", "MEMBERSTATUS", "CHARBUFFS", "ITEMCOUNT", "FOLLOWTELEPORT" };
 
  private boolean checkBot(String text)
  {
    for (String botCommand : WALKER_COMMAND_LIST)
    {
      if (text.startsWith(botCommand))
        return true;
    }
    return false;
  }

 

  @Override
  public String getType()
  {
    return "[C] 38 Say2";
  }
}
TOP

Related Classes of com.l2jfrozen.gameserver.network.clientpackets.Say2

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.