/** * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.apache.activemq.broker.scheduler; import java.util.List; import org.apache.activemq.util.ByteSequence; public interface JobScheduler { /** * @return the name of the scheduler * @throws Exception */ String getName() throws Exception; /** * Starts dispatch of scheduled Jobs to registered listeners. * * Any listener added after the start dispatch method can miss jobs so its * important to register critical listeners before the start of job dispatching. * * @throws Exception */ void startDispatching() throws Exception; /** * Stops dispatching of scheduled Jobs to registered listeners. * * @throws Exception */ void stopDispatching() throws Exception; /** * Add a Job listener which will receive events related to scheduled jobs. * * @param listener * The job listener to add. * * @throws Exception */ void addListener(JobListener listener) throws Exception; /** * remove a JobListener that was previously registered. If the given listener is not in * the registry this method has no effect. * * @param listener * The listener that should be removed from the listener registry. * * @throws Exception */ void removeListener(JobListener listener) throws Exception; /** * Add a job to be scheduled * * @param jobId * a unique identifier for the job * @param payload * the message to be sent when the job is scheduled * @param delay * the time in milliseconds before the job will be run * * @throws Exception if an error occurs while scheduling the Job. */ void schedule(String jobId, ByteSequence payload, long delay) throws Exception; /** * Add a job to be scheduled * * @param jobId * a unique identifier for the job * @param payload * the message to be sent when the job is scheduled * @param cronEntry * The cron entry to use to schedule this job. * * @throws Exception if an error occurs while scheduling the Job. */ void schedule(String jobId, ByteSequence payload, String cronEntry) throws Exception; /** * Add a job to be scheduled * * @param jobId * a unique identifier for the job * @param payload * the message to be sent when the job is scheduled * @param cronEntry * cron entry * @param delay * time in ms to wait before scheduling * @param period * the time in milliseconds between successive executions of the Job * @param repeat * the number of times to execute the job - less than 0 will be repeated forever * @throws Exception */ void schedule(String jobId, ByteSequence payload, String cronEntry, long delay, long period, int repeat) throws Exception; /** * remove all jobs scheduled to run at this time * * @param time * The UTC time to use to remove a batch of scheduled Jobs. * * @throws Exception */ void remove(long time) throws Exception; /** * remove a job with the matching jobId * * @param jobId * The unique Job Id to search for and remove from the scheduled set of jobs. * * @throws Exception if an error occurs while removing the Job. */ void remove(String jobId) throws Exception; /** * remove all the Jobs from the scheduler * * @throws Exception */ void removeAllJobs() throws Exception; /** * remove all the Jobs from the scheduler that are due between the start and finish times * * @param start * time in milliseconds * @param finish * time in milliseconds * @throws Exception */ void removeAllJobs(long start, long finish) throws Exception; /** * Get the next time jobs will be fired * * @return the time in milliseconds * @throws Exception */ long getNextScheduleTime() throws Exception; /** * Get all the jobs scheduled to run next * * @return a list of jobs that will be scheduled next * @throws Exception */ List<Job> getNextScheduleJobs() throws Exception; /** * Get all the outstanding Jobs * * @return a list of all jobs * @throws Exception */ List<Job> getAllJobs() throws Exception; /** * Get all outstanding jobs due to run between start and finish * * @param start * @param finish * @return a list of jobs * @throws Exception */ List<Job> getAllJobs(long start, long finish) throws Exception; }