///////////////////////////////////////////////////////////////////////////// // // Project ProjectForge Community Edition // www.projectforge.org // // Copyright (C) 2001-2014 Kai Reinhard (k.reinhard@micromata.de) // // ProjectForge is dual-licensed. // // This community edition 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; version 3 of the License. // // This community edition 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 org.projectforge.meb; import org.projectforge.core.AbstractCronJob; import org.quartz.JobExecutionContext; import org.quartz.JobExecutionException; /** * Job should be scheduled every 10 minutes. * @author Kai Reinhard (k.reinhard@micromata.de) * */ public class MebPollingJob extends AbstractCronJob { private static final org.apache.log4j.Logger log = org.apache.log4j.Logger.getLogger(MebPollingJob.class); private MebJobExecutor mebJobExecutor; public void execute(final JobExecutionContext context) throws JobExecutionException { // log.info("MEB polling job started."); if (mebJobExecutor == null) { wire(context); } try { mebJobExecutor.execute(false); } catch (final Throwable ex) { log.error("While executing hibernate search re-index job: " + ex.getMessage(), ex); } // log.info("MEB polling job finished."); } protected void wire(final JobExecutionContext context) { mebJobExecutor = (MebJobExecutor) wire(context, "mebJobExecutor"); } }