|
@@ -1,18 +1,5 @@
|
|
|
package com.citygis.quartz.controller;
|
|
|
|
|
|
-import java.util.List;
|
|
|
-import javax.servlet.http.HttpServletResponse;
|
|
|
-import org.quartz.SchedulerException;
|
|
|
-import org.springframework.beans.factory.annotation.Autowired;
|
|
|
-import org.springframework.security.access.prepost.PreAuthorize;
|
|
|
-import org.springframework.web.bind.annotation.DeleteMapping;
|
|
|
-import org.springframework.web.bind.annotation.GetMapping;
|
|
|
-import org.springframework.web.bind.annotation.PathVariable;
|
|
|
-import org.springframework.web.bind.annotation.PostMapping;
|
|
|
-import org.springframework.web.bind.annotation.PutMapping;
|
|
|
-import org.springframework.web.bind.annotation.RequestBody;
|
|
|
-import org.springframework.web.bind.annotation.RequestMapping;
|
|
|
-import org.springframework.web.bind.annotation.RestController;
|
|
|
import com.citygis.common.annotation.Log;
|
|
|
import com.citygis.common.constant.Constants;
|
|
|
import com.citygis.common.core.controller.BaseController;
|
|
@@ -26,16 +13,25 @@ import com.citygis.quartz.domain.SysJob;
|
|
|
import com.citygis.quartz.service.ISysJobService;
|
|
|
import com.citygis.quartz.util.CronUtils;
|
|
|
import com.citygis.quartz.util.ScheduleUtils;
|
|
|
+import io.swagger.annotations.Api;
|
|
|
+import io.swagger.annotations.ApiOperation;
|
|
|
+import org.quartz.SchedulerException;
|
|
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
|
+import org.springframework.security.access.prepost.PreAuthorize;
|
|
|
+import org.springframework.web.bind.annotation.*;
|
|
|
+
|
|
|
+import javax.servlet.http.HttpServletResponse;
|
|
|
+import java.util.List;
|
|
|
|
|
|
|
|
|
* 调度任务信息操作处理
|
|
|
- *
|
|
|
+ *
|
|
|
* @author citygis
|
|
|
*/
|
|
|
+@Api(tags = "定时任务")
|
|
|
@RestController
|
|
|
@RequestMapping("/monitor/job")
|
|
|
-public class SysJobController extends BaseController
|
|
|
-{
|
|
|
+public class SysJobController extends BaseController {
|
|
|
@Autowired
|
|
|
private ISysJobService jobService;
|
|
|
|
|
@@ -44,8 +40,7 @@ public class SysJobController extends BaseController
|
|
|
*/
|
|
|
@PreAuthorize("@ss.hasPermi('monitor:job:list')")
|
|
|
@GetMapping("/list")
|
|
|
- public TableDataInfo list(SysJob sysJob)
|
|
|
- {
|
|
|
+ public TableDataInfo list(SysJob sysJob) {
|
|
|
startPage();
|
|
|
List<SysJob> list = jobService.selectJobList(sysJob);
|
|
|
return getDataTable(list);
|
|
@@ -57,8 +52,7 @@ public class SysJobController extends BaseController
|
|
|
@PreAuthorize("@ss.hasPermi('monitor:job:export')")
|
|
|
@Log(title = "定时任务", businessType = BusinessType.EXPORT)
|
|
|
@PostMapping("/export")
|
|
|
- public void export(HttpServletResponse response, SysJob sysJob)
|
|
|
- {
|
|
|
+ public void export(HttpServletResponse response, SysJob sysJob) {
|
|
|
List<SysJob> list = jobService.selectJobList(sysJob);
|
|
|
ExcelUtil<SysJob> util = new ExcelUtil<SysJob>(SysJob.class);
|
|
|
util.exportExcel(response, list, "定时任务");
|
|
@@ -67,10 +61,10 @@ public class SysJobController extends BaseController
|
|
|
|
|
|
* 获取定时任务详细信息
|
|
|
*/
|
|
|
+ @ApiOperation("获取定时任务详细信息")
|
|
|
@PreAuthorize("@ss.hasPermi('monitor:job:query')")
|
|
|
@GetMapping(value = "/{jobId}")
|
|
|
- public AjaxResult getInfo(@PathVariable("jobId") Long jobId)
|
|
|
- {
|
|
|
+ public AjaxResult getInfo(@PathVariable("jobId") Long jobId) {
|
|
|
return success(jobService.selectJobById(jobId));
|
|
|
}
|
|
|
|
|
@@ -80,30 +74,18 @@ public class SysJobController extends BaseController
|
|
|
@PreAuthorize("@ss.hasPermi('monitor:job:add')")
|
|
|
@Log(title = "定时任务", businessType = BusinessType.INSERT)
|
|
|
@PostMapping
|
|
|
- public AjaxResult add(@RequestBody SysJob job) throws SchedulerException, TaskException
|
|
|
- {
|
|
|
- if (!CronUtils.isValid(job.getCronExpression()))
|
|
|
- {
|
|
|
+ public AjaxResult add(@RequestBody SysJob job) throws SchedulerException, TaskException {
|
|
|
+ if (!CronUtils.isValid(job.getCronExpression())) {
|
|
|
return error("新增任务'" + job.getJobName() + "'失败,Cron表达式不正确");
|
|
|
- }
|
|
|
- else if (StringUtils.containsIgnoreCase(job.getInvokeTarget(), Constants.LOOKUP_RMI))
|
|
|
- {
|
|
|
+ } else if (StringUtils.containsIgnoreCase(job.getInvokeTarget(), Constants.LOOKUP_RMI)) {
|
|
|
return error("新增任务'" + job.getJobName() + "'失败,目标字符串不允许'rmi'调用");
|
|
|
- }
|
|
|
- else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), new String[] { Constants.LOOKUP_LDAP, Constants.LOOKUP_LDAPS }))
|
|
|
- {
|
|
|
+ } else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), new String[]{Constants.LOOKUP_LDAP, Constants.LOOKUP_LDAPS})) {
|
|
|
return error("新增任务'" + job.getJobName() + "'失败,目标字符串不允许'ldap(s)'调用");
|
|
|
- }
|
|
|
- else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), new String[] { Constants.HTTP, Constants.HTTPS }))
|
|
|
- {
|
|
|
+ } else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), new String[]{Constants.HTTP, Constants.HTTPS})) {
|
|
|
return error("新增任务'" + job.getJobName() + "'失败,目标字符串不允许'http(s)'调用");
|
|
|
- }
|
|
|
- else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), Constants.JOB_ERROR_STR))
|
|
|
- {
|
|
|
+ } else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), Constants.JOB_ERROR_STR)) {
|
|
|
return error("新增任务'" + job.getJobName() + "'失败,目标字符串存在违规");
|
|
|
- }
|
|
|
- else if (!ScheduleUtils.whiteList(job.getInvokeTarget()))
|
|
|
- {
|
|
|
+ } else if (!ScheduleUtils.whiteList(job.getInvokeTarget())) {
|
|
|
return error("新增任务'" + job.getJobName() + "'失败,目标字符串不在白名单内");
|
|
|
}
|
|
|
job.setCreateBy(getUsername());
|
|
@@ -113,33 +95,22 @@ public class SysJobController extends BaseController
|
|
|
|
|
|
* 修改定时任务
|
|
|
*/
|
|
|
+ @ApiOperation("修改定时任务")
|
|
|
@PreAuthorize("@ss.hasPermi('monitor:job:edit')")
|
|
|
@Log(title = "定时任务", businessType = BusinessType.UPDATE)
|
|
|
@PutMapping
|
|
|
- public AjaxResult edit(@RequestBody SysJob job) throws SchedulerException, TaskException
|
|
|
- {
|
|
|
- if (!CronUtils.isValid(job.getCronExpression()))
|
|
|
- {
|
|
|
+ public AjaxResult edit(@RequestBody SysJob job) throws SchedulerException, TaskException {
|
|
|
+ if (!CronUtils.isValid(job.getCronExpression())) {
|
|
|
return error("修改任务'" + job.getJobName() + "'失败,Cron表达式不正确");
|
|
|
- }
|
|
|
- else if (StringUtils.containsIgnoreCase(job.getInvokeTarget(), Constants.LOOKUP_RMI))
|
|
|
- {
|
|
|
+ } else if (StringUtils.containsIgnoreCase(job.getInvokeTarget(), Constants.LOOKUP_RMI)) {
|
|
|
return error("修改任务'" + job.getJobName() + "'失败,目标字符串不允许'rmi'调用");
|
|
|
- }
|
|
|
- else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), new String[] { Constants.LOOKUP_LDAP, Constants.LOOKUP_LDAPS }))
|
|
|
- {
|
|
|
+ } else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), new String[]{Constants.LOOKUP_LDAP, Constants.LOOKUP_LDAPS})) {
|
|
|
return error("修改任务'" + job.getJobName() + "'失败,目标字符串不允许'ldap(s)'调用");
|
|
|
- }
|
|
|
- else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), new String[] { Constants.HTTP, Constants.HTTPS }))
|
|
|
- {
|
|
|
+ } else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), new String[]{Constants.HTTP, Constants.HTTPS})) {
|
|
|
return error("修改任务'" + job.getJobName() + "'失败,目标字符串不允许'http(s)'调用");
|
|
|
- }
|
|
|
- else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), Constants.JOB_ERROR_STR))
|
|
|
- {
|
|
|
+ } else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), Constants.JOB_ERROR_STR)) {
|
|
|
return error("修改任务'" + job.getJobName() + "'失败,目标字符串存在违规");
|
|
|
- }
|
|
|
- else if (!ScheduleUtils.whiteList(job.getInvokeTarget()))
|
|
|
- {
|
|
|
+ } else if (!ScheduleUtils.whiteList(job.getInvokeTarget())) {
|
|
|
return error("修改任务'" + job.getJobName() + "'失败,目标字符串不在白名单内");
|
|
|
}
|
|
|
job.setUpdateBy(getUsername());
|
|
@@ -149,11 +120,11 @@ public class SysJobController extends BaseController
|
|
|
|
|
|
* 定时任务状态修改
|
|
|
*/
|
|
|
+ @ApiOperation("定时任务状态修改")
|
|
|
@PreAuthorize("@ss.hasPermi('monitor:job:changeStatus')")
|
|
|
@Log(title = "定时任务", businessType = BusinessType.UPDATE)
|
|
|
@PutMapping("/changeStatus")
|
|
|
- public AjaxResult changeStatus(@RequestBody SysJob job) throws SchedulerException
|
|
|
- {
|
|
|
+ public AjaxResult changeStatus(@RequestBody SysJob job) throws SchedulerException {
|
|
|
SysJob newJob = jobService.selectJobById(job.getJobId());
|
|
|
newJob.setStatus(job.getStatus());
|
|
|
return toAjax(jobService.changeStatus(newJob));
|
|
@@ -162,11 +133,11 @@ public class SysJobController extends BaseController
|
|
|
|
|
|
* 定时任务立即执行一次
|
|
|
*/
|
|
|
+ @ApiOperation("定时任务立即执行一次")
|
|
|
@PreAuthorize("@ss.hasPermi('monitor:job:changeStatus')")
|
|
|
@Log(title = "定时任务", businessType = BusinessType.UPDATE)
|
|
|
@PutMapping("/run")
|
|
|
- public AjaxResult run(@RequestBody SysJob job) throws SchedulerException
|
|
|
- {
|
|
|
+ public AjaxResult run(@RequestBody SysJob job) throws SchedulerException {
|
|
|
boolean result = jobService.run(job);
|
|
|
return result ? success() : error("任务不存在或已过期!");
|
|
|
}
|
|
@@ -174,11 +145,11 @@ public class SysJobController extends BaseController
|
|
|
|
|
|
* 删除定时任务
|
|
|
*/
|
|
|
+ @ApiOperation("删除定时任务")
|
|
|
@PreAuthorize("@ss.hasPermi('monitor:job:remove')")
|
|
|
@Log(title = "定时任务", businessType = BusinessType.DELETE)
|
|
|
@DeleteMapping("/{jobIds}")
|
|
|
- public AjaxResult remove(@PathVariable Long[] jobIds) throws SchedulerException, TaskException
|
|
|
- {
|
|
|
+ public AjaxResult remove(@PathVariable Long[] jobIds) throws SchedulerException, TaskException {
|
|
|
jobService.deleteJobByIds(jobIds);
|
|
|
return success();
|
|
|
}
|