/*
* 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 silentium.gameserver.taskmanager.tasks;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import silentium.gameserver.model.entity.sevensigns.SevenSigns;
import silentium.gameserver.model.entity.sevensigns.SevenSignsFestival;
import silentium.gameserver.taskmanager.Task;
import silentium.gameserver.taskmanager.TaskManager;
import silentium.gameserver.taskmanager.TaskManager.ExecutedTask;
import silentium.gameserver.taskmanager.TaskTypes;
/**
* Updates all data for the Seven Signs and Festival of Darkness engines, when time is elapsed.
*
* @author Tempy
*/
public class TaskSevenSignsUpdate extends Task
{
private static final Logger _log = LoggerFactory.getLogger(TaskOlympiadSave.class.getName());
public static final String NAME = "SevenSignsUpdate";
@Override
public String getName()
{
return NAME;
}
@Override
public void onTimeElapsed(ExecutedTask task)
{
try
{
SevenSigns.getInstance().saveSevenSignsStatus();
if (!SevenSigns.getInstance().isSealValidationPeriod())
SevenSignsFestival.getInstance().saveFestivalData(false);
_log.info("SevenSigns: Data updated successfully.");
}
catch (Exception e)
{
_log.warn("SevenSigns: Failed to save Seven Signs configuration: " + e);
}
}
@Override
public void initializate()
{
super.initializate();
TaskManager.addUniqueTask(NAME, TaskTypes.TYPE_FIXED_SHEDULED, "1800000", "1800000", "");
}
}