mirror of https://github.com/ouqiang/gocron
174 lines
6.2 KiB
Go
174 lines
6.2 KiB
Go
{% template "common/header" . %}
|
|
<style type="text/css">
|
|
pre {
|
|
white-space: pre-wrap;
|
|
word-wrap: break-word;
|
|
padding:10px;
|
|
background-color: #4C4C4C;
|
|
color: white;
|
|
}
|
|
</style>
|
|
<div class="ui grid">
|
|
<!--the vertical menu-->
|
|
{% template "task/menu" . %}
|
|
|
|
<div class="twelve wide column">
|
|
{%if .IsAdmin%}
|
|
<div class="pageHeader">
|
|
<div class="segment">
|
|
<h3 class="ui dividing header">
|
|
<div class="content">
|
|
<button class="ui small teal button" onclick="clearLog()">清空日志</button>
|
|
</div>
|
|
</h3>
|
|
</div>
|
|
</div>
|
|
{%end%}
|
|
<form class="ui form">
|
|
<div class="six fields search">
|
|
<div class="field">
|
|
<input type="text" placeholder="任务ID" name="task_id" value="{%if gt .Params.TaskId 0%}{%.Params.TaskId%}{%end%}">
|
|
</div>
|
|
<div class="field">
|
|
<select name="protocol" id="protocol">
|
|
<option value="0">执行方式</option>
|
|
<option value="2" {%if eq .Params.Protocol 2%}selected{%end%} data-match="host_id" data-validate-type="selectProtocol">SHELL</option>
|
|
<option value="1" {%if eq .Params.Protocol 1%}selected{%end%}>HTTP</option>
|
|
</select>
|
|
</div>
|
|
<div class="field">
|
|
<select name="status">
|
|
<option value="0">状态</option>
|
|
<option value="1" {%if eq .Params.Status 0%}selected{%end%} >失败</option>
|
|
<option value="2" {%if eq .Params.Status 1%}selected{%end%}>执行中</option>
|
|
<option value="3" {%if eq .Params.Status 2%}selected{%end%}>成功</option>
|
|
<option value="4" {%if eq .Params.Status 3%}selected{%end%}>取消</option>
|
|
</select>
|
|
</div>
|
|
<div class="field">
|
|
<button class="ui linkedin submit button">搜索</button>
|
|
</div>
|
|
</div>
|
|
</form>
|
|
<table class="ui celled table">
|
|
<thead>
|
|
<tr>
|
|
<th>任务ID</th>
|
|
<th>任务名称</th>
|
|
<th>cron表达式</th>
|
|
<th>执行方式</th>
|
|
<th>重试次数</th>
|
|
<th>任务节点</th>
|
|
<th>执行时长</th>
|
|
<th>状态</th>
|
|
<th>执行结果</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
{%range $i, $v := .Logs%}
|
|
<tr>
|
|
<td><a href="/task?id={%.TaskId%}">{%.TaskId%}</a></td>
|
|
<td>{%.Name%}</td>
|
|
<td>{%.Spec%}</td>
|
|
<td>{%if eq .Protocol 1%} HTTP {%else if eq .Protocol 2%} SHELL {%end%}</td>
|
|
<td>{%.RetryTimes%}</td>
|
|
<td>{%unescape .Hostname%}</td>
|
|
<td>
|
|
{%if and (ne .Status 3) (ne .Status 4)%}
|
|
{%if gt .TotalTime 0%}{%.TotalTime%}秒{%else%}1秒{%end%}<br>
|
|
开始时间: {%.StartTime.Format "2006-01-02 15:04:05" %}<br>
|
|
{%if ne .Status 1%}
|
|
结束时间: {%.EndTime.Format "2006-01-02 15:04:05" %}
|
|
{%end%}
|
|
{%end%}
|
|
</td>
|
|
<td>
|
|
{%if eq .Status 2%}
|
|
成功
|
|
{%else if eq .Status 1%}
|
|
<span style="color:green">执行中</span>
|
|
{%else if eq .Status 0%}
|
|
<span style="color:red">失败</span>
|
|
{%else if eq .Status 3%}
|
|
<span style="color:#4499EE">取消</span>
|
|
{%end%}
|
|
</td>
|
|
<td>
|
|
{%if or (eq .Status 2) (eq .Status 0)%}
|
|
<button class="ui small primary button"
|
|
onclick="showResult('{%.Name%}', '{%.Command%}', '{%.Result%}')"
|
|
>查看结果
|
|
</button>
|
|
{%end%}
|
|
|
|
|
|
{%if $.IsAdmin%}
|
|
{%if and (eq .Status 1) (eq .Protocol 2) %}
|
|
<button class="ui small blue button" onclick="stopTask({%.Id%}, {%.TaskId%})">停止任务</button>
|
|
{%end%}
|
|
{%end%}
|
|
</td>
|
|
</tr>
|
|
{%end%}
|
|
</tbody>
|
|
</table>
|
|
{% template "common/pagination" .%}
|
|
</div>
|
|
</div>
|
|
|
|
<div class="message">
|
|
<result></result>
|
|
</div>
|
|
|
|
<script type="text/x-vue-template" id="task-result">
|
|
<div class="ui modal">
|
|
<i class="close icon"></i>
|
|
<div class="header">
|
|
{{name}}
|
|
</div>
|
|
<div>
|
|
<pre style="background-color:#04477C;color:lightslategray">{{command}}</pre>
|
|
</div>
|
|
<div>
|
|
<pre>{{result}}</pre>
|
|
</div>
|
|
</div>
|
|
</script>
|
|
|
|
<script type="text/javascript">
|
|
function showResult(name, command,result) {
|
|
$('.message').html($('#task-result').html());
|
|
new Vue(
|
|
{
|
|
el: '.message',
|
|
data: {
|
|
result: result.replace(/\\n/,"<br>"),
|
|
name: name,
|
|
command: command
|
|
}
|
|
}
|
|
);
|
|
$('.ui.modal.transition').remove();
|
|
$('.ui.modal').modal({
|
|
detachable: false,
|
|
observeChanges: true
|
|
}).modal('refresh').modal('show');
|
|
}
|
|
|
|
function stopTask(id, taskId) {
|
|
util.confirm("确定要停止任务吗", function () {
|
|
util.post("/task/log/stop/", {id: id, task_id:taskId}, function (code, message) {
|
|
swal('提示', message, 'info');
|
|
});
|
|
});
|
|
}
|
|
|
|
function clearLog() {
|
|
util.confirm("确定要删除所有日志吗?", function() {
|
|
util.post("/task/log/clear",{}, function() {
|
|
location.reload();
|
|
});
|
|
});
|
|
}
|
|
</script>
|
|
{% template "common/footer" . %} |