Jump to content
  • 0

[AutoVoteReward] Hopzone Fail To load Votes


Question

Posted

Hi everyone i am still a newbie trying to find a solution about my AutoVoteReward...

I use a l2jFrozen project and my auto vote reward ONLY on hopzone site get me error and dont load the Votes of the site i put in config section...

[Hopzone fails but Topzone and Network works perfect]

Is there anyone who can help me with this error? Thank you anyway for your time!

 

Here is  My AutoVoteRewardHandler.java Code:

package com.l2jfrozen.gameserver.handler;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.URL;
import java.net.URLConnection;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.Set;

import org.apache.log4j.Level;
import org.apache.log4j.Logger;

import com.gargoylesoftware.htmlunit.BrowserVersion;
import com.gargoylesoftware.htmlunit.WebClient;
import com.gargoylesoftware.htmlunit.html.HtmlPage;
import com.l2jfrozen.Config;
import com.l2jfrozen.gameserver.model.L2World;
import com.l2jfrozen.gameserver.model.actor.instance.L2PcInstance;
import com.l2jfrozen.gameserver.model.entity.Announcements;
import com.l2jfrozen.gameserver.network.clientpackets.Say2;
import com.l2jfrozen.gameserver.network.serverpackets.CreatureSay;
import com.l2jfrozen.gameserver.powerpak.PowerPakConfig;
import com.l2jfrozen.gameserver.thread.ThreadPoolManager;

/**
 * @author L2jFrozen <br>
 * <br>
 *         Network working with L2jFrozen AutoVoteReward: <br>
 *         Hopzone -> http://l2.hopzone.net/ <br>
 *         Topzone -> http://l2topzone.com/ <br>
 *         L2network -> http://l2network.eu/ <br>
 */

public class AutoVoteRewardHandler
{
    protected static final Logger LOGGER = Logger.getLogger(AutoVoteRewardHandler.class);

    protected List<String> already_rewarded;

    private int _l2networkVotesCount = 0;
    private int _hopzoneVotesCount = 0;
    private int _topzoneVotesCount = 0;
    protected List<String> _already_rewarded;

    protected static boolean _l2network = false;
    protected static boolean _topzone = false;
    protected static boolean _hopzone = false;

    private AutoVoteRewardHandler()
    {
        LOGGER.info("Vote Reward System Initiated.");

        if (_hopzone)
        {
            int hopzone_votes = getHopZoneVotes();

            if (hopzone_votes == -1)
            {
                hopzone_votes = 0;
            }

            setHopZoneVoteCount(hopzone_votes);
        }

        if (_l2network)
        {
            int l2network_votes = getL2NetworkVotes();

            if (l2network_votes == -1)
            {
                l2network_votes = 0;
            }

            setL2NetworkVoteCount(l2network_votes);
        }

        if (_topzone)
        {
            int topzone_votes = getTopZoneVotes();

            if (topzone_votes == -1)
            {
                topzone_votes = 0;
            }

            setTopZoneVoteCount(topzone_votes);
        }

        ThreadPoolManager.getInstance().scheduleGeneralAtFixedRate(new AutoReward(), PowerPakConfig.VOTES_SYSYEM_INITIAL_DELAY, PowerPakConfig.VOTES_SYSYEM_STEP_DELAY);
    }

