169 lines
5.3 KiB
Java
169 lines
5.3 KiB
Java
/*
|
|
* This file is part of the L2J Mobius project.
|
|
*
|
|
* 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.l2jmobius.gameserver.handler;
|
|
|
|
import java.sql.Connection;
|
|
import java.sql.PreparedStatement;
|
|
import java.sql.ResultSet;
|
|
import java.sql.SQLException;
|
|
import java.util.Map;
|
|
import java.util.concurrent.ConcurrentHashMap;
|
|
import java.util.logging.Level;
|
|
import java.util.logging.Logger;
|
|
|
|
import com.l2jmobius.commons.database.DatabaseFactory;
|
|
import com.l2jmobius.gameserver.enums.DailyMissionStatus;
|
|
import com.l2jmobius.gameserver.model.DailyMissionDataHolder;
|
|
import com.l2jmobius.gameserver.model.DailyMissionPlayerEntry;
|
|
import com.l2jmobius.gameserver.model.actor.instance.L2PcInstance;
|
|
import com.l2jmobius.gameserver.model.events.ListenersContainer;
|
|
|
|
/**
|
|
* @author Sdw
|
|
*/
|
|
public abstract class AbstractDailyMissionHandler extends ListenersContainer
|
|
{
|
|
protected Logger LOGGER = Logger.getLogger(getClass().getName());
|
|
|
|
private final Map<Integer, DailyMissionPlayerEntry> _entries = new ConcurrentHashMap<>();
|
|
private final DailyMissionDataHolder _holder;
|
|
|
|
protected AbstractDailyMissionHandler(DailyMissionDataHolder holder)
|
|
{
|
|
_holder = holder;
|
|
init();
|
|
}
|
|
|
|
public DailyMissionDataHolder getHolder()
|
|
{
|
|
return _holder;
|
|
}
|
|
|
|
public abstract boolean isAvailable(L2PcInstance player);
|
|
|
|
public abstract void init();
|
|
|
|
public int getStatus(L2PcInstance player)
|
|
{
|
|
final DailyMissionPlayerEntry entry = getPlayerEntry(player.getObjectId(), false);
|
|
return entry != null ? entry.getStatus().getClientId() : DailyMissionStatus.NOT_AVAILABLE.getClientId();
|
|
}
|
|
|
|
public int getProgress(L2PcInstance player)
|
|
{
|
|
final DailyMissionPlayerEntry entry = getPlayerEntry(player.getObjectId(), false);
|
|
return entry != null ? entry.getProgress() : 0;
|
|
}
|
|
|
|
public synchronized void reset()
|
|
{
|
|
try (Connection con = DatabaseFactory.getInstance().getConnection();
|
|
PreparedStatement ps = con.prepareStatement("DELETE FROM character_daily_rewards WHERE rewardId = ? AND status = ?"))
|
|
{
|
|
ps.setInt(1, _holder.getId());
|
|
ps.setInt(2, DailyMissionStatus.COMPLETED.getClientId());
|
|
ps.execute();
|
|
}
|
|
catch (SQLException e)
|
|
{
|
|
LOGGER.log(Level.WARNING, "Error while clearing data for: " + getClass().getSimpleName(), e);
|
|
}
|
|
finally
|
|
{
|
|
_entries.clear();
|
|
}
|
|
}
|
|
|
|
public boolean requestReward(L2PcInstance player)
|
|
{
|
|
if (isAvailable(player))
|
|
{
|
|
giveRewards(player);
|
|
|
|
final DailyMissionPlayerEntry entry = getPlayerEntry(player.getObjectId(), true);
|
|
entry.setStatus(DailyMissionStatus.COMPLETED);
|
|
entry.setLastCompleted(System.currentTimeMillis());
|
|
storePlayerEntry(entry);
|
|
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
protected void giveRewards(L2PcInstance player)
|
|
{
|
|
_holder.getRewards().forEach(i -> player.addItem("One Day Reward", i, player, true));
|
|
}
|
|
|
|
protected void storePlayerEntry(DailyMissionPlayerEntry entry)
|
|
{
|
|
try (Connection con = DatabaseFactory.getInstance().getConnection();
|
|
PreparedStatement ps = con.prepareStatement("REPLACE INTO character_daily_rewards (charId, rewardId, status, progress, lastCompleted) VALUES (?, ?, ?, ?, ?)"))
|
|
{
|
|
ps.setInt(1, entry.getObjectId());
|
|
ps.setInt(2, entry.getRewardId());
|
|
ps.setInt(3, entry.getStatus().getClientId());
|
|
ps.setInt(4, entry.getProgress());
|
|
ps.setLong(5, entry.getLastCompleted());
|
|
ps.execute();
|
|
|
|
// Cache if not exists
|
|
_entries.computeIfAbsent(entry.getObjectId(), id -> entry);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
LOGGER.log(Level.WARNING, "Error while saving reward " + entry.getRewardId() + " for player: " + entry.getObjectId() + " in database: ", e);
|
|
}
|
|
}
|
|
|
|
protected DailyMissionPlayerEntry getPlayerEntry(int objectId, boolean createIfNone)
|
|
{
|
|
final DailyMissionPlayerEntry existingEntry = _entries.get(objectId);
|
|
if (existingEntry != null)
|
|
{
|
|
return existingEntry;
|
|
}
|
|
|
|
try (Connection con = DatabaseFactory.getInstance().getConnection();
|
|
PreparedStatement ps = con.prepareStatement("SELECT * FROM character_daily_rewards WHERE charId = ? AND rewardId = ?"))
|
|
{
|
|
ps.setInt(1, objectId);
|
|
ps.setInt(2, _holder.getId());
|
|
try (ResultSet rs = ps.executeQuery())
|
|
{
|
|
if (rs.next())
|
|
{
|
|
final DailyMissionPlayerEntry entry = new DailyMissionPlayerEntry(rs.getInt("charId"), rs.getInt("rewardId"), rs.getInt("status"), rs.getInt("progress"), rs.getLong("lastCompleted"));
|
|
_entries.put(objectId, entry);
|
|
}
|
|
}
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
LOGGER.log(Level.WARNING, "Error while loading reward " + _holder.getId() + " for player: " + objectId + " in database: ", e);
|
|
}
|
|
|
|
if (createIfNone)
|
|
{
|
|
final DailyMissionPlayerEntry entry = new DailyMissionPlayerEntry(objectId, _holder.getId());
|
|
_entries.put(objectId, entry);
|
|
return entry;
|
|
}
|
|
return null;
|
|
}
|
|
}
|