All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.exist.scheduler.ScheduledJobInfo Maven / Gradle / Ivy

/*
 *  eXist Open Source Native XML Database
 *  Copyright (C) 2001-2015 The eXist Project
 *  http://exist-db.org
 *
 *  This program is free software; you can redistribute it and/or
 *  modify it under the terms of the GNU Lesser General Public License
 *  as published by the Free Software Foundation; either version 2
 *  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 Lesser General Public License for more details.
 *
 *  You should have received a copy of the GNU Lesser General Public
 *  License along with this library; if not, write to the Free Software
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 */
package org.exist.scheduler;

import java.util.Date;
import org.quartz.CronTrigger;
import org.quartz.Scheduler;
import org.quartz.SchedulerException;
import org.quartz.SimpleTrigger;
import org.quartz.Trigger;

/**
 * Information about a Scheduled Job.
 *
 * @author Adam Retter
 */
public class ScheduledJobInfo {
    
    public enum TriggerState {
        ERROR,
        NONE,
        NORMAL,
        PAUSED,
        BLOCKED,
        COMPLETE
    }
    
    private final Scheduler scheduler;
    private final Trigger trigger;

    public ScheduledJobInfo(final Scheduler scheduler, final Trigger trigger) {
        this.scheduler = scheduler;
        this.trigger = trigger;
    }

    /**
     * Get the Job's Name.
     *
     * @return  the Job's Name
     */
    public String getName() {
        return trigger.getJobKey().getName();
    }


    /**
     * Get the Job's Group.
     *
     * @return  the Job's Group
     */
    public String getGroup() {
        return trigger.getJobKey().getGroup();
    }


    /**
     * Get the Name of the Job's Trigger.
     *
     * @return  the Name of the Job's Trigger
     */
    public String getTriggerName() {
        return trigger.getKey().getName();
    }


    /**
     * Get the Start time of the Job.
     *
     * @return  the Start time of the Job
     */
    public Date getStartTime() {
        return trigger.getStartTime();
    }


    /**
     * Get the End time of the Job.
     *
     * @return  the End time of the Job, or null of the job is Scheduled forever
     */
    public Date getEndTime() {
        return trigger.getEndTime();
    }


    /**
     * Get the Previous Fired time of the Job.
     *
     * @return  the time the Job was Previously Fired, or null if the job hasnt fired yet
     */
    public Date getPreviousFireTime() {
        return trigger.getPreviousFireTime();
    }


    /**
     * Get the Time the Job will Next be Fired.
     *
     * @return  the time the Job will Next be Fired, or null if the job wont fire again
     */
    public Date getNextFireTime() {
        return trigger.getNextFireTime();
    }


    /**
     * Get the Final Time the Job will be Fired.
     *
     * @return  the time the Job will be Fired for the Final time, or null if the job is Scheduled forever
     */
    public Date getFinalFireTime() {
        return trigger.getFinalFireTime();
    }


    /**
     * Get the Expression that was used to configure the Triggers firing pattern.
     *
     * @return  The expression that was used to configure the Triggers firing pattern
     */
    public String getTriggerExpression(){
        if(trigger instanceof CronTrigger) {
            return ((CronTrigger)trigger).getCronExpression();
        } else if(trigger instanceof SimpleTrigger) {
            return String.valueOf(((SimpleTrigger)trigger).getRepeatInterval());
        }

        return null;
    }

    /**
     * Get the State of the Job's Trigger.
     *
     * @return  the TRIGGER_STATE_*
     */
    public TriggerState getTriggerState() {
        try {
            switch(scheduler.getTriggerState(trigger.getKey())) {

                case ERROR:
                    return TriggerState.ERROR;

                case NONE:
                    return TriggerState.NONE;

                case NORMAL:
                    return TriggerState.NORMAL;

                case PAUSED:
                    return TriggerState.PAUSED;

                case BLOCKED:
                    return TriggerState.BLOCKED;

                case COMPLETE:
                    return TriggerState.COMPLETE;

                default:
                    return TriggerState.ERROR;
            }
        } catch(final SchedulerException se) {
            return TriggerState.ERROR;
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy