Jump to content
  • 0

Save Votes On Database


Question

Posted

Hello , Im tryning to make vote systems save the votes into the database , and load them after restart

 

topzone system

package com.l2jserver.gameserver.instancemanager;
    
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.URL;
import java.net.URLConnection;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.logging.Level;
import java.util.logging.Logger;

import com.l2jserver.Config;
import com.l2jserver.L2DatabaseFactory;
import com.l2jserver.gameserver.ThreadPoolManager;
import com.l2jserver.gameserver.model.L2World;
import com.l2jserver.gameserver.model.actor.instance.L2PcInstance;
import com.l2jserver.gameserver.network.clientpackets.Say2;
import com.l2jserver.gameserver.network.serverpackets.CreatureSay;
import com.l2jserver.gameserver.network.serverpackets.ExShowScreenMessage;
import com.l2jserver.gameserver.util.Broadcast;
    
public class TzVoteRewardManager
{
   private static Logger _log = Logger.getLogger(TzVoteRewardManager.class.getName());
       
   private static final String http = Config.TOPZONE_URL;
   private static final int initialCheck  = 1 * 1000;
   private static final int delayForCheck = 10 * 60000;
   private static final int itemId    = Config.TOPZONE_REWARD_ID ;
   private static final int itemCount = Config.TOPZONE_REWARD_COUNT ;
   private static final int votesRequiredForReward = 10;

   private static List<String> _ips = new ArrayList<String>();
   private static int lastVoteCount = 0;
      
   private TzVoteRewardManager()
   {
	   if(!Config.ENABLE_TOPZONE)
		   return;
	   _log.info("----------------------------------------------------");
       _log.info("AutoVoteRewardManager: Vote reward system For TZ initiated.");
       _log.info("----------------------------------------------------");
           load();  
       ThreadPoolManager.getInstance().scheduleGeneralAtFixedRate(new AutoReward(), initialCheck, delayForCheck);
   }
      
   private class AutoReward implements Runnable
   {
       public void run()
       {
           int votes = getVotes();
           _log.info("AutoVoteRewardManager For TZ : We now have " + votes + "/"+(getLastVoteCount()+votesRequiredForReward)+" vote(s). Next check in "+(delayForCheck/1000)+" sec.");

           if (votes >= getLastVoteCount() + votesRequiredForReward)
           {
               Collection<L2PcInstance> pls = L2World.getInstance().getAllPlayers().values();
               {
                   for (L2PcInstance onlinePlayer : pls)
                   {
                       if (onlinePlayer.isOnline() && !onlinePlayer.getClient().isDetached() && !_ips.contains(onlinePlayer.getClient().getConnection().getInetAddress().getHostAddress()))
                       {
                              _log.warning("Hello Moto!Giving reward to character "+onlinePlayer.getName());
                               onlinePlayer.addItem("vote_reward", itemId, itemCount, onlinePlayer, true);
                               onlinePlayer.sendPacket(new ExShowScreenMessage("You Have bean Rewarded For topzone votes!", 5000));
                               onlinePlayer.sendPacket(new CreatureSay(1, Say2.PARTY, "SYSTEM", "You Have bean Rewarded For topzone votes!"));
                           _ips.add(onlinePlayer.getClient().getConnection().getInetAddress().getHostAddress());
                       }
                   }
               }
               _log.info("AutoVoteRewardManager: Reward for votes now!");
               Broadcast.toAllOnlinePlayers(new CreatureSay(1, Say2.CRITICAL_ANNOUNCE, "SYSTEM", "Topzone SYSTEM:" + " Thanks For Vote You Have Been Rewarded!"));
               setLastVoteCount(getLastVoteCount() + votesRequiredForReward);
           }
                
           if (getLastVoteCount() == 0)
           {
               setLastVoteCount(votes);
           }
           else if ((getLastVoteCount() + votesRequiredForReward) - votes > votesRequiredForReward || votes > (getLastVoteCount() + votesRequiredForReward))
           {
               setLastVoteCount(votes);
           }
              
           Broadcast.toAllOnlinePlayers(new CreatureSay(1, Say2.CRITICAL_ANNOUNCE, "SYSTEM", "Topzone SYSTEM:" + " We have " + votes + " Vote(s). || Next Reward On " + (getLastVoteCount()+votesRequiredForReward) + " Votes."));
           _ips.clear();
       }
   }
      