    protected class AutoReward implements Runnable
    {
        @Override
        public void run()
        {
            @SuppressWarnings("unused")
			final int minutes = (PowerPakConfig.VOTES_SYSYEM_STEP_DELAY / 1000) / 60;

            if (_hopzone)
            {
                final int hopzone_votes = getHopZoneVotes();

                if (hopzone_votes != -1)
                {
                	LOGGER.info("Hopzone Votes Are:" + hopzone_votes);
					CreatureSay cs = new CreatureSay(1, Say2.HERO_VOICE, "[Vote System]",  "Hopzone Current Votes: " + hopzone_votes + "...");
	 				for(L2PcInstance player: L2World.getInstance().getAllPlayers())
					{
						if(player != null)
							if(player.isOnline()!=0)
					  			player.sendPacket(cs);    					
            	}
                    if (hopzone_votes != 0 && hopzone_votes >= getHopZoneVoteCount() + PowerPakConfig.VOTES_FOR_REWARD)
                    {
                        _already_rewarded = new ArrayList<>();

                        final Collection<L2PcInstance> pls = L2World.getInstance().getAllPlayers();

    					CreatureSay cs1 = new CreatureSay(1, Say2.HERO_VOICE, "[Vote System]",  "Great Work! Check your inventory for Reward!!");
    	 				for(L2PcInstance player: L2World.getInstance().getAllPlayers())
    					{
    						if(player != null)
    							if(player.isOnline()!=0)
    					  			player.sendPacket(cs1);
    					}
                        // L2ItemInstance item;
                        for (final L2PcInstance player : pls)
                        {
                            if (player != null && !player.isInOfflineMode() && player.isOnline() == 1)
                            {
                                if (player._active_boxes <= 1 || (player._active_boxes > 1 && checkSingleBox(player)))
                                {

                                    final Set<Integer> items = PowerPakConfig.VOTES_REWARDS_LIST.keySet();
                                    for (final Integer i : items)
                                    {
                                        // item = player.getInventory().getItemByItemId(i);

                                        // TODO: check on maxstack for item
                                        player.addItem("reward", i, PowerPakConfig.VOTES_REWARDS_LIST.get(i), player, true);

                                    }

                                }
                            }
                        }
                        setHopZoneVoteCount(hopzone_votes);
					}
					CreatureSay cs1 = new CreatureSay(1, Say2.HERO_VOICE, "[Vote System]",  "Hopzone Next Reward on: " + (getHopZoneVoteCount() + PowerPakConfig.VOTES_FOR_REWARD) + " Votes!!");
	 				for(L2PcInstance player: L2World.getInstance().getAllPlayers())
					{
						if(player != null)
							if(player.isOnline()!=0)
					  			player.sendPacket(cs1);
					}
                    CreatureSay cs2 = new CreatureSay(1, Say2.HERO_VOICE, "[Vote System]",  "Website " + PowerPakConfig.SERVER_WEB_SITE);
	 				for(L2PcInstance player: L2World.getInstance().getAllPlayers())
					{
						if(player != null)
							if(player.isOnline()!=0)
					  			player.sendPacket(cs2);
                }
                }

            }

            if (_topzone && _hopzone && PowerPakConfig.VOTES_SYSYEM_STEP_DELAY > 0)
            {
                try
                {
                    Thread.sleep(PowerPakConfig.VOTES_SYSYEM_STEP_DELAY / 2);
                }
                catch (final InterruptedException e)
                {
                    if (Config.ENABLE_ALL_EXCEPTIONS)
                        e.printStackTrace();
                }
            }

            if (_topzone)
            {
                final int topzone_votes = getTopZoneVotes();

                if (topzone_votes != -1)
                {
                	LOGGER.info("Topzone Votes Are:" + topzone_votes);
					CreatureSay cs = new CreatureSay(1, Say2.HERO_VOICE, "[Vote System]",  "Topzone Current Votes: "+ topzone_votes + "...");
	 				for(L2PcInstance player: L2World.getInstance().getAllPlayers())
					{
						if(player != null)
							if(player.isOnline()!=0)
					  			player.sendPacket(cs);
				    	}
	 				
                    if (topzone_votes != 0 && topzone_votes >= getTopZoneVoteCount() + PowerPakConfig.VOTES_FOR_REWARD)
                    {
                        _already_rewarded = new ArrayList<>();

                        final Collection<L2PcInstance> pls = L2World.getInstance().getAllPlayers();

    					CreatureSay cs1 = new CreatureSay(1, Say2.HERO_VOICE, "[Vote System]",  "Great Work! Check your inventory for Reward!!");
    	 				for(L2PcInstance player: L2World.getInstance().getAllPlayers())
    					{
    						if(player != null)
    							if(player.isOnline()!=0)
    					  			player.sendPacket(cs1);
    					}
                        // L2ItemInstance item;
                        for (final L2PcInstance player : pls)
                        {
                            if (player != null && !player.isInOfflineMode() && player.isOnline() == 1)
                            {
                                if (player._active_boxes <= 1 || (player._active_boxes > 1 && checkSingleBox(player)))
                                {
                                    final Set<Integer> items = PowerPakConfig.VOTES_REWARDS_LIST.keySet();
                                    for (final Integer i : items)
                                    {
                                        // item = player.getInventory().getItemByItemId(i);

                                        // TODO: check on maxstack for item
                                        player.addItem("reward", i, PowerPakConfig.VOTES_REWARDS_LIST.get(i), player, true);
                                    }
                                }
                            }
                        }
                        setTopZoneVoteCount(topzone_votes);
					}
					CreatureSay cs1 = new CreatureSay(1, Say2.HERO_VOICE, "[Vote System]",  "Topzone Next Reward on: " + (getTopZoneVoteCount() + PowerPakConfig.VOTES_FOR_REWARD) + " Votes!!");
	 				for(L2PcInstance player: L2World.getInstance().getAllPlayers())
					{
						if(player != null)
							if(player.isOnline()!=0)
					  			player.sendPacket(cs1);
				    	}
                    CreatureSay cs2 = new CreatureSay(1, Say2.HERO_VOICE, "[Vote System]",  "Website " + PowerPakConfig.SERVER_WEB_SITE);
	 				for(L2PcInstance player: L2World.getInstance().getAllPlayers())
					{
						if(player != null)
							if(player.isOnline()!=0)
					  			player.sendPacket(cs2);
                }
                }
            }

            if (_topzone && _hopzone &&  PowerPakConfig.VOTES_SYSYEM_STEP_DELAY > 0)
            {
              try
                {
                    Thread.sleep(PowerPakConfig.VOTES_SYSYEM_STEP_DELAY / 2);
                }
                catch (final InterruptedException e)
                {
                    if (Config.ENABLE_ALL_EXCEPTIONS)
                        e.printStackTrace();
                }
            }
            
            if (_l2network &&  PowerPakConfig.VOTES_SYSYEM_STEP_DELAY1 > 0)
            {
              try
                {
                    Thread.sleep(PowerPakConfig.VOTES_SYSYEM_STEP_DELAY1 / 2);
                }
                catch (final InterruptedException e)
                {
                    if (Config.ENABLE_ALL_EXCEPTIONS)
                        e.printStackTrace();
                }
            }

            if (_l2network)
            {
                final int l2network_votes = getL2NetworkVotes();

                if (l2network_votes != -1)
                {
					LOGGER.info("Network Votes Are:" + l2network_votes);
					CreatureSay cs = new CreatureSay(1, Say2.HERO_VOICE, "[Vote System]",  "Network Current Votes: "+ l2network_votes + "...");
	 				for(L2PcInstance player: L2World.getInstance().getAllPlayers())
					{
						if(player != null)
							if(player.isOnline()!=0)
					  			player.sendPacket(cs);
				    	}
                
                    if (l2network_votes != 0 && l2network_votes >= getL2NetworkVoteCount() + PowerPakConfig.VOTES_FOR_REWARD)
                    {
                        already_rewarded = new ArrayList<>();

                        final Collection<L2PcInstance> pls = L2World.getInstance().getAllPlayers();

    					CreatureSay cs1 = new CreatureSay(1, Say2.HERO_VOICE, "[Vote System]",  "Great Work! Check your inventory for Reward!!");
    	 				for(L2PcInstance player: L2World.getInstance().getAllPlayers())
    					{
    						if(player != null)
    							if(player.isOnline()!=0)
    					  			player.sendPacket(cs1);
    					}
                        // L2ItemInstance item;
                        for (final L2PcInstance player : pls)
                        {
                            if (player != null && !player.isInOfflineMode() && player.isOnline() == 1)
                            {
                                if (player._active_boxes <= 1 || (player._active_boxes > 1 && checkSingleBox(player)))
                                {
                                    final Set<Integer> items = PowerPakConfig.VOTES_REWARDS_LIST.keySet();
                                    for (final Integer i : items)
                                    {
                                        // item = player.getInventory().getItemByItemId(i);

                                        // TODO: check on maxstack for item
                                        player.addItem("reward", i, PowerPakConfig.VOTES_REWARDS_LIST.get(i), player, true);
                                    }
                                }
                            }
                        }
                        setL2NetworkVoteCount(l2network_votes);
                    }
                    CreatureSay cs1 = new CreatureSay(1, Say2.HERO_VOICE, "[Vote System]",  "Network Next Reward on: " + (getL2NetworkVoteCount() + PowerPakConfig.VOTES_FOR_REWARD) + " Votes!!");
	 				for(L2PcInstance player: L2World.getInstance().getAllPlayers())
					{
						if(player != null)
							if(player.isOnline()!=0)
					  			player.sendPacket(cs1);
				  }
                    CreatureSay cs2 = new CreatureSay(1, Say2.HERO_VOICE, "[Vote System]",  "Website " + PowerPakConfig.SERVER_WEB_SITE);
	 				for(L2PcInstance player: L2World.getInstance().getAllPlayers())
					{
						if(player != null)
							if(player.isOnline()!=0)
					  			player.sendPacket(cs2);
                }
                }
            }
        }
    }
    // Check boxes
    protected boolean checkSingleBox(final L2PcInstance player)
    {
   		if (player == null)
			return false;

        if (player.getClient() != null && player.getClient().getConnection() != null && !player.getClient().getConnection().isClosed() && player.isOnline() == 1 && !player.isInOfflineMode())
        {
            final String playerip = player.getClient().getConnection().getInetAddress().getHostAddress();

            if (_already_rewarded.contains(playerip))
                return false;
            _already_rewarded.add(playerip);
            return true;
        }

        // if no connection (maybe offline shop) dnt reward
        return false;
    }

