/* * Copyright (C) 2004-2014 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 . */ 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; } }