   private int getVotes()
   {
       URL url = null;
       InputStreamReader isr = null;
       BufferedReader in = null;
       try
       {
           url = new URL(http);
           URLConnection con = url.openConnection();
           con.addRequestProperty("User-Agent", "Mozilla/4.76"); 
           isr = new InputStreamReader(con.getInputStream());
           in = new BufferedReader(isr);
           String inputLine;
           while ((inputLine = in.readLine()) != null)
           {
               // for top-zone
        	   if (inputLine.contains("Votes:"))
        	   {
        	    	  return  Integer.parseInt(inputLine.split(">")[3].replace("</div", ""));
        	      }
           }
       }
       catch (IOException e)
       {
           _log.warning("AutoVoteRewardHandler: "+e);
       }
       finally
       {
           try
           {
               in.close();
           }
           catch (IOException e)
           {}
           try
           {
               isr.close();
           }
           catch (IOException e)
           {}
       }
       return 0;
   }
      
   private void setLastVoteCount(int voteCount)
   {
       lastVoteCount = voteCount;
   }
      
   private static int getLastVoteCount()
   {
       return lastVoteCount;
   }
   
   private void load()
     {
         int votes = 0;
         Connection con = null;
         try
         {
             con = L2DatabaseFactory.getInstance().getConnection();
             PreparedStatement statement = con.prepareStatement("SELECT vote FROM votes LIMIT 1");
             ResultSet rset = statement.executeQuery();
   
             while (rset.next())
             {
                 votes = rset.getInt("vote");
             }
             rset.close();
             statement.close();
         }
         catch (Exception e)
         {
             _log.log(Level.WARNING, "data error on vote: ", e);
         }
         finally
         {
             L2DatabaseFactory.close(con);
         }
         
         setLastVoteCount(votes);
     }
     
     public void save()
     {
         Connection con = null;
         try
         {
             con = L2DatabaseFactory.getInstance().getConnection();
             PreparedStatement statement = con.prepareStatement("UPDATE votes SET vote = ? WHERE id=1");
             statement.setInt(1, getLastVoteCount());
             statement.execute();
             statement.close();
         }
         catch (Exception e)
         {
             _log.log(Level.WARNING, "data error on vote: ", e);
         }
         finally
         {
             L2DatabaseFactory.close(con);
         }
     }
  
   public static TzVoteRewardManager getInstance()
   {
       return SingletonHolder._instance;
   }
      
   @SuppressWarnings("synthetic-access")
   private static class SingletonHolder
   {
       protected static final TzVoteRewardManager _instance = new TzVoteRewardManager();
   }
}

shutdown.java

		TzVoteRewardManager.getInstance().save();
		_log.info("Vote Reward Manager TZ: Data saved For Topzone.");

votes.sql

-- ----------------------------
-- Table structure for votes
-- ----------------------------
DROP TABLE IF EXISTS `votes`;
CREATE TABLE `votes` (
  `id` int(6) NOT NULL,
  `vote` int(6) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of votes
-- ----------------------------

when server restarting i can see the msg ive add about saving.. but does not saving really :P Kinda strange .. any idea? No errors at all , system is working , rewards for all , ip check etc , just not saving like ti should..

12 answers to this question

Recommended Posts

  • 0
Posted

Not exactly. If the table is completely empty, obviously there's nothing to UPDATE.

his table hasn't been empty any time so the problem is not there.
  • 0
Posted (edited)

Its outdated, plus can be work for topzone + hopzone + reward ? or i have to make 2 different instaces , so i can have both running? And i dont see ip protection :/

 

And one more , This one need same database for gameserver and login.. I want seperated .. its really stupid to merge databases for many ressons !

Edited by ČυяŞŀŅğ
  • 0
Posted (edited)

oh i got this 

http://imageshack.us/f/203/tkmu.jpg/

 

29090 was the votes of the one site , this means votes () can see the votes.. So the only poblem is writing this into the sql right? and load after

 

 

edit , i checked load , its working , i write it manualy inside database , id 1 and votes 40000 , and when server loaded i saw next reward at 40010.

Edited by ČυяŞŀŅğ
  • 0
Posted (edited)

You are missing INSERT statement. Your save() method is incorrect.

 

You can do it with 2 ways, either way is fine (save() method):

1) First DELETE the entire table and then INSERT the votes.

