Jump to content
  • 0

Question

Posted

Something went wrong in VoteBase::getApiResponse

 

 

can some one help me solve this? every time i write .vote comand its says somthing whent wrong need to vote again. and in logs i see this

 

Something went wrong in VoteBase::getApiResponse

 

can some one help?

13 answers to this question

Recommended Posts

  • 0
Posted
Something went wrong in VoteBase::getApiResponse

java.io.IOException: Server returned HTTP response code: 403 for URL: https://api.l2topzone.com/v1/vote?token=5e14bd08d6ef4a9f42fed190db6f27b2&ip=85.206.147.64

at sun.net.www.protocol.http.HttpURLConnection.getInputStream0(HttpURLConnection.java:1876)

at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1474)

at sun.net.www.protocol.https.HttpsURLConnectionImpl.getInputStream(HttpsURLConnectionImpl.java:254)

at handler.voicecommands.RewardVote.getApiResponse(RewardVote.java:472)

at handler.voicecommands.RewardVote.hasVoted(RewardVote.java:436)

at handler.voicecommands.RewardVote.useVoicedCommand(RewardVote.java:217)

at l2f.gameserver.network.clientpackets.Say2C.runImpl(Say2C.java:154)

at l2f.gameserver.network.clientpackets.L2GameClientPacket.run(L2GameClientPacket.java:49)

at l2f.commons.net.nio.impl.MMOExecutableQueue.run(MMOExecutableQueue.java:39)

at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)

at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)

at java.lang.Thread.run(Thread.java:748)

java.lang.NullPointerException

at handler.voicecommands.RewardVote.tryParseBool(RewardVote.java:446)

at handler.voicecommands.RewardVote.hasVoted(RewardVote.java:437)

at handler.voicecommands.RewardVote.useVoicedCommand(RewardVote.java:217)

at l2f.gameserver.network.clientpackets.Say2C.runImpl(Say2C.java:154)

at l2f.gameserver.network.clientpackets.L2GameClientPacket.run(L2GameClientPacket.java:49)

at l2f.commons.net.nio.impl.MMOExecutableQueue.run(MMOExecutableQueue.java:39)

at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)

at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)

at java.lang.Thread.run(Thread.java:748)

 

 

its full error , i tryed google iit but i cant solve it.... can u help me?
  • 0
Posted

See imports its acis :P

 

On scale 1 to 10 how sexy and dumb you're? 

l2f is aCis import? 

 

About topic owner, let us smell our nails.. SSSSSS so nice smell.. Good now i smell my cute nails i can fix ur code.. 

GTFO and post your code on the requested file and line the error says...

  • 0
Posted

On scale 1 to 10 how sexy and dumb you're? 

l2f is aCis import? 

 

About topic owner, let us smell our nails.. SSSSSS so nice smell.. Good now i smell my cute nails i can fix ur code.. 

GTFO and post your code on the requested file and line the error says...

Uh yes i thought was net.sf :D..

Then its sunrise or something h5

  • 0
Posted

Uh yes i thought was net.sf :D..

Then its sunrise or something h5

On scale 10 to 10, How nab are you? It's one of the shared L2World sources that the idiot guy lately shared along with tale's one.

This guy simply try open a l2tales server. simple as fuck.

  • 0
Posted
package handler.voicecommands;

 

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.util.Map;

import java.util.concurrent.ConcurrentHashMap;

import java.io.BufferedReader;

import java.io.InputStreamReader;

import java.net.HttpURLConnection;

import java.net.URL;

 

import l2f.commons.util.Rnd;

import l2f.gameserver.Config;

import l2f.gameserver.ThreadPoolManager;

import l2f.gameserver.database.DatabaseFactory;

import l2f.gameserver.handler.voicecommands.IVoicedCommandHandler;

import l2f.gameserver.handler.voicecommands.VoicedCommandHandler;

import l2f.gameserver.model.GameObjectsStorage;

import l2f.gameserver.model.Player;

import l2f.gameserver.network.serverpackets.Say2;

import l2f.gameserver.network.serverpackets.components.ChatType;

import l2f.gameserver.scripts.Functions;

import l2f.gameserver.scripts.ScriptFile;

import l2f.gameserver.utils.BatchStatement;

import l2f.gameserver.vote.VoteRead;

 

public class RewardVote implements IVoicedCommandHandler, ScriptFile