    protected int getHopZoneVotes()
    {
        int votes = -1;

        try
        {
            final WebClient webClient = new WebClient(BrowserVersion.CHROME);
            webClient.getOptions().setThrowExceptionOnFailingStatusCode(false);
            webClient.getOptions().setThrowExceptionOnScriptError(false);
            webClient.getOptions().setPrintContentOnFailingStatusCode(false);

            final HtmlPage page = webClient.getPage(PowerPakConfig.VOTES_SITE_HOPZONE_URL);

            final String fullPage = page.asXml();
            final int constrainA = fullPage.indexOf("rank anonymous tooltip") + 24;
            String voteSection = fullPage.substring(constrainA);
            final int constrainB = voteSection.indexOf("span") - 2;
            voteSection = voteSection.substring(0, constrainB).trim();
            votes = Integer.parseInt(voteSection);

            // Try to free all the freaking resources
            page.cleanUp();
            webClient.getJavaScriptEngine().shutdown();
            webClient.closeAllWindows();
        }
        catch (final Exception e)
        {
            LOGGER.warn("[AutoVoteReward] Server HOPZONE is offline or something is wrong in link", e);
            Announcements.getInstance().gameAnnounceToAll("[AutoVoteReward] HOPZONE is offline. We will check reward as it will be online again");
        }

        return votes;
    }

