/** * Copyright (C) 2017-2018 Christian Pierre MOMON * Copyright (C) 2011-2013,2017 Nicolas Vinot * * This file is part of (April) Hebdobot. * * Hebdobot is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Hebdobot 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 Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Hebdobot. If not, see */ package org.april.hebdobot.cron; import org.apache.commons.lang3.StringUtils; import org.april.hebdobot.bot.Hebdobot; import org.quartz.Job; import org.quartz.JobDataMap; import org.quartz.JobExecutionContext; import org.quartz.JobExecutionException; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * The Class NotifyCronJob. */ public class NotifyJob implements Job { private static final Logger logger = LoggerFactory.getLogger(NotifyJob.class); /* (non-Javadoc) * @see org.quartz.Job#execute(org.quartz.JobExecutionContext) */ @Override public void execute(final JobExecutionContext context) throws JobExecutionException { logger.info("CRON FIRE " + context.getTrigger().getDescription()); JobDataMap map = context.getJobDetail().getJobDataMap(); Hebdobot bot = (Hebdobot) map.get("bot"); CronValue cron = (CronValue) map.get("cron"); if (StringUtils.isBlank(cron.getIrcMessage())) { logger.info("No IRC message so no notify."); } else { bot.notifyIrc(cron.getIrcMessage()); } if (StringUtils.isBlank(cron.getTwitterMessage())) { logger.info("No Twitter message so no notify."); } else { bot.notifyTwitter(cron.getTwitterMessage(), cron.getImageFile()); } } }