Jump to content

Recommended Posts

Posted

Hello...recently i was searching on some forums and i found a very interesting tool for lineage2 servers.

This is a Vote point system that whould impulse the players to vote for a reward...

Java scrips are made by "bubulina" .

 

the script below has only the java files that we need to implement into the server side ..

also if anyone whould share the script needed to implement into the websites whould be great.

 

All the credits for that script goes to "bubulina" ...Have a nice day!

 

This share is a 'simple' core mod to inspirate your players to vote to the server. I added a field to the characters table in the servers SQL. With Navicat (design table/ add field) the properties are:

 

Name: 'vote'  Type: 'int' Lenght: 10  Decimals: 0 Allow null:[ ] Default: 0 Unsigned: [x]

 

 

After that apply the patch that i attached. This contains the diff file and 2 java files wich you have to copy to handler/voicedcommandhandlers/. After that compile the server core and you're done.

You have to make a PHP script for your servers homepage for increase the character's vote field if he voted. In the game use the .vote voice command to see how many vote points you have and .change to change theese points to Glittering Medal. You can change the reward item-s id in VoteChange.java so you can give anything you want for the vote points. I use the Glittering Medal with a simple multisell NPC.

Diff file:

 

Index: D:/Eclipse/Core Version 1.2.6/src/main/java/com/l2jfree/gameserver/model/actor/instance/L2PcInstance.java
===================================================================
--- D:/Eclipse/Core Version 1.2.6/src/main/java/com/l2jfree/gameserver/model/actor/instance/L2PcInstance.java (revision 4875)
+++ D:/Eclipse/Core Version 1.2.6/src/main/java/com/l2jfree/gameserver/model/actor/instance/L2PcInstance.java (working copy)
@@ -267,8 +267,8 @@
 private static final String DELETE_SKILL_SAVE    = "DELETE FROM character_skills_save WHERE charId=? AND class_index=?";

 // Character Character SQL String Definitions:
