package com.xxl.job.admin.controller; import com.xxl.job.admin.core.constant.Constants.JobGroupEnum; import com.xxl.job.admin.core.model.ReturnT; import com.xxl.job.admin.core.model.XxlJobInfo; import com.xxl.job.admin.core.model.XxlJobLog; import com.xxl.job.admin.dao.IXxlJobInfoDao; import com.xxl.job.admin.dao.IXxlJobLogDao; import com.xxl.job.core.router.HandlerRouter.ActionRepository; import com.xxl.job.core.router.model.RequestModel; import com.xxl.job.core.router.model.ResponseModel; import com.xxl.job.core.util.XxlJobNetCommUtil; import org.apache.commons.lang.StringUtils; import org.apache.commons.lang.time.DateUtils; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.ResponseBody; import javax.annotation.Resource; import java.text.ParseException; import java.util.Date; import java.util.HashMap; import java.util.List; import java.util.Map; /** * index controller * @author xuxueli 2015-12-19 16:13:16 */ @Controller @RequestMapping("/joblog") public class JobLogController { @Resource public IXxlJobLogDao xxlJobLogDao; @Resource public IXxlJobInfoDao xxlJobInfoDao; @RequestMapping public String index(Model model, String jobGroup, String jobName) { model.addAttribute("jobGroup", jobGroup); model.addAttribute("jobName", jobName); model.addAttribute("JobGroupList", JobGroupEnum.values()); return "joblog/joblog.index"; } @RequestMapping("/getJobsByGroup") @ResponseBody public ReturnT> listJobByGroup(String jobGroup){ List list = xxlJobInfoDao.getJobsByGroup(jobGroup); return new ReturnT>(list); } @RequestMapping("/pageList") @ResponseBody public Map pageList(@RequestParam(required = false, defaultValue = "0") int start, @RequestParam(required = false, defaultValue = "10") int length, String jobGroup, String jobName, String filterTime) { // parse param Date triggerTimeStart = null; Date triggerTimeEnd = null; if (StringUtils.isNotBlank(filterTime)) { String[] temp = filterTime.split(" - "); if (temp!=null && temp.length == 2) { try { triggerTimeStart = DateUtils.parseDate(temp[0], new String[]{"yyyy-MM-dd HH:mm:ss"}); triggerTimeEnd = DateUtils.parseDate(temp[1], new String[]{"yyyy-MM-dd HH:mm:ss"}); } catch (ParseException e) { } } } // page query List list = xxlJobLogDao.pageList(start, length, jobGroup, jobName, triggerTimeStart, triggerTimeEnd); int list_count = xxlJobLogDao.pageListCount(start, length, jobGroup, jobName, triggerTimeStart, triggerTimeEnd); // package result Map maps = new HashMap(); maps.put("recordsTotal", list_count); // 总记录数 maps.put("recordsFiltered", list_count); // 过滤后的总记录数 maps.put("data", list); // 分页列表 return maps; } /*@RequestMapping("/save") @ResponseBody @PermessionLimit(limit=false) public RemoteCallBack triggerLog(int trigger_log_id, String status, String msg) { RemoteCallBack callBack = new RemoteCallBack(); callBack.setStatus(RemoteCallBack.FAIL); XxlJobLog log = xxlJobLogDao.load(trigger_log_id); if (log!=null) { log.setHandleTime(new Date()); log.setHandleStatus(status); log.setHandleMsg(msg); xxlJobLogDao.updateHandleInfo(log); callBack.setStatus(RemoteCallBack.SUCCESS); return callBack; } return callBack; }*/ @RequestMapping("/logDetail") @ResponseBody public ReturnT logDetail(int id){ // base check XxlJobLog log = xxlJobLogDao.load(id); if (log == null) { return new ReturnT(500, "参数异常"); } if (!ResponseModel.SUCCESS.equals(log.getTriggerStatus())) { return new ReturnT(500, "调度失败,无法查看执行日志"); } // trigger id, trigger time RequestModel requestModel = new RequestModel(); requestModel.setTimestamp(System.currentTimeMillis()); requestModel.setAction(ActionRepository.LOG.name()); requestModel.setLogId(id); requestModel.setLogDateTim(log.getTriggerTime().getTime()); ResponseModel responseModel = XxlJobNetCommUtil.postHex(XxlJobNetCommUtil.addressToUrl(log.getExecutorAddress()), requestModel); if (ResponseModel.SUCCESS.equals(responseModel.getStatus())) { return new ReturnT(responseModel.getMsg()); } else { return new ReturnT(500, responseModel.getMsg()); } } @RequestMapping("/logDetailPage") public String logDetailPage(int id, Model model){ ReturnT data = logDetail(id); model.addAttribute("result", data); return "joblog/logdetail"; } @RequestMapping("/logKill") @ResponseBody public ReturnT logKill(int id){ // base check XxlJobLog log = xxlJobLogDao.load(id); XxlJobInfo jobInfo = xxlJobInfoDao.load(log.getJobGroup(), log.getJobName()); if (log == null || jobInfo==null) { return new ReturnT(500, "参数异常"); } if (!ResponseModel.SUCCESS.equals(log.getTriggerStatus())) { return new ReturnT(500, "调度失败,无法终止日志"); } // request of kill RequestModel requestModel = new RequestModel(); requestModel.setTimestamp(System.currentTimeMillis()); requestModel.setAction(ActionRepository.KILL.name()); requestModel.setJobGroup(log.getJobGroup()); requestModel.setJobName(log.getJobName()); ResponseModel responseModel = XxlJobNetCommUtil.postHex(XxlJobNetCommUtil.addressToUrl(log.getExecutorAddress()), requestModel); if (ResponseModel.SUCCESS.equals(responseModel.getStatus())) { log.setHandleStatus(ResponseModel.FAIL); log.setHandleMsg("人为操作主动终止"); log.setHandleTime(new Date()); xxlJobLogDao.updateHandleInfo(log); return new ReturnT(responseModel.getMsg()); } else { return new ReturnT(500, responseModel.getMsg()); } } }