170 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			170 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| /*
 | |
|  * Copyright (C) 2004-2015 L2J Server
 | |
|  * 
 | |
|  * This file is part of L2J Server.
 | |
|  * 
 | |
|  * L2J Server 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.
 | |
|  * 
 | |
|  * L2J Server 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.l2jserver.gameserver.model.entity;
 | |
| 
 | |
| import java.sql.Connection;
 | |
| import java.sql.PreparedStatement;
 | |
| import java.sql.ResultSet;
 | |
| import java.util.Calendar;
 | |
| import java.util.logging.Level;
 | |
| import java.util.logging.Logger;
 | |
| 
 | |
| import com.l2jserver.L2DatabaseFactory;
 | |
| import com.l2jserver.gameserver.idfactory.IdFactory;
 | |
| import com.l2jserver.gameserver.model.actor.instance.L2PcInstance;
 | |
| 
 | |
| /**
 | |
|  * @author evill33t
 | |
|  */
 | |
| public class Couple
 | |
| {
 | |
| 	private static final Logger _log = Logger.getLogger(Couple.class.getName());
 | |
| 	
 | |
| 	private int _Id = 0;
 | |
| 	private int _player1Id = 0;
 | |
| 	private int _player2Id = 0;
 | |
| 	private boolean _maried = false;
 | |
| 	private Calendar _affiancedDate;
 | |
| 	private Calendar _weddingDate;
 | |
| 	
 | |
| 	public Couple(int coupleId)
 | |
| 	{
 | |
| 		_Id = coupleId;
 | |
| 		
 | |
| 		try (Connection con = L2DatabaseFactory.getInstance().getConnection();
 | |
| 			PreparedStatement ps = con.prepareStatement("SELECT * FROM mods_wedding WHERE id = ?"))
 | |
| 		{
 | |
| 			ps.setInt(1, _Id);
 | |
| 			try (ResultSet rs = ps.executeQuery())
 | |
| 			{
 | |
| 				while (rs.next())
 | |
| 				{
 | |
| 					_player1Id = rs.getInt("player1Id");
 | |
| 					_player2Id = rs.getInt("player2Id");
 | |
| 					_maried = rs.getBoolean("married");
 | |
| 					
 | |
| 					_affiancedDate = Calendar.getInstance();
 | |
| 					_affiancedDate.setTimeInMillis(rs.getLong("affianceDate"));
 | |
| 					
 | |
| 					_weddingDate = Calendar.getInstance();
 | |
| 					_weddingDate.setTimeInMillis(rs.getLong("weddingDate"));
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 		catch (Exception e)
 | |
| 		{
 | |
| 			_log.log(Level.SEVERE, "Exception: Couple.load(): " + e.getMessage(), e);
 | |
| 		}
 | |
| 	}
 | |
| 	
 | |
| 	public Couple(L2PcInstance player1, L2PcInstance player2)
 | |
| 	{
 | |
| 		int _tempPlayer1Id = player1.getObjectId();
 | |
| 		int _tempPlayer2Id = player2.getObjectId();
 | |
| 		
 | |
| 		_player1Id = _tempPlayer1Id;
 | |
| 		_player2Id = _tempPlayer2Id;
 | |
| 		
 | |
| 		_affiancedDate = Calendar.getInstance();
 | |
| 		_affiancedDate.setTimeInMillis(Calendar.getInstance().getTimeInMillis());
 | |
| 		
 | |
| 		_weddingDate = Calendar.getInstance();
 | |
| 		_weddingDate.setTimeInMillis(Calendar.getInstance().getTimeInMillis());
 | |
| 		
 | |
| 		try (Connection con = L2DatabaseFactory.getInstance().getConnection();
 | |
| 			PreparedStatement ps = con.prepareStatement("INSERT INTO mods_wedding (id, player1Id, player2Id, married, affianceDate, weddingDate) VALUES (?, ?, ?, ?, ?, ?)"))
 | |
| 		{
 | |
| 			_Id = IdFactory.getInstance().getNextId();
 | |
| 			ps.setInt(1, _Id);
 | |
| 			ps.setInt(2, _player1Id);
 | |
| 			ps.setInt(3, _player2Id);
 | |
| 			ps.setBoolean(4, false);
 | |
| 			ps.setLong(5, _affiancedDate.getTimeInMillis());
 | |
| 			ps.setLong(6, _weddingDate.getTimeInMillis());
 | |
| 			ps.execute();
 | |
| 		}
 | |
| 		catch (Exception e)
 | |
| 		{
 | |
| 			_log.log(Level.SEVERE, "Could not create couple: " + e.getMessage(), e);
 | |
| 		}
 | |
| 	}
 | |
| 	
 | |
| 	public void marry()
 | |
| 	{
 | |
| 		try (Connection con = L2DatabaseFactory.getInstance().getConnection();
 | |
| 			PreparedStatement ps = con.prepareStatement("UPDATE mods_wedding set married = ?, weddingDate = ? where id = ?"))
 | |
| 		{
 | |
| 			ps.setBoolean(1, true);
 | |
| 			_weddingDate = Calendar.getInstance();
 | |
| 			ps.setLong(2, _weddingDate.getTimeInMillis());
 | |
| 			ps.setInt(3, _Id);
 | |
| 			ps.execute();
 | |
| 			_maried = true;
 | |
| 		}
 | |
| 		catch (Exception e)
 | |
| 		{
 | |
| 			_log.log(Level.SEVERE, "Could not marry: " + e.getMessage(), e);
 | |
| 		}
 | |
| 	}
 | |
| 	
 | |
| 	public void divorce()
 | |
| 	{
 | |
| 		try (Connection con = L2DatabaseFactory.getInstance().getConnection();
 | |
| 			PreparedStatement ps = con.prepareStatement("DELETE FROM mods_wedding WHERE id=?"))
 | |
| 		{
 | |
| 			ps.setInt(1, _Id);
 | |
| 			ps.execute();
 | |
| 		}
 | |
| 		catch (Exception e)
 | |
| 		{
 | |
| 			_log.log(Level.SEVERE, "Exception: Couple.divorce(): " + e.getMessage(), e);
 | |
| 		}
 | |
| 	}
 | |
| 	
 | |
| 	public final int getId()
 | |
| 	{
 | |
| 		return _Id;
 | |
| 	}
 | |
| 	
 | |
| 	public final int getPlayer1Id()
 | |
| 	{
 | |
| 		return _player1Id;
 | |
| 	}
 | |
| 	
 | |
| 	public final int getPlayer2Id()
 | |
| 	{
 | |
| 		return _player2Id;
 | |
| 	}
 | |
| 	
 | |
| 	public final boolean getMaried()
 | |
| 	{
 | |
| 		return _maried;
 | |
| 	}
 | |
| 	
 | |
| 	public final Calendar getAffiancedDate()
 | |
| 	{
 | |
| 		return _affiancedDate;
 | |
| 	}
 | |
| 	
 | |
| 	public final Calendar getWeddingDate()
 | |
| 	{
 | |
| 		return _weddingDate;
 | |
| 	}
 | |
| }
 | 