- private static final String UPDATE_CHARACTER    = "UPDATE characters SET level=?,maxHp=?,curHp=?,maxCp=?,curCp=?,maxMp=?,curMp=?,face=?,hairStyle=?,hairColor=?,heading=?,x=?,y=?,z=?,exp=?,expBeforeDeath=?,sp=?,karma=?,pvpkills=?,pkkills=?,rec_have=?,rec_left=?,clanid=?,race=?,classid=?,deletetime=?,title=?,accesslevel=?,online=?,isin7sdungeon=?,clan_privs=?,wantspeace=?,base_class=?,onlinetime=?,in_jail=?,jail_timer=?,newbie=?,nobless=?,pledge_rank=?,subpledge=?,last_recom_date=?,lvl_joined_academy=?,apprentice=?,sponsor=?,varka_ketra_ally=?,clan_join_expiry_time=?,clan_create_expiry_time=?,banchat_timer=?,char_name=?,death_penalty_level=?,trust_level=? WHERE charId=?";
- private static final String RESTORE_CHARACTER    = "SELECT account_name, charId, char_name, level, maxHp, curHp, maxCp, curCp, maxMp, curMp, face, hairStyle, hairColor, sex, heading, x, y, z, exp, expBeforeDeath, sp, karma, pvpkills, pkkills, clanid, race, classid, deletetime, cancraft, title, rec_have, rec_left, accesslevel, online, char_slot, lastAccess, clan_privs, wantspeace, base_class, onlinetime, isin7sdungeon, in_jail, jail_timer, banchat_timer, newbie, nobless, pledge_rank, subpledge, last_recom_date, lvl_joined_academy, apprentice, sponsor, varka_ketra_ally, clan_join_expiry_time,clan_create_expiry_time,charViP,death_penalty_level,trust_level FROM characters WHERE charId=?";
+ private static final String UPDATE_CHARACTER    = "UPDATE characters SET level=?,maxHp=?,curHp=?,maxCp=?,curCp=?,maxMp=?,curMp=?,face=?,hairStyle=?,hairColor=?,heading=?,x=?,y=?,z=?,exp=?,expBeforeDeath=?,sp=?,karma=?,pvpkills=?,pkkills=?,rec_have=?,rec_left=?,clanid=?,race=?,classid=?,deletetime=?,title=?,accesslevel=?,online=?,isin7sdungeon=?,clan_privs=?,wantspeace=?,base_class=?,onlinetime=?,in_jail=?,jail_timer=?,newbie=?,nobless=?,pledge_rank=?,subpledge=?,last_recom_date=?,lvl_joined_academy=?,apprentice=?,sponsor=?,varka_ketra_ally=?,clan_join_expiry_time=?,clan_create_expiry_time=?,banchat_timer=?,char_name=?,death_penalty_level=?,trust_level=?,vote=? WHERE charId=?";
+ private static final String RESTORE_CHARACTER    = "SELECT account_name, charId, char_name, level, maxHp, curHp, maxCp, curCp, maxMp, curMp, face, hairStyle, hairColor, sex, heading, x, y, z, exp, expBeforeDeath, sp, karma, pvpkills, pkkills, clanid, race, classid, deletetime, cancraft, title, rec_have, rec_left, accesslevel, online, char_slot, lastAccess, clan_privs, wantspeace, base_class, onlinetime, isin7sdungeon, in_jail, jail_timer, banchat_timer, newbie, nobless, pledge_rank, subpledge, last_recom_date, lvl_joined_academy, apprentice, sponsor, varka_ketra_ally, clan_join_expiry_time,clan_create_expiry_time,charViP,death_penalty_level,trust_level,vote FROM characters WHERE charId=?";
    
 // Character Subclass SQL String Definitions:
 private static final String RESTORE_CHAR_SUBCLASSES   = "SELECT class_id,exp,sp,level,class_index FROM character_subclasses WHERE charId=? ORDER BY class_index ASC";
@@ -289,7 +289,9 @@
 private static final String RESTORE_CHAR_RECOMS    = "SELECT charId,target_id FROM character_recommends WHERE charId=?";
 private static final String ADD_CHAR_RECOM     = "INSERT INTO character_recommends (charId,target_id) VALUES (?,?)";
 private static final String DELETE_CHAR_RECOMS    = "DELETE FROM character_recommends WHERE charId=?";
-
+ private static final String RESTORE_CHAR_VOTE    = "SELECT vote FROM characters WHERE charId=?";
+ private static final String UPDATE_CHAR_VOTE   = "UPDATE characters SET vote=? WHERE charId=?";
+ 
 // Character Transformation SQL String Definitions:
 private static final String SELECT_CHAR_TRANSFORM   = "SELECT transform_id FROM characters WHERE charId=?";
 private static final String UPDATE_CHAR_TRANSFORM   = "UPDATE characters SET transform_id=? WHERE charId=?";
@@ -408,6 +410,10 @@

 /** The number of player killed during a PvP (the player killed was PvP Flagged) */
 private int        _pvpKills;
+ 
+ /** The number of the player's votes */
+ 
+ private int        _voteCount;

 /** The PK counter of the L2PcInstance (= Number of non PvP Flagged player killed) */
 private int        _pkKills;
@@ -2****6 +2107,19 @@
  return _pvpKills;
 }

+ 
+ public int getVoteCount()
+ {
+  restoreVote();
+  return _voteCount;
+ }
+ 
+ public void setVoteCount(int vote)
+ {
+  _voteCount = vote;
+  updateVote();
+ }
+ 
 /**
 * Set the the PvP Kills of the L2PcInstance (Number of player killed during a PvP).<BR><BR>
 */
@@ -6794,7 +6813,8 @@
    player.setAllianceWithVarkaKetra(rset.getInt("varka_ketra_ally"));
    player.setDeathPenaltyBuffLevel(rset.getInt("death_penalty_level"));
    player.setTrustLevel(rset.getInt("trust_level"));
-
+    player.setVoteCount(rset.getInt("vote"));
+    
    // Add the L2PcInstance object in _allObjects
    // L2World.getInstance().storeObject(player);

@@ -7030,6 +7050,57 @@
  finally { try { if (con != null) con.close(); } catch (SQLException e) { e.printStackTrace(); } }
 }

+ 
+ private void restoreVote()
+  {
+   Connection con = null;
+ 
+   try
+   {
+    con = L2DatabaseFactory.getInstance().getConnection(con);
+    PreparedStatement statement = con.prepareStatement(RESTORE_CHAR_VOTE);
+    statement.setInt(1, getObjectId());
+    ResultSet rset = statement.executeQuery();
+    while (rset.next())
+    {
+     _voteCount=(rset.getInt("vote"));
+    }
+ 
+    rset.close();
+    statement.close();
+   }
+   catch (Exception e)
+   {
+    _log.error("could not restore vote: ", e);
+   }
+   finally { try { if (con != null) con.close(); } catch (SQLException e) { e.printStackTrace(); } }
+  }
+ 
+ 
+ private void updateVote()
+ {
+
+
+
+   Connection con = null;
+   try
+   {
+    con = L2DatabaseFactory.getInstance().getConnection(con);
+    PreparedStatement statement = con.prepareStatement(UPDATE_CHAR_VOTE);
+    statement.setInt(1, _voteCount);
+    statement.setInt(2, getObjectId());
+
+    statement.execute();
+    statement.close();
+   }
+   catch (Exception e)
+   {
+    _log.fatal("Vote insert info: " + e);
+   }
+         finally { try { if (con != null) con.close(); } catch (SQLException e) { e.printStackTrace(); } }
+  }
+ 
+ 
 /**
 * Store recipe book data for this L2PcInstance, if not on an active sub-class.
 */
@@ -7203,7 +7274,8 @@
   statement.setString(49, getName());
   statement.setLong(50, getDeathPenaltyBuffLevel());
   statement.setLong(51, getTrustLevel());
-   statement.setInt(52, getObjectId());
+   statement.setInt(52, getVoteCount());
+   statement.setInt(53, getObjectId());
   statement.execute();
   statement.close();
  }
Index: D:/Eclipse/Core Version 1.2.6/src/main/java/com/l2jfree/gameserver/handler/VoicedCommandHandler.java
===================================================================
--- D:/Eclipse/Core Version 1.2.6/src/main/java/com/l2jfree/gameserver/handler/VoicedCommandHandler.java (revision 4875)
+++ D:/Eclipse/Core Version 1.2.6/src/main/java/com/l2jfree/gameserver/handler/VoicedCommandHandler.java (working copy)
@@ -48,6 +48,8 @@
  registerVoicedCommandHandler(new CastleDoors());
  registerVoicedCommandHandler(new Hellbound());
  registerVoicedCommandHandler(new VersionInfo());