2) Make a boolean on load() to see if votes exist or not**. If boolean is false, use INSERT statement, if boolean is true, use UPDATE statement.

 

Also that id field is completely unnecessary.

 

** You can do that, by going to load() method and add the boolean to this line:

while (rset.next())
{
    _votesRegistered = true;
    votes = rset.getInt("vote");
}

Also change while (rset.next()) to if (rset.next()), a loop there is also not necessary.

Edited by Versus
  • 0
Posted

Btw , this code was working before , i just changed the names from getting and loading from database from votes , to votetz etc , because i made 2 similar system to work together.. and samewere there i lost it i guess.. anyway :) I need You to explain this in noob language

     public void save()
     {
         Connection con = null;
         try
         {
             con = L2DatabaseFactory.getInstance().getConnection();
             PreparedStatement statement = con.prepareStatement("UPDATE votes SET vote = ? ");
             statement.setInt(1, getLastVoteCount());
             statement.execute();
             statement.close();
             System.out.println(getLastVoteCount()); 
         }
         catch (Exception e)
         {
             _log.log(Level.WARNING, "data error on vote: ", e);
         }
         finally
         {
             L2DatabaseFactory.close(con);
         }
     }
  

i removed the id shit you said :D

   private void load()
     {
         int votes = 0;
         Connection con = null;
         try
         {
             con = L2DatabaseFactory.getInstance().getConnection();
             PreparedStatement statement = con.prepareStatement("SELECT vote FROM votes LIMIT 1");
             ResultSet rset = statement.executeQuery();
             System.out.println(getLastVoteCount()); 
              if (rset.next())
             {
                _votesRegistered = true;
                votes = rset.getInt("vote");
             }
             rset.close();
             statement.close();
         }
         catch (Exception e)
         {
             _log.log(Level.WARNING, "data error on vote: ", e);
         }
         finally
         {
             L2DatabaseFactory.close(con);
         }
         
         setLastVoteCount(votes);
     }

and this one like you said :D I i think save part still incomplete xD i didnt understand :/

  • 0
Posted

the save() method seems fine... I used to have exactly the same and it's working, the "UPDATE" thingy is fine, you don't need to delete and insert...

 

the only thing that comes to my mind is that you're calling wrong the "save()" method when the server is restarting... but that would be weird... try changing the method by "public static void save()" and then access with "TzVoteRewardManager.save()", I feel like it's stupid but I don't see any problem in the whole code..

  • 0
Posted (edited)

and this one like you said :D I i think save part still incomplete xD i didnt understand :/

You only did one part of what i said. Should be like that on save() method

 

if (_votesRegistered)

      statement = con.prepareStatement("UPDATE ...........");

else

      statement = con.prepareStatement("INSERT ...........");

 

Please re-read my previous post to understand better what i meant.

 

 

the save() method seems fine... I used to have exactly the same and it's working, the "UPDATE" thingy is fine, you don't need to delete and insert...

 

the only thing that comes to my mind is that you're calling wrong the "save()" method when the server is restarting... but that would be weird... try changing the method by "public static void save()" and then access with "TzVoteRewardManager.save()", I feel like it's stupid but I don't see any problem in the whole code..

Not exactly. If the table is completely empty, obviously there's nothing to UPDATE.

