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

com.lifeonwalden.springscheduling.CronTrigger Maven / Gradle / Ivy

There is a newer version: 0.2.11
Show newest version
/**
 * Copyright 2016 HongLu
 * 
 * Licensed 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 com.lifeonwalden.springscheduling;

import java.util.Date;
import java.util.TimeZone;

import org.springframework.scheduling.Trigger;
import org.springframework.scheduling.TriggerContext;
import org.springframework.scheduling.support.CronSequenceGenerator;

/**
 * {@link Trigger} implementation for cron expressions. Wraps a {@link CronSequenceGenerator}.
 *
 * @author Juergen Hoeller
 * @since 3.0
 * @see CronSequenceGenerator
 */
public class CronTrigger extends BaseTrigger {

  private CronSequenceGenerator sequenceGenerator;

  private String expression;

  /**
   * Build a {@link CronTrigger} from the pattern provided in the default time zone.
   * 
   * @param id id for trigger
   * @param name name for trigger
   * @param expression a space-separated list of time fields, following cron expression conventions
   */
  public CronTrigger(String id, String name, String expression) {
    this.expression = expression;
    this.sequenceGenerator = new CronSequenceGenerator(expression);
    this.id = id;
    this.name = name;
  }

  /**
   * Build a {@link CronTrigger} from the pattern provided in the given time zone.
   * 
   * @param id id for trigger
   * @param name name for trigger
   * @param expression a space-separated list of time fields, following cron expression conventions
   * @param timeZone a time zone in which the trigger times will be generated
   */
  public CronTrigger(String id, String name, String expression, TimeZone timeZone) {
    this.sequenceGenerator = new CronSequenceGenerator(expression, timeZone);
    this.id = id;
    this.name = name;
  }

  /**
   * 
   * @param expression a space-separated list of time fields, following cron expression conventions
   */
  public void updateTrigger(String expression) {
    this.sequenceGenerator = new CronSequenceGenerator(expression);
  }

  /**
   * 
   * @param expression a space-separated list of time fields, following cron expression conventions
   * @param timeZone a time zone in which the trigger times will be generated
   */
  public void updateTrigger(String expression, TimeZone timeZone) {
    this.sequenceGenerator = new CronSequenceGenerator(expression, timeZone);
  }

  /**
   * @return the cron pattern that this trigger has been built with.
   */
  public String getExpression() {
    return this.expression;
  }

  /**
   * Determine the next execution time according to the given trigger context.
   * 

* Next execution times are calculated based on the {@linkplain TriggerContext#lastCompletionTime completion time} of * the previous execution; therefore, overlapping executions won't occur. */ @Override public Date nextExecutionTime(TriggerContext triggerContext) { Date date = triggerContext.lastCompletionTime(); if (date != null) { Date scheduled = triggerContext.lastScheduledExecutionTime(); if (scheduled != null && date.before(scheduled)) { // Previous task apparently executed too early... // Let's simply use the last calculated execution time then, // in order to prevent accidental re-fires in the same second. date = scheduled; } } else { date = new Date(); } if (date.getTime() > System.currentTimeMillis()) { return date; } else { return this.sequenceGenerator.next(date); } } @Override public boolean equals(Object other) { return (this == other || (other instanceof CronTrigger && this.sequenceGenerator.equals(((CronTrigger) other).sequenceGenerator))); } @Override public int hashCode() { return this.sequenceGenerator.hashCode(); } @Override public String toString() { return this.sequenceGenerator.toString(); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy