Jump to content

Message System


Pauler

Recommended Posts

Hello there summoners.

 

Untill now, I haven't shared anything coded in Java. So I decided to code and share a message system (or mail system). It gives the possibility to players to send messages to each other even if the recipient is offline. Coded in l2jfrozen.

 

 

First, run this code at your mysql:

DROP TABLE IF EXISTS `mails`;
CREATE TABLE `mails` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `from` text,
  `to` text,
  `title` text,
  `message` text,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=43 DEFAULT CHARSET=latin1;

 

Core Side:

### Eclipse Workspace Patch 1.0
#P L2jFrozen_GS
Index: head-src/com/l2jfrozen/gameserver/network/clientpackets/RequestBypassToServer.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/network/clientpackets/RequestBypassToServer.java	(revision 948)
+++ head-src/com/l2jfrozen/gameserver/network/clientpackets/RequestBypassToServer.java	(working copy)
@@ -18,8 +18,11 @@
  */
package com.l2jfrozen.gameserver.network.clientpackets;

+import java.util.StringTokenizer;
import java.util.logging.Level;
import java.util.logging.Logger;
+import java.sql.PreparedStatement;
+import java.sql.ResultSet;

import com.l2jfrozen.Config;
import com.l2jfrozen.gameserver.ai.CtrlIntention;
@@ -40,9 +43,12 @@
import com.l2jfrozen.gameserver.model.entity.event.L2Event;
import com.l2jfrozen.gameserver.model.entity.event.TvT;
import com.l2jfrozen.gameserver.model.entity.event.VIP;
+import com.l2jfrozen.gameserver.handler.voicedcommandhandlers.MailCmd;
import com.l2jfrozen.gameserver.network.serverpackets.ActionFailed;
import com.l2jfrozen.gameserver.network.serverpackets.NpcHtmlMessage;
import com.l2jfrozen.gameserver.util.GMAudit;
+import com.l2jfrozen.util.database.L2DatabaseFactory;
+import com.mysql.jdbc.Connection;

public final class RequestBypassToServer extends L2GameClientPacket
{
@@ -124,6 +130,93 @@
			{
				playerHelp(activeChar, _command.substring(12));
			}
+			else if (_command.startsWith("sendMsg")) {
+				
+				StringTokenizer st = new StringTokenizer(_command);
+				
+				st.nextToken();
+				
+				String to = st.nextToken();
+				String title = st.nextToken();
+				String message = "";
+				
+				while(st.hasMoreTokens()) {
+					
+					message = message + st.nextToken() + " ";
+					
+				}
+				
+				if (to.equalsIgnoreCase(activeChar.getName())) {
+					
+					activeChar.sendMessage("You cannot send a message to yourself.");
+					return;
+				
+				}
+				
+				if (to.equalsIgnoreCase("") || message.equalsIgnoreCase("")) {
+					
+					activeChar.sendMessage("You have to fill all the fields.");
+					return;
+					
+				}
+				
+				if (title.equalsIgnoreCase(""))
+					title = "(No Subject)";
+				
+				java.sql.Connection con = null;
+				
+				try {
+					
+					con = L2DatabaseFactory.getInstance().getConnection(false);
+					
+					PreparedStatement statement = con.prepareStatement("INSERT INTO mails VALUES ('0',?,?,?,?)");
+					
+					statement.setString(1, activeChar.getName());
+					statement.setString(2, to);
+					statement.setString(3, title);
+					statement.setString(4, message);
+					
+					statement.execute();
+					activeChar.sendMessage("Your message has been sent.");
+					statement.close();
+					
+				}catch(Exception e) {
+					
+					e.printStackTrace();
+					_log.log(Level.SEVERE, e.getMessage(), e);
+					
+				}
+				
+			}
+			else if (_command.startsWith("delMsg")) {
+				
+				StringTokenizer st = new StringTokenizer(_command);
+				st.nextToken();
+				
+				int messageId = Integer.parseInt(st.nextToken());
+				
+				java.sql.Connection con = null;
+				
+				try {
+					
+					con = L2DatabaseFactory.getInstance().getConnection(false);
+					
+					PreparedStatement statement = con.prepareStatement("DELETE FROM mails WHERE id=?");
+					
+					statement.setInt(1, messageId);
+					
+					statement.execute();
+					activeChar.sendMessage("The message has been deleted.");
+					statement.close();
+					
+				}catch(Exception e) {
+					
+					e.printStackTrace();
+					_log.log(Level.SEVERE, e.getMessage(), e);
+					
+				}
+				
+			}
			else if(_command.startsWith("npc_"))
			{
				if(!activeChar.validateBypass(_command))
Index: head-src/com/l2jfrozen/gameserver/network/clientpackets/EnterWorld.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/network/clientpackets/EnterWorld.java	(revision 948)
+++ head-src/com/l2jfrozen/gameserver/network/clientpackets/EnterWorld.java	(working copy)
@@ -15,6 +15,7 @@
package com.l2jfrozen.gameserver.network.clientpackets;

import java.io.File;
+import java.sql.ResultSet;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
@@ -23,6 +24,10 @@
import java.util.regex.Pattern;
import java.util.regex.PatternSyntaxException;

+import java.sql.PreparedStatement;
+import java.sql.ResultSet;
+import java.sql.SQLException;
+
import com.l2jfrozen.Config;
import com.l2jfrozen.crypt.nProtect;
import com.l2jfrozen.crypt.nProtect.RestrictionType;
@@ -94,6 +99,7 @@
import com.l2jfrozen.gameserver.thread.TaskPriority;
import com.l2jfrozen.gameserver.thread.ThreadPoolManager;
import com.l2jfrozen.gameserver.util.Util;
+import com.l2jfrozen.util.database.L2DatabaseFactory;

/**
  * Enter World Packet Handler
@@ -277,9 +283,42 @@
		// Welcome to Lineage II
		sendPacket(new SystemMessage(SystemMessageId.WELCOME_TO_LINEAGE));

-		// Credits to L2jfrozen
-		activeChar.sendMessage("This server uses L2JFrozen, a project founded by L2Chef and");
-		activeChar.sendMessage("developed by the L2JFrozen Dev Team at l2jfrozen.com");
+		java.sql.Connection con = null;
+		
+		int results = 0;
+		
+		try {
+			
+			con = L2DatabaseFactory.getInstance().getConnection(false);
+			
+			PreparedStatement statement = con.prepareStatement("SELECT * FROM mails WHERE `to`=?");
+			
+			statement.setString(1, activeChar.getName());
+			
+			ResultSet result = statement.executeQuery();
+			
+			while (result.next()) {
+				
+				results++;
+				
+			}
+			
+		}catch(Exception e) {
+			
+			
+		}
+		
+		activeChar.sendMessage("You have " + results + " messages.");
+		

		SevenSigns.getInstance().sendCurrentPeriodMsg(activeChar);
		Announcements.getInstance().showAnnouncements(activeChar);
Index: head-src/com/l2jfrozen/gameserver/handler/VoicedCommandHandler.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/handler/VoicedCommandHandler.java	(revision 948)
+++ head-src/com/l2jfrozen/gameserver/handler/VoicedCommandHandler.java	(working copy)
@@ -30,6 +30,7 @@
import com.l2jfrozen.gameserver.handler.voicedcommandhandlers.CTFCmd;
import com.l2jfrozen.gameserver.handler.voicedcommandhandlers.DMCmd;
import com.l2jfrozen.gameserver.handler.voicedcommandhandlers.FarmPvpCmd;
+import com.l2jfrozen.gameserver.handler.voicedcommandhandlers.MailCmd;
import com.l2jfrozen.gameserver.handler.voicedcommandhandlers.Online;
import com.l2jfrozen.gameserver.handler.voicedcommandhandlers.StatsCmd;
import com.l2jfrozen.gameserver.handler.voicedcommandhandlers.TvTCmd;
@@ -66,6 +67,8 @@

		registerVoicedCommandHandler( new Voting());

+		registerVoicedCommandHandler(new MailCmd());
+		
		if(Config.BANKING_SYSTEM_ENABLED)
		{
			registerVoicedCommandHandler(new BankingCmd());
Index: head-src/com/l2jfrozen/gameserver/handler/voicedcommandhandlers/MailCmd.java
===================================================================
--- head-src/com/l2jfrozen/gameserver/handler/voicedcommandhandlers/MailCmd.java	(revision 0)
+++ head-src/com/l2jfrozen/gameserver/handler/voicedcommandhandlers/MailCmd.java	(revision 0)
@@ -0,0 +1,148 @@
+/*
+ * 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 3 of the License, 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, see <http://www.gnu.org/licenses/>.
+ */
+package com.l2jfrozen.gameserver.handler.voicedcommandhandlers;
+
+import java.sql.PreparedStatement;
+import java.sql.ResultSet;
+import java.sql.SQLException;
+
+import javolution.text.TextBuilder;
+
+import com.l2jfrozen.gameserver.handler.IVoicedCommandHandler;
+import com.l2jfrozen.gameserver.model.actor.instance.L2PcInstance;
+import com.l2jfrozen.gameserver.network.serverpackets.NpcHtmlMessage;
+import com.l2jfrozen.util.database.L2DatabaseFactory;
+
+/**
+ * @author Pauler
+ **/
+
+public class MailCmd implements IVoicedCommandHandler
+{
+	
+	public static final String[] VOICED_COMMANDS = { "mailread", "mailsend" };
+	
+	@Override
+	public boolean useVoicedCommand(String command, L2PcInstance activeChar, String target)
+	{
+		if (command.equalsIgnoreCase("mailread")) {
+			
+			mailread(activeChar);
+			
+		}
+		
+		if (command.equalsIgnoreCase("mailsend")) {
+			
+			mailsend(activeChar);
+			
+		}
+		
+		return false;
+	}
+	
+	public void mailread(L2PcInstance activeChar) {
+		
+		NpcHtmlMessage msg = new NpcHtmlMessage(20);
+        msg.setHtml(showMailReadWindow(activeChar));
+        msg.replace("%objectId%", String.valueOf(20));
+        activeChar.sendPacket(msg);
+		
+	}
+	
+	public String showMailReadWindow(L2PcInstance activeChar) {
+		
+		TextBuilder tb = new TextBuilder();
+		tb.append("<html><head><title>Inbox</title></head><body>");
+		
+		java.sql.Connection con = null;
+		try
+		{
+			con = L2DatabaseFactory.getInstance().getConnection(false);
+			
+			PreparedStatement statement = con.prepareStatement("SELECT * FROM mails WHERE `to`=? ORDER BY id DESC");
+			
+			statement.setString(1, activeChar.getName());
+			
+			ResultSet result = statement.executeQuery();
+			
+			int messageId = 0;
+			
+			while (result.next()) {
+				
+				tb.append("<font color=\"D6A718\">From:</font> <br>" + result.getString(2) + "<br>");
+				tb.append("<font color=\"D6A718\">Title:</font> <br>" + result.getString(4) + "<br>");
+				tb.append("<font color=\"D6A718\">Message:</font> <br>" + result.getString(5) + "<br>");
+				
+				messageId = result.getInt(1);
+				
+				tb.append("<button value=\"Delete\" action=\"bypass -h delMsg " + messageId +"\" width=100 height=20><br>*******************************<br>");
+				
+		
+			}
+			
+		}
+		catch (SQLException e)
+		{
+			e.printStackTrace();
+		}
+		
+		tb.append("</body></html>");
+		
+		return tb.toString();
+		
+	}
+	
+	public void mailsend(L2PcInstance activeChar) {
+		
+		NpcHtmlMessage msg = new NpcHtmlMessage(20);
+        msg.setHtml(showMailSendWindow(activeChar));
+        msg.replace("%objectId%", String.valueOf(20));
+        activeChar.sendPacket(msg);
+		
+	}
+	
+	public String showMailSendWindow(L2PcInstance activeChar) {
+		
+		TextBuilder tb = new TextBuilder();
+		tb.append("<html><head><title>Send a Mail</title></head><body>");
+		
+		tb.append("<br><font color=\"C99B10\">Welcome to the mail system.<br>Use the fields below in order to send messages to your friends.<br>Attention: Your title must include only 1 word.</font><br><br>");
+		tb.append("<center>");
+		
+		tb.append("To:<br>");
+		tb.append("<edit var=\"to\" width=\"120\" height=\"15\"><br><br>");
+		
+		tb.append("Title:<br>");
+		tb.append("<edit var=\"title\" width=\"120\" height=\"15\"><br><br>");
+		
+		tb.append("Message:<br>");
+		tb.append("<multiedit var=\"message\" width=\"120\" height=\"120\"><br><br>");
+		
+		tb.append("<button value=\"Send\" action=\"bypass -h sendMsg $to $title $message\" width=204 height=20>");
+		
+		tb.append("</center>");
+		
+		tb.append("</body></html>");
+	
+		return tb.toString();
+	}
+	
+	@Override
+	public String[] getVoicedCommandList()
+	{
+		return VOICED_COMMANDS;
+	}
+	
+}

Link to comment
Share on other sites

+1, this is good keep em commin'

 

hmm :P

 

a floodprotector is must there,since if someone spam it,it'll cause lag.

 

yeap, also if you dont check for not existing players they can just send a shitload just add a couple checkers and a flood protector and it will be nice :)

Link to comment
Share on other sites

also if you dont check for not existing players they can just send a shitload

it was my point when i asked him 'what if players doesn't exist?' :P

 

+1 from me aswell.

Link to comment
Share on other sites

it was my point when i asked him 'what if players doesn't exist?' :P

 

+1 from me aswell.

+1, this is good keep em commin'

 

yeap, also if you dont check for not existing players they can just send a shitload just add a couple checkers and a flood protector and it will be nice :)

I really appreciate it.
Link to comment
Share on other sites

Guest
This topic is now closed to further replies.

  • Posts

    • L2D geodata works. https://www.mediafire.com/file/oos96b3j3yq853s/l2d.7z   There was a voice command [voice_%multisell ID] for any npc to open the multisell. The voice command has been removed.   Update 01.09.2023 *VIP Coins items have been fixed, it was giving as invalid when using the item being on the 31st. *Fixed HEROES Coins items being invalid when used on the 31st. *Fixed the problem with hero skill animations. *ThreadPool has been configured to avoid vps crashes due to the number of events. #Diff from all of the above.   ---> JDK 17 https://github.com/Sarada-L2/L2jMega
    • Greetings forum users! A Telegram bot for conducting contests and automatically awarding prizes to characters is available for sale. Out of the box, it supports the following builds: Paun-Team, L2jEternity, Lucera2. Any other build can be added upon client request for free. Brief bot functionality: Multilingual support: ru, eng, ua Daily and scheduled contests with images Convenient prize and contest configuration Participation bonuses Automatic removal of contests after a specified time Channel subscription verification. Price: $70 Contact: https://t.me/se1dhe A few screenshots below  
    • You can't simply point fingers at others for your own shortcomings it's important to take responsibility and learn from your mistakes.     From here, i can see that you've given up because your servers weren't successful, and now you're blaming the community for your mistakes. You can't just say it's others fault when things go wrong you need to admit your own mistakes and try to do better next time.   peace
    • The same topic comes up time and time again. The "end" of L2 isn't due to the server administrators or the type of servers they create. It's largely because as adults, we struggle to find the time for economic and social stability. The reason I don't play L2 isn't that the servers are shit. On the contrary, many of them introduce fresh content in both PvE and PvP, bringing innovative ideas to a game that's 20 years old. The real barrier is lack of  time our life demands. I can't commit 6-7 hours daily just to make consistent  progress to keep up with the meta and not  to find myself lagging behind a week. This isn't only on l2 but with the  general idea of mmo. In the past five years, I've bought games like New World, Diablo 4, WoW, and Final Fantasy 14. But often, I find myself leveling up at my own  pace and mostly solo since my friends and I have different schedules. So, what do I end up doing when I feel like gaming? I typically boot up a MOBA or FPS, play for a couple of hours on Discord with whoever is available to play, then shut down my PC and call it a day.  Additionally, to stay on topic, I believe we're currently in an era where there are several stable projects for players to enjoy. Examples include Reborn, Classic Club, Talking Island, and Gold, just to name a few. As for the Aqua project, I've observed its launch and closure occur at a similar pace as those scam servers you've mentioned. 
  • Topics

×
×
  • Create New...

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