+  registerVoicedCommandHandler(new VoteCount());
+  registerVoicedCommandHandler(new VoteChange());
  if (Config.ALLOW_WEDDING)
  {
   registerVoicedCommandHandler(new Wedding());

 

 

handler/voicedcommandhandlers/VoteChange.java

 

package com.l2jfree.gameserver.handler.voicedcommandhandlers;
import com.l2jfree.gameserver.handler.IVoicedCommandHandler;
import com.l2jfree.gameserver.model.actor.instance.L2PcInstance;
/** 
* @author Rizel
* 
*/
public class VoteChange  implements IVoicedCommandHandler
{
private static final String[] VOICED_COMMANDS =
            { "change" };
public boolean useVoicedCommand(String command, L2PcInstance activeChar, String target)
{
 if (command.startsWith("change"))
 {
  if (activeChar.getVoteCount() == 0)
  {
   activeChar.sendMessage("You don't have any vote points.");
   return true;   
  }
  else
  {
  activeChar.addItem("Loot", 6393, activeChar.getVoteCount(), activeChar, true);
  activeChar.sendMessage("You changed " + activeChar.getVoteCount() + " vote points to Medal!");
  activeChar.setVoteCount(0);
  return true;
  }
 }
 return false;
}
public String[] getVoicedCommandList()
{
 return VOICED_COMMANDS;
}
}

 

handler/voicedcommandhandlers/VoteCount.java

 

package com.l2jfree.gameserver.handler.voicedcommandhandlers;
import com.l2jfree.gameserver.handler.IVoicedCommandHandler;
import com.l2jfree.gameserver.model.actor.instance.L2PcInstance;
/** 
* @author Rizel
* 
*/
public class VoteCount  implements IVoicedCommandHandler
{
private static final String[] VOICED_COMMANDS =
            { "vote" };
public boolean useVoicedCommand(String command, L2PcInstance activeChar, String target)
{
 if (command.startsWith("vote"))
 {
  activeChar.sendMessage("Your vote points: " + activeChar.getVoteCount());
  return true;
 }
 return false;
}
public String[] getVoicedCommandList()
{
 return VOICED_COMMANDS;
}
}

 

btw bubulina = skanners

Posted

Lol, stealing a job claiming it as yours?

 

That was made by rizel half year ago. -1 karma & locked.

Guest
This topic is now closed to further replies.
  • Posts

    • how do I make it so that you only deal damage to a mob if you have the right items equipped, like jewels, belt, underwear, bracelet, so if you don't have one of those items equipped, you don't deal any damage to the mob thanks
    • I always welcome bug reports and never ban ppl - until proven leaker - not sure where the "arrogant" part comes from, I would like to know what exactly let you think that (quote me please, and not 12y old quotes as the other frog meme dude). I request bug reports to be properly detailed, otherwise it's a waste of time. Other than that, I don't see where I have been arrogant. I got proper discussions with many ppl, not sure why you wouldn't be one of them.   I got 76 bug reports in my list (21 on forums, 55 on gitlab).   I have a single bug report regarding lvl 4 clan quest, which has to be tested since it's not even clear about what is supposed to be broken. Seven Signs was never reworked and is basically L2J based (we got a rework branch to test/commit with reworked AIs). Geoengine got no specific issues (at my knowledge), pathfinding was reworked lately to be way more performant, and I still try to improve performance using some pool system. Movement was partially fixed in latest 410, and probably will get another rework soon (notably reverting to the task wallclock).   "I" surely didn't spend 12y over geoengine - Hasha cared about geoengine during rev 334 / 354 / 390 / 395 and 397. It is solely his work, and always tagged as it. He was rewarded with money for his work, and almost a decade of aCis access.   aCis is a community work, things tagged with Tryskell is my work, the leftover is someone else work. 22 ppl worked as developers in this project over 14 years.   I would gladly accept whatever list of fixes/reports you have to share. You will even be rewarded (you probably know about cookie system), as anyone else sharing bug report or fixes.   My main concerns lately is the lack of decent L2OFF IL data, it is my main bottleneck actually. If you're aware about decent L2OFF data to parse, let me know.
    • Your project doesn't compare to aCis; you have to be an idiot to use that. I know someone who bought the High Five "PREMIUM" version, which has the same bugs as the free version. If you want, I can share his latest premium version. Players are going through walls with their bad geoengine, falling under the Olympiad. If you want, I can record and prove what I'm saying. The aCis project is 50 steps ahead of yours and it's not even stable...
    • l2jteon, l2joneo l2jscoria etc etc. and from that we went to this 
  • 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..

AdBlock Extension Detected!

Our website is made possible by displaying online advertisements to our members.

Please disable AdBlock browser extension first, to be able to use our community.

I've Disabled AdBlock