2020-07-19 10:25:40 +08:00
|
|
|
|
package com.ruoyi.quartz.domain;
|
|
|
|
|
|
2021-03-15 16:38:43 +08:00
|
|
|
|
import cn.hutool.core.util.StrUtil;
|
2021-04-12 17:49:56 +08:00
|
|
|
|
import com.baomidou.mybatisplus.annotation.*;
|
2020-07-19 10:25:40 +08:00
|
|
|
|
import com.fasterxml.jackson.annotation.JsonFormat;
|
|
|
|
|
import com.ruoyi.common.annotation.Excel;
|
|
|
|
|
import com.ruoyi.common.annotation.Excel.ColumnType;
|
|
|
|
|
import com.ruoyi.common.constant.ScheduleConstants;
|
|
|
|
|
import com.ruoyi.quartz.util.CronUtils;
|
2021-04-12 17:49:56 +08:00
|
|
|
|
import lombok.Data;
|
|
|
|
|
import lombok.NoArgsConstructor;
|
|
|
|
|
import lombok.experimental.Accessors;
|
2021-03-15 16:38:43 +08:00
|
|
|
|
|
|
|
|
|
import javax.validation.constraints.NotBlank;
|
|
|
|
|
import javax.validation.constraints.Size;
|
|
|
|
|
import java.io.Serializable;
|
|
|
|
|
import java.util.Date;
|
2021-04-12 17:49:56 +08:00
|
|
|
|
import java.util.HashMap;
|
|
|
|
|
import java.util.Map;
|
2020-07-19 10:25:40 +08:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 定时任务调度表 sys_job
|
2021-04-22 21:07:18 +08:00
|
|
|
|
*
|
2020-07-19 10:25:40 +08:00
|
|
|
|
* @author ruoyi
|
|
|
|
|
*/
|
2021-04-12 17:49:56 +08:00
|
|
|
|
|
|
|
|
|
@Data
|
|
|
|
|
@NoArgsConstructor
|
|
|
|
|
@Accessors(chain = true)
|
|
|
|
|
@TableName("sys_job")
|
2021-04-22 21:07:18 +08:00
|
|
|
|
public class SysJob implements Serializable {
|
2020-07-19 10:25:40 +08:00
|
|
|
|
private static final long serialVersionUID = 1L;
|
|
|
|
|
|
2021-04-22 21:07:18 +08:00
|
|
|
|
/**
|
|
|
|
|
* 任务ID
|
|
|
|
|
*/
|
2020-07-19 10:25:40 +08:00
|
|
|
|
@Excel(name = "任务序号", cellType = ColumnType.NUMERIC)
|
2021-04-12 17:49:56 +08:00
|
|
|
|
@TableId(value = "job_id", type = IdType.AUTO)
|
2020-07-19 10:25:40 +08:00
|
|
|
|
private Long jobId;
|
|
|
|
|
|
2021-04-22 21:07:18 +08:00
|
|
|
|
/**
|
|
|
|
|
* 任务名称
|
|
|
|
|
*/
|
2021-04-12 17:49:56 +08:00
|
|
|
|
@NotBlank(message = "任务名称不能为空")
|
|
|
|
|
@Size(min = 0, max = 64, message = "任务名称不能超过64个字符")
|
2020-07-19 10:25:40 +08:00
|
|
|
|
@Excel(name = "任务名称")
|
|
|
|
|
private String jobName;
|
|
|
|
|
|
2021-04-22 21:07:18 +08:00
|
|
|
|
/**
|
|
|
|
|
* 任务组名
|
|
|
|
|
*/
|
2020-07-19 10:25:40 +08:00
|
|
|
|
@Excel(name = "任务组名")
|
|
|
|
|
private String jobGroup;
|
|
|
|
|
|
2021-04-22 21:07:18 +08:00
|
|
|
|
/**
|
|
|
|
|
* 调用目标字符串
|
|
|
|
|
*/
|
2021-04-12 17:49:56 +08:00
|
|
|
|
@NotBlank(message = "调用目标字符串不能为空")
|
|
|
|
|
@Size(min = 0, max = 500, message = "调用目标字符串长度不能超过500个字符")
|
2020-07-19 10:25:40 +08:00
|
|
|
|
@Excel(name = "调用目标字符串")
|
|
|
|
|
private String invokeTarget;
|
|
|
|
|
|
2021-04-22 21:07:18 +08:00
|
|
|
|
/**
|
|
|
|
|
* cron执行表达式
|
|
|
|
|
*/
|
2021-04-12 17:49:56 +08:00
|
|
|
|
@NotBlank(message = "Cron执行表达式不能为空")
|
|
|
|
|
@Size(min = 0, max = 255, message = "Cron执行表达式不能超过255个字符")
|
2020-07-19 10:25:40 +08:00
|
|
|
|
@Excel(name = "执行表达式 ")
|
|
|
|
|
private String cronExpression;
|
|
|
|
|
|
2021-04-22 21:07:18 +08:00
|
|
|
|
/**
|
|
|
|
|
* cron计划策略
|
|
|
|
|
*/
|
2020-07-19 10:25:40 +08:00
|
|
|
|
@Excel(name = "计划策略 ", readConverterExp = "0=默认,1=立即触发执行,2=触发一次执行,3=不触发立即执行")
|
|
|
|
|
private String misfirePolicy = ScheduleConstants.MISFIRE_DEFAULT;
|
|
|
|
|
|
2021-04-22 21:07:18 +08:00
|
|
|
|
/**
|
|
|
|
|
* 是否并发执行(0允许 1禁止)
|
|
|
|
|
*/
|
2020-07-19 10:25:40 +08:00
|
|
|
|
@Excel(name = "并发执行", readConverterExp = "0=允许,1=禁止")
|
|
|
|
|
private String concurrent;
|
|
|
|
|
|
2021-04-22 21:07:18 +08:00
|
|
|
|
/**
|
|
|
|
|
* 任务状态(0正常 1暂停)
|
|
|
|
|
*/
|
2020-07-19 10:25:40 +08:00
|
|
|
|
@Excel(name = "任务状态", readConverterExp = "0=正常,1=暂停")
|
|
|
|
|
private String status;
|
|
|
|
|
|
2021-04-12 17:49:56 +08:00
|
|
|
|
/**
|
|
|
|
|
* 创建者
|
|
|
|
|
*/
|
2021-04-22 21:07:18 +08:00
|
|
|
|
@TableField(fill = FieldFill.INSERT)
|
2021-04-12 17:49:56 +08:00
|
|
|
|
private String createBy;
|
2020-07-19 10:25:40 +08:00
|
|
|
|
|
2021-04-12 17:49:56 +08:00
|
|
|
|
/**
|
|
|
|
|
* 创建时间
|
|
|
|
|
*/
|
|
|
|
|
@TableField(fill = FieldFill.INSERT)
|
|
|
|
|
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
|
|
|
|
|
private Date createTime;
|
2020-07-19 10:25:40 +08:00
|
|
|
|
|
2021-04-12 17:49:56 +08:00
|
|
|
|
/**
|
|
|
|
|
* 更新者
|
|
|
|
|
*/
|
2021-04-22 21:07:18 +08:00
|
|
|
|
@TableField(fill = FieldFill.INSERT_UPDATE)
|
2021-04-12 17:49:56 +08:00
|
|
|
|
private String updateBy;
|
2020-07-19 10:25:40 +08:00
|
|
|
|
|
2021-04-12 17:49:56 +08:00
|
|
|
|
/**
|
|
|
|
|
* 更新时间
|
|
|
|
|
*/
|
|
|
|
|
@TableField(fill = FieldFill.INSERT_UPDATE)
|
|
|
|
|
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
|
|
|
|
|
private Date updateTime;
|
2020-07-19 10:25:40 +08:00
|
|
|
|
|
2021-04-12 17:49:56 +08:00
|
|
|
|
/**
|
|
|
|
|
* 备注
|
|
|
|
|
*/
|
|
|
|
|
private String remark;
|
2020-07-19 10:25:40 +08:00
|
|
|
|
|
2021-04-12 17:49:56 +08:00
|
|
|
|
/**
|
|
|
|
|
* 请求参数
|
|
|
|
|
*/
|
|
|
|
|
@TableField(exist = false)
|
|
|
|
|
private Map<String, Object> params = new HashMap<>();
|
2020-07-19 10:25:40 +08:00
|
|
|
|
|
|
|
|
|
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
|
2021-04-22 21:07:18 +08:00
|
|
|
|
public Date getNextValidTime() {
|
|
|
|
|
if (StrUtil.isNotEmpty(cronExpression)) {
|
2020-07-19 10:25:40 +08:00
|
|
|
|
return CronUtils.getNextExecution(cronExpression);
|
|
|
|
|
}
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|