    protected int getTopZoneVotes()
    {
        int votes = -1;
        URL url = null;
        URLConnection con = null;
        InputStream is = null;
        InputStreamReader isr = null;
        BufferedReader in = null;

        try
        {
            url = new URL(PowerPakConfig.VOTES_SITE_TOPZONE_URL);
            con = url.openConnection();
            con.addRequestProperty("User-Agent", "L2TopZone");
            is = con.getInputStream();
            isr = new InputStreamReader(is);
            in = new BufferedReader(isr);
            String inputLine;
            while ((inputLine = in.readLine()) != null)
            {
                votes = Integer.valueOf(inputLine);
                break;
            }
        }
        catch (final Exception e)
        {
            LOGGER.warn("[AutoVoteReward] Server TOPZONE is offline or something is wrong in link");
            Announcements.getInstance().gameAnnounceToAll("[AutoVoteReward] TOPZONE is offline. We will check reward as it will be online again");
            // e.printStackTrace();
        }
        finally
        {
            if (in != null)
                try
                {
                    in.close();
                }
                catch (final IOException e1)
                {
                    e1.printStackTrace();
                }
            if (isr != null)
                try
                {
                    isr.close();
                }
                catch (final IOException e1)
                {
                    e1.printStackTrace();
                }
            if (is != null)
                try
                {
                    is.close();
                }
                catch (final IOException e1)
                {
                    e1.printStackTrace();
                }
        }
        return votes;
    }

    protected int getL2NetworkVotes()
    {
        int votes = -1;
        URL url = null;
        URLConnection con = null;
        InputStream is = null;
        InputStreamReader isr = null;
        BufferedReader in = null;

        try
        {
            url = new URL(PowerPakConfig.VOTES_SITE_L2NETWORK_URL);
            con = url.openConnection();
            con.addRequestProperty("User-Agent", "L2Network");
            is = con.getInputStream();
            isr = new InputStreamReader(is);
            in = new BufferedReader(isr);
            String inputLine;
            while ((inputLine = in.readLine()) != null)
            {
                if (inputLine.contains("color:#e7ebf2"))
                {
                    votes = Integer.valueOf(inputLine.split(">")[2].replace("</b", ""));
                    break;
                }
            }
        }
        catch (final Exception e)
        {
            LOGGER.warn("[AutoVoteReward] Server L2NETWORK is offline or something is wrong in link");
            Announcements.getInstance().gameAnnounceToAll("[AutoVoteReward] L2Network is offline. We will check reward as it will be online again");
            // e.printStackTrace();
        }
        finally
        {
            if (in != null)
                try
                {
                    in.close();
                }
                catch (final IOException e1)
                {
                    e1.printStackTrace();
                }
            if (isr != null)
                try
                {
                    isr.close();
                }
                catch (final IOException e1)
                {
                    e1.printStackTrace();
                }
            if (is != null)
                try
                {
                    is.close();
                }
                catch (final IOException e1)
                {
                    e1.printStackTrace();
                }
        }
        return votes;
    }

    protected void setHopZoneVoteCount(final int voteCount)
    {
        _hopzoneVotesCount = voteCount;
    }

    protected int getHopZoneVoteCount()
    {
        return _hopzoneVotesCount;
    }

    protected void setTopZoneVoteCount(final int voteCount)
    {
        _topzoneVotesCount = voteCount;
    }

    protected int getTopZoneVoteCount()
    {
        return _topzoneVotesCount;
    }

    protected void setL2NetworkVoteCount(final int voteCount)
    {
        _l2networkVotesCount = voteCount;
    }

    protected int getL2NetworkVoteCount()
    {
        return _l2networkVotesCount;
    }

    public static AutoVoteRewardHandler getInstance()
    {
        Logger.getLogger("com.gargoylesoftware").setLevel(Level.OFF);

        if (PowerPakConfig.VOTES_SITE_HOPZONE_URL != null && !PowerPakConfig.VOTES_SITE_HOPZONE_URL.equals(""))
            _hopzone = true;

        if (PowerPakConfig.VOTES_SITE_TOPZONE_URL != null && !PowerPakConfig.VOTES_SITE_TOPZONE_URL.equals(""))
            _topzone = true;

        if (PowerPakConfig.VOTES_SITE_L2NETWORK_URL != null && !PowerPakConfig.VOTES_SITE_L2NETWORK_URL.equals(""))
            _l2network = true;

        if (_topzone || _hopzone || _l2network)
            return SingletonHolder._instance;

        return null;
    }

    @SuppressWarnings("synthetic-access")
    private static class SingletonHolder
    {
        protected static final AutoVoteRewardHandler _instance = new AutoVoteRewardHandler();
    }
}

 

 

And This Is My Config Lines: (for example i use an another server details to test it)

 

# Automatic Vote Reward System
VoteRewardSystem= True
VotesRequiredForReward = 3
VotesSystemInitialDelay= 300000
VotesSystemStepDelay= 300000
VotesRewards= 7570,1;

# Leave empty to disable one site
# Put your website url
ServerWebSite = www.l2Test.com
#
# Hopzone: http://l2.hopzone.net
VotesSiteHopZoneUrl = http://l2.hopzone.net/lineage2/details/100936/L2Warland
# Topzone: http://l2topzone.com
VotesSiteTopZoneUrl =  http://l2topzone.com/tv.php?id=13556
# ---------------------------------------
VotesSystemNetworkDelay = 300000
# L2Network: http://l2network.eu
VotesSiteL2NetworkUrl = https://l2network.eu/details/l2warland/

 

10 answers to this question

Recommended Posts

  • 0
Posted (edited)

melron i already tried this but the same problem...