Edited by Versus

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

    • Hey Dexters! Https://lineage2dex.com SKADI server starting TODAY! ✅ On 18:00 (UTC +2) We allow you to login for create character! To restrict your name and transfer ToDs/Starter packs in game. Make it before start! On start, we can have problems with WEB! It is IMPORTANT to prepare everything for starting the game RIGHT NOW, do not postpone for later, during the opening there may be problems with the web part of the project and you simply can not register. ## [ - REGISTRATION AND FILES](https://lineage2dex.com/en/start) ✨ Get a +15% bonus on all TOD orders! The bonus is active until February 1st, 23:00 and also applies to UNION. ✅ What you need to know at the start: ➡️ All Epic Raid Bosses dead on start. Re-spawn time you can check in game ALT+B Raid tab ➡️ All other RBs (for difficult 1 location) alive on server start (including Sub and Nobl RB) ➡️ Max enchant for items +10, this limits will be change with server time ➡️ Difficulty 1 locations are available ➡️ Locations drop Basic and Advanced tier resources, allowing you to craft B and A grade equivalent gear ➡️ School of Dark Arts — PvP zone with x5 drop. Its intance Zone, to enter it you need make TP from GateKeeper. If you will teleport on it by map, you will go on regular zone, not pvp ➡️ Only B-grade equivalent equipment is available for purchase (common, its dont have durability) ➡️ Tier 1 talents are available to learn ➡️ Talent Point Shop is available [ - Roadmap](https://wiki.lineage2dex.com/road-map/en) [ - Basic server description](https://wiki.lineage2dex.com/general-description-skadi-x100/en) Thank you for participating in the beta! All players who spent more than 1 hour on the beta server will receive useful items for autofarming and equipment repair. The rewards will be granted to the first character on the same account that participated in the beta. All items will be placed in the Quest Inventory. Good luck everyone! And have a fun on new Skadi server!
    • ## [1.5.1] - 2026-01-30   ### 🐛 Bug Fixes - **Top Voters**: Top voters list now loads correctly for inactive servers (previously showed "Server not found"). - **View Counter**: Server info page view count now records correctly for inactive servers.   ### 🔄 Improvements - **My Servers – Hide/Active**: The hide/active toggle now works correctly and is only shown when the server is approved (active) by an admin. Owner hide/show is separate from admin status. Toggling no longer causes a full page refresh. - **Accessibility**: Form fields across the site now have proper labels and IDs for screen readers and autofill — server info edit form, add server form, My Servers edit, Admin Panel (Email, Vote System, pricing, filters, logs), and related inputs.
    • LIVE VERIFICATION? SUMSUB? “IMPOSSIBLE”? ▪ Spoiler: it is possible — if you know who to work with. A client came in with a task to pass **live verification** on **WantToPay**, a Telegram virtual card service. On the platform side — **Sumsub**: liveness check, SMS, manual review. “Fast” and “by eye” simply don’t work here. › What was done: → analyzed the verification scenario and Sumsub requirements → built the correct flow: phone number, email, timing → **completed live verification remotely, without account handover** → handled SMS and confirmation codes → brought the process to final approval ▪ Result: → verification passed → access granted → no flags or repeat requests ▪ Live verification is not luck. It’s scenario-based preparation — not hope. › TG: @mustang_service ( https:// t.me/ mustang_service ) › Channel: Mustang Service ( https:// t.me/ +6RAKokIn5ItmYjEx ) *All data is published with the client’s consent.* #verification #sumsub #livecheck #kyc #case
    • IMPORTANT INFO: In a few days, I will switch to completely new code, written from scratch with a new download system, patch building and management system. The Updater will become true 2026 code with "foolproof systems". I'm going to create a Discord server for customers to request new ideas and features. FIRST CUSTOMERS ARE ALREADY USING THE NEW UPDATER ON LIVE SERVERS! Watch this topic for upcoming info because the new updater is around the corner! Yes, you can still use self-update on the previous updater! No, the new updater won't be compatible with the old patch system! A new build is required, but players who already have game files won't have to download the entire patch again! New templates and updates to existing templates are coming soon! Sneak peek:  
  • 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..