{

private static enum ValueType

{

ACCOUNT_NAME,

IP_ADRESS,

HWID

}

 

private static final String[] COMMANDS_LIST = new String[] { "vote", "getreward", "getvote", "votereward", "voteme", "fuckvote", "rewardget", "reward", "votereward"};

 

// Rewards

private static final int[][] BLESSED_ENCHANTS_CATEGORY = { { 6673, 1 } };

 

private static final int[] PERMANENT_CATEGORY = { 37004, // Vote Rune

   1 };

 

 private static final int[][] MISC_CATEGORY = { { 37007, 1 }, { 37007, 2 },  { 37007, 3 } };

 private static final double[][] RANDOM_CATEGORY = { { 6577,// 1 Blessed Enchant Weapon S

   1,

   0.05 }, { 6578,// 1 Blessed Enchant Armor S

   1,

   0.05 }, { 13071,// 1 Red Soul Crystal - Stage 16

   1,

   0.05 }, { 13072,// 1 Blue Soul Crystal - Stage 16

   1,

   0.05 }, { 13073,// 1 Green Soul Crystal - Stage 16

   1,

   0.155 }, { 10480,// 1 Red Soul Crystal - Stage 15

   1,

   0.155 }, { 10481,// 1 Blue Soul Crystal - Stage 15

   1,

   0.155 }, { 10482,// 1 Green Soul Crystal - Stage 15

   1,

   0.566 }, { 14169,// 1 Top Life Stone Level 84

   1,

   1.25 }, { 14168,// 1 High Life Stone Level 84

   1,

   2.0 }, { 13073,// 1 Giant's Codex - Mastery

   1,

   3.333 }, { 959,// 1 Enchant Weapon S

   1,

   3.0 }, { 6622,// 1 Giant's Codex

   3,

   8.0 }, { 960,// 1 Enchant Armor S

   1,

   8.0 }, { 9552,// 1 Fire Crystal

   1,

   8.0 }, { 9553,// 1 Water Crystal

   1,

   8.0 }, { 9556,// 1 Dark Crystal

   1,

   8.0 }, { 9557,// 1 Holy Crystal

   1,

   8.0 }, { 9554,// 1 Earth Crystal

   1,

   8.0 }, { 9555,// 1 Wind Crystal

   1,

   8.0 }, { 9546,// 1 Fire Stone

   2,

   20.0 }, { 9547,// 1 Water Stone

   2,

   20.0 }, { 9548,// 1 Earth Stone

   2,

   20.0 }, { 9549,// 1 Wind Stone

   2,

   20.0 }, { 9550,// 1 Dark Stone

   2,

   20.0 }, { 9551,// 1 Holy Stone

   2,

   100.0 }, };

 

private static final long VOTE_COMMAND_REUSE = 5 * 60 * 1000L; // 5 Minutes

private static final long VOTE_PENALTY = 12 * 60 * 60 * 1000L; // 12 Hours

 

public static final Map<Integer, Long> _votePlayerReuses = new ConcurrentHashMap<Integer, Long>();

public static final Map<String, Long> _accountPenalties = new ConcurrentHashMap<String, Long>();

public static final Map<String, Long> _ipPenalties = new ConcurrentHashMap<String, Long>();

public static final Map<String, Long> _hwidPenalties = new ConcurrentHashMap<String, Long>();

 

public RewardVote()

{

// If there is a set vote reward message, schedule it

if(!Config.VOTE_REWARD_MSG.isEmpty())

ThreadPoolManager.getInstance().scheduleAtFixedRate(new VoteAnnounceTask(), 5 * 60 * 1000, Config.ANNOUNCE_VOTE_DELAY * 1000);

 

// Restore from the db all the penalties of the votes, it doesn't matter if its 0. So we can do it only once at start

Connection con = null;

PreparedStatement statement = null;

ResultSet rset = null;

try

{

con = DatabaseFactory.getInstance().getConnection();

statement = con.prepareStatement("SELECT * FROM vote_system");

 

rset = statement.executeQuery();

while(rset.next())

{

final String value = rset.getString("value");

final long time = rset.getLong("penalty_time");

 

switch(rset.getInt("value_type"))

{

// Account Name

case 0:

{

_accountPenalties.put(value, time);

break;

}

// Ip Address

case 1:

{

_ipPenalties.put(value, time);

break;

}

// Hwid

case 2:

{

_hwidPenalties.put(value, time);

break;

}

}

}

}

catch(Exception e)

{}

}

 

@Override

public boolean useVoicedCommand(String command, Player activeChar, String params)

{

if(command.equalsIgnoreCase("vote"))

{

try

{

// No connection, no vote

if(activeChar.getNetConnection() == null)

return false;

 

if(!Config.ENABLE_VOTE)

{

activeChar.sendMessage("Voting is currently disabled!");

return false;

}

 

// Min lvl 40

if(activeChar.getLevel() < 40)

{

activeChar.sendMessage("You need to be at least level 40 to use this command.");

return false;

}

 

final long currentTime = System.currentTimeMillis();

 

// Synerge - Check if voting is not blocked. If a web connection ocurrs, then the vote will be block for everyone for 15 minutes

if(VoteRead._siteBlockTime >= currentTime)

{

activeChar.sendMessage("There are problems with the connection to the vote site, so it has been disabled for some minutes. Try again later");

return false;

}

 

// Check player vote reuse

if(activeChar.getAccessLevel() < 1 && _votePlayerReuses.containsKey(activeChar.getObjectId()))

{

if(_votePlayerReuses.get(activeChar.getObjectId()) > currentTime)

{

activeChar.sendMessage("You can use this command only once every 5 minutes.");

return false;

}

}

 

_votePlayerReuses.put(activeChar.getObjectId(), currentTime + VOTE_COMMAND_REUSE);

 

// Getting IP of client, here we will have to check for HWID when we have LAMEGUARD

final String IPClient = activeChar.getIP();

final String HWID = (activeChar.getHWID() != null ? activeChar.getHWID() : "");

 

// Check the penalties of the player to see if he can vote again

if(!checkPlayerPenalties(activeChar, IPClient, HWID, true))

return false;

 

// Return 0 if he didnt voted. Date when he voted on website

/*final long dateHeVotedOnWebsite = VoteRead.checkVotedIP(IPClient);

if(dateHeVotedOnWebsite < 1)

{

activeChar.sendMessage("To claim reward, you need to vote on all banners!");

return false;

}*/

 

if (!hasVoted(activeChar)) {

                    activeChar.sendMessage("To claim reward, you need to vote!");

                    return false;

                }

 

 

// Add the vote penalty to the player

addNewPlayerPenalty(activeChar, IPClient, HWID);

 

// Give the rewards

giveRewards(activeChar);

activeChar.sendMessage("Successfully rewarded.");

 

return true;

}

catch(Exception e)

{

e.printStackTrace();

}

}

return false;

}

 

// Thread to send to all players that didn't voted yet to vote for the server

protected static class VoteAnnounceTask implements Runnable

{

@Override

public void run()

{

if(Config.VOTE_REWARD_MSG.isEmpty())

return;

 

final Say2 announce = new Say2(0, ChatType.ANNOUNCEMENT, "", Config.VOTE_REWARD_MSG);

 

final Iterable<Player> world = GameObjectsStorage.getAllPlayersForIterate();

for(Player player : world)

{

if(player == null || player.getNetConnection() == null)

continue;

 

// No offline or store mode

if(player.isInStoreMode())

continue;

 

// If the player has an active penalty means that he already voted

if(!checkPlayerPenalties(player, player.getIP(), player.getHWID(), false))

continue;

 

player.sendPacket(announce);

}

}

}

 

/**

* Gives to the player all the vote rewards

*

* @param player

*/

protected static void giveRewards(Player player)

{

// First give the permanent item

Functions.addItem(player, PERMANENT_CATEGORY[0], PERMANENT_CATEGORY[1], "VoteReward Permanent");

 

// First give the vote main random reward

final int[] reward = getReward();

Functions.addItem(player, reward[0], reward[1], "VoteReward Main");

 

// Then give some random rewards

for(double[] item : RANDOM_CATEGORY)

{

if(Rnd.chance(item[2]))

{

Functions.addItem(player, (int) item[0], (long) item[1], "Vote Random Reward");

return;

}

}

}

 

/**

* Puts new penalties for the account name, ip and hwid of the player after he succesfully voted

*

* @param activeChar

* @param IPClient

* @param HWID

*/

protected static void addNewPlayerPenalty(Player activeChar, String IPClient, String HWID)

{

final long newPenalty = System.currentTimeMillis() + VOTE_PENALTY;

_accountPenalties.put(activeChar.getAccountName(), newPenalty);

_ipPenalties.put(IPClient, newPenalty);

_hwidPenalties.put(HWID, newPenalty);

 

// Also store the penalties in the db

Connection con = null;

PreparedStatement statement = null;

try

{

con = DatabaseFactory.getInstance().getConnection();

statement = BatchStatement.createPreparedStatement(con, "REPLACE INTO vote_system(value_type, value, penalty_time) VALUES (?, ?, ?)");

final String[] values = new String[] { activeChar.getAccountName(), IPClient, HWID };

for(ValueType type : ValueType.values())

{

statement.setInt(1, type.ordinal());

statement.setString(2, values[type.ordinal()]);

statement.setLong(3, newPenalty);

statement.addBatch();

}

 

statement.executeBatch();

}

catch(Exception e)

{}

}

 

/**

* @param activeChar

* @param IPClient

* @param HwID

* @param sendMessage

* @return Returns true if the player doesn't have an active penalty after voting

*/

protected static boolean checkPlayerPenalties(Player activeChar, String IPClient, String HwID, boolean sendMessage)

{

final long accountPenalty = checkPenalty(ValueType.ACCOUNT_NAME, activeChar.getAccountName());

final long ipPenalty = checkPenalty(ValueType.IP_ADRESS, IPClient);

final long hwidPenalty = checkPenalty(ValueType.HWID, HwID);

 

final int penalty = (int) ((Math.max(accountPenalty, Math.max(ipPenalty, hwidPenalty)) - System.currentTimeMillis()) / (60 * 1000L));

 

if(penalty > 0)

{

if(sendMessage)

{

if(penalty > 60)

{

activeChar.sendMessage("You can vote only once every 12 hours. You still have to wait " + (penalty / 60) + " hours " + (penalty % 60) + " minutes.");

}

else

{

activeChar.sendMessage("You can vote only once every 12 hours. You still have to wait " + penalty + " minutes.");

}

}

return false;

}

return true;

}

 

/**

* @param type

* @param value

* @return Returns the penalty of a particular type and value if it exists

*/

private static long checkPenalty(ValueType type, String value)

{

switch(type)

{

case ACCOUNT_NAME:

{

if(_accountPenalties.containsKey(value))

return _accountPenalties.get(value);

break;

}

case IP_ADRESS:

{

if(_ipPenalties.containsKey(value))

return _ipPenalties.get(value);

break;

}

case HWID:

{

if(_hwidPenalties.containsKey(value))

return _hwidPenalties.get(value);

break;

}

}

 

return 0;

}

 

public static int[] getReward()

{

return MISC_CATEGORY[Rnd.get(MISC_CATEGORY.length)];

}

 

@Override

public void onLoad()

{

VoicedCommandHandler.getInstance().registerVoicedCommandHandler(this);

}

 

@Override

public void onReload()

{

//

}

 

@Override

public void onShutdown()

{

//

}

 

@Override

public String[] getVoicedCommandList()

{

return COMMANDS_LIST;

}

 

// New Topzone Vote Reward System (API)

 

public String getApiEndpoint(Player player) {

        return String.format("https://api.l2topzone.com/v1/vote?token=%s&ip=%s", Config.VOTE_TOPZONE_APIKEY, player.getIP());

    }

 