Reborn12 i checked all the forum posts before post it here as i said i'm still new to javascripting so i cant conver javascript from acis to l2jfrozen that's why i ask your help... As i saw you're a very experienced dev for this matter so the help i need here is a new fixed javascript to replace the existing one without convert it by my self manualy cause i dont know how to do it yet....

If there any other file or java script you need to check plz ask me to sent it here to find the problem

Thank you for your time guys i appreciate it!

Edited by KaLeDoR
Edit
  • 0
Posted (edited)

i tried it but i  think i made wrong lines copy/paste  i erased (+) values but on build makes errors 

 

As i saied i'm so newbie and i dont know what error is to disguss it further i see the line where is the error but i dont know why and what to do to make it right.

 

Could you plz make the edit for me please if you have some spare time?

 

Or sent me a pick from where to where i make the edit or even better if you have some spare time edit it and sent me the code just to cope paste it...

 

Thanks anyway!

Edited by KaLeDoR
edit
  • 0
Posted

	public static int getVotes()
	{
		int votes = 0;
		try
		{
			URL url = new URL("https://l2.hopzone.net/lineage2/details/100936/L2Warland");
			InputStream is = url.openStream();
			try (BufferedReader br = new BufferedReader(new InputStreamReader(is)))
			{
				String line;
				while ((line = br.readLine()) != null)
				{
					if (line.contains("<span class=\"rank tooltip\" title"))
						votes = Integer.valueOf(line.split(">")[2].replace("</span", ""));
				}
			}
		}
		catch (IOException e)
		{
			e.printStackTrace();
		}
		
		return votes;
	}

 

  • 0
Posted

if i do this i would have to edit the link from javascript right?

This will affect the next lines in javascript about gethopzonevote  and the html needed from configs?

  • 0
Posted (edited)

just replace the link with Config.yourConfig dont forget to write https instead of http

 

URL(Config.Config);

 

Edited by melron
  • 0
Posted

 

victory-meme.jpg

 

Guys i edited by myself and using Reborn12 code and now it works Perfect no errors and take the votes right!

The change i made was this:

protected int getHopZoneVotes()
    {
        int votes = -1;
        URL url = null;
        URLConnection con = null;
        InputStream is = null;
        InputStreamReader isr = null;
        BufferedReader in = null;

        try
        {
            url = new URL(PowerPakConfig.VOTES_SITE_HOPZONE_URL);
            con = url.openConnection();
            con.addRequestProperty("User-Agent", "L2HopZone");
            is = con.getInputStream();
            isr = new InputStreamReader(is);
            in = new BufferedReader(isr);
            String inputLine;
            while ((inputLine = in.readLine()) != null)
            {
            	if (inputLine.contains("Total Votes") || inputLine.contains("rank tooltip") || inputLine.contains("no steal make love") || inputLine.contains("no votes here") || inputLine.contains("bang, you don't have votes") || inputLine.contains("la vita e bella") || inputLine.contains("rank anonymous tooltip"))
                {
                    votes = Integer.valueOf(inputLine.split(">")[2].replace("</span", ""));
                    break;
                }
            }
        }
        catch (final Exception e)
        {
            LOGGER.warn("[AutoVoteReward] Server HOPZONE is offline or something is wrong in link", e);
            Announcements.getInstance().gameAnnounceToAll("[AutoVoteReward] HOPZONE is offline. We will check reward as it will be online again");
         // e.printStackTrace();
        }
        finally
        {
            if (in != null)
                try
                {
                    in.close();
                }
                catch (final IOException e1)
                {
                    e1.printStackTrace();
                }
            if (isr != null)
                try
                {
                    isr.close();
                }
                catch (final IOException e1)
                {
                    e1.printStackTrace();
                }
            if (is != null)
                try
                {
                    is.close();
                }
                catch (final IOException e1)
                {
                    e1.printStackTrace();
                }
        }
        return votes;
    }

Thank you all for your time and the sollutions you told me! 

Now i'm looking for an Individual VoteReward System-NPC for L2JFrozen if anyone have something i apprecciate it!

  • 0
Posted (edited)

You can search in shares and files section i shared one before some months

topic locked

Edited by Reborn12
Guest
This topic is now closed to further replies.
×
×
  • Create New...