net.sf.l2j.gameserver.model.entity.ClanHallSiege.java Source code

Java tutorial

Introduction

Here is the source code for net.sf.l2j.gameserver.model.entity.ClanHallSiege.java

Source

/*
 * 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 net.sf.l2j.gameserver.model.entity;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Calendar;

import net.sf.l2j.L2DatabaseFactory;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

/*
 * Author: MHard
 */
public abstract class ClanHallSiege {
    protected static Log _log = LogFactory.getLog(ClanHallSiege.class.getName());
    private Calendar _siegeDate;
    public Calendar _siegeEndDate;
    private boolean _isInProgress = false;

    public long restoreSiegeDate(int ClanHallId) {
        long res = 0;
        Connection con = null;
        try {
            con = L2DatabaseFactory.getInstance().getConnection();
            PreparedStatement statement = con.prepareStatement("SELECT siege_data FROM clanhall_siege WHERE id=?");
            statement.setInt(1, ClanHallId);
            ResultSet rs = statement.executeQuery();
            if (rs.next())
                res = rs.getLong("siege_data");
            rs.close();
            statement.close();
        } catch (Exception e) {
            _log.error("Exception: can't get clanhall siege date: " + e.getMessage(), e);
        } finally {
            try {
                if (con != null)
                    con.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        return res;
    }

    public void setNewSiegeDate(long siegeDate, int ClanHallId, int hour) {
        Calendar tmpDate = Calendar.getInstance();
        if (siegeDate <= System.currentTimeMillis()) {
            tmpDate.setTimeInMillis(System.currentTimeMillis());
            tmpDate.add(Calendar.DAY_OF_MONTH, 3);
            tmpDate.set(Calendar.DAY_OF_WEEK, 6);
            tmpDate.set(Calendar.HOUR_OF_DAY, hour);
            tmpDate.set(Calendar.MINUTE, 0);
            tmpDate.set(Calendar.SECOND, 0);
            setSiegeDate(tmpDate);
            Connection con = null;
            try {
                con = L2DatabaseFactory.getInstance().getConnection();
                PreparedStatement statement = con
                        .prepareStatement("UPDATE clanhall_siege SET siege_data=? WHERE id = ?");
                statement.setLong(1, getSiegeDate().getTimeInMillis());
                statement.setInt(2, ClanHallId);
                statement.execute();
                statement.close();
            } catch (Exception e) {
                _log.error("Exception: can't save clanhall siege date: " + e.getMessage(), e);
            } finally {
                try {
                    if (con != null)
                        con.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
        }
    }

    public final Calendar getSiegeDate() {
        return _siegeDate;
    }

    public final void setSiegeDate(Calendar par) {
        _siegeDate = par;
    }

    public final boolean getIsInProgress() {
        return _isInProgress;
    }

    public final void setIsInProgress(boolean par) {
        _isInProgress = par;
    }
}