    public boolean hasVoted(Player player) {

        try {

            String endpoint = getApiEndpoint(player);

            if (endpoint.startsWith("err"))

                return false;

            String voted = grabValue(getApiResponse(endpoint), "\"isVoted\":", ",\"serverTime\"");

            return tryParseBool(voted);

        } catch (Exception e) {

            player.sendMessage("Something went wrong. Please try again later.");

            e.printStackTrace();

        }

        return false;

    }

 

    public boolean tryParseBool(String bool) {

        if (bool.startsWith("1"))

            return true;

 

        CharSequence cs = "voteTime";

        if (bool.contains(cs)) {

            //System.out.println("Contains \"voteTime\"");

            String newbool = bool.substring(0, 4);

            //System.out.println("Bool to pass: " + newbool);

            return Boolean.parseBoolean(newbool);

        }

 

        return Boolean.parseBoolean(bool.trim());

    }

 

    public String getApiResponse(String endpoint) {

        StringBuilder stringBuilder = new StringBuilder();

 

        try {

            URL url = new URL(endpoint);

            HttpURLConnection connection = (HttpURLConnection) url.openConnection();

            connection.addRequestProperty("User-Agent", "Mozilla/4.76");

            connection.setRequestMethod("GET");

 

            connection.setReadTimeout(5 * 1000);

            connection.connect();

 

            try (BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream()))) {

                String line = null;

                while ((line = reader.readLine()) != null) {

                    stringBuilder.append(line + "\n");

                }

            }

            connection.disconnect();

            System.out.println(stringBuilder.toString());//

            return stringBuilder.toString();

        } catch (Exception e) {

            System.out.println("Something went wrong in VoteBase::getApiResponse");

            e.printStackTrace();

            return "err";

        }

    }

 

private static String grabValue(String str, String open, String close) {

        final int INDEX_NOT_FOUND = -1;

        if (str == null || open == null || close == null) {

            return null;

        }

        int start = str.indexOf(open);

        if (start != INDEX_NOT_FOUND) {

            int end = str.indexOf(close, start + open.length());

            if (end != INDEX_NOT_FOUND) {

                return str.substring(start + open.length(), end);

            }

        }

        return null;

    }

}

 

 

 

 

 

 

its this file for votes

  • 0
Posted (edited)

Hello, 

the error is found in the second line of your error...

 

java.io.IOException: Server returned HTTP response code: 403 for URL: https://api.l2topzon...p=85.206.147.64

 

Contact xzone on l2topzone.com and you will solve the problem.

 

PS. problem was already solved. Topic can be close

Edited by xzone

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now


  • Posts

    • Short version: took Vanganth's classic Interlude pack as the starting point and rebuilt the rest on top of the Classic Secret of Empire client (protocol 166).   Stuff that got reworked, but not limited to: The AI is the one I'm proudest of. ~600 individual NPC behavior scripts, all parsed and verified against retail. Aggro range, follow logic, target switching, idle pattern, social actions. All behaving the way they do on the official server, not the way "close enough" L2J packs usually do. ~2,5k skills loaded, full enchant tree, soul crystal absorption rules. Every formula in Formulas.java and StatFunctions.java got rewritten to match retail. Geodata is not excluded. NPCs/spawns, 6k+ templates, 28k+ spawns, all raid bosses, all the standard event content (Olympiad, Seven Signs with Festival of Darkness, Castle Sieges, Clan Hall stuff, Fortress sieges, Dimensional Rift, Four Sepulchers, Cardiff Invasion). all quest scripts. The engine itself runs both Interlude (protocol 740–770) and Secret of Empire (166) off the same codebase, opcode-mapped. The thing I want to be clear about: this is as close to PTS as L2J realistically gets. Most, not all, L2J packs out there have approximated formulas, stub AI, patchy geodata, hardcoded raid scripts. We didn't take that route.   When can you actually play it:   Server most likely opens next year. If I get more dev time over the coming months a beta by end of this year is realistic, possibly earlier. No promises, depends on how much time I can put in.   The server is already playable since the most important work is done. So if you'd like to collaborate, you'll be able to test it fairly soon. The server files are really good. You might even want to use them for your own server if we decide to go that route.   Server tiers being considered: Low-rate retail - the flagship, most likely first server. Strict PTS. Mid-to-high rate, minimal customs - almost certainly happening as a second server. More accessible but the engine integrity stays. Old L2Finest pride-style (high-rate, heavy customs, the original flavor some of you remember) - very low chance and definitely not soon. It's on the list but well behind the first two.   That's where we are. More updates as open beta gets closer.
    • Maybe some NPC is causing the problem for you, if you don't have a custom map, keep a backup of the database and remove the npc 1-1 to see where the problem is coming from. A custom npc is probably the problem. I had this problem before and searched a lot to find it.
    • 🔥 L2 REDMOON – INTERLUDE 🔥 🆕 Newly opened – Full players joining!   🌐 Discord: https://discord.gg/5PvP5BrGg 💬 Website: https://L2Redmoon.com   ⚔️ Progressive Server • Classic • No Pay To Win   📊 Stage System (Progressive): 🔹 Stage 1: Lv 1–42 | XP x3 | 2 weeks 🔹 Stage 2: Lv 43–60 | XP x4 | 2 weeks 🔹 Stage 3: Lv 61–75 | XP x5 | 10 days 🔹 Endgame: Lv 75–80 | XP x10   💰 General Rates: 💰 Adena x8 💎 Spoil x3 📦 Drop x3 📜 Quest x3   🚫 NO PAY TO WIN ⭐ Premium +30% (Optional) 🛡️ Safe +3 ⚔️ Max +16   🏆 Auto reward max for clans   🔥 ENDGAME – Final competitive phase   @everyone
    • @SkyLordwhats so funny nigga
  • Topics

×
×
  • Create New...

Important Information

This community uses essential cookies to function properly. Non-essential cookies and third-party services are used only with your consent. Read our Privacy Policy and We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue..