2018-01-28 07:48:37 +00:00
|
|
|
{% template "common/header" . %}
|
2017-04-08 09:15:30 +00:00
|
|
|
<div class="ui grid">
|
2018-01-28 07:48:37 +00:00
|
|
|
{%template "task/menu" .%}
|
2017-04-08 09:15:30 +00:00
|
|
|
<div class="twelve wide column">
|
2018-01-28 07:48:37 +00:00
|
|
|
{%if .IsAdmin%}
|
2017-10-01 14:53:22 +00:00
|
|
|
<div class="pageHeader">
|
2017-04-08 09:15:30 +00:00
|
|
|
<div class="segment">
|
|
|
|
<h3 class="ui dividing header">
|
2017-04-23 06:11:53 +00:00
|
|
|
<a href="/task/create">
|
|
|
|
<i class="large add icon"></i>
|
|
|
|
<div class="content">
|
2017-04-26 08:17:18 +00:00
|
|
|
添加任务
|
2017-04-23 06:11:53 +00:00
|
|
|
</div>
|
|
|
|
</a>
|
2017-04-08 09:15:30 +00:00
|
|
|
</h3>
|
|
|
|
</div>
|
|
|
|
</div>
|
2018-01-28 07:48:37 +00:00
|
|
|
{%end%}
|
2017-04-21 09:41:59 +00:00
|
|
|
<form class="ui form">
|
2017-04-22 15:39:33 +00:00
|
|
|
<div class="six fields search">
|
|
|
|
<div class="one wide field">
|
2018-01-28 07:48:37 +00:00
|
|
|
<input type="text" placeholder="任务ID" name="id" value="{%if gt .Params.Id 0%}{%.Params.Id%}{%end%}">
|
2017-04-22 15:39:33 +00:00
|
|
|
</div>
|
2017-04-21 09:41:59 +00:00
|
|
|
<div class="field">
|
2018-01-28 07:48:37 +00:00
|
|
|
<input type="text" placeholder="任务名称" name="name" value="{%.Params.Name%}">
|
2017-04-21 09:41:59 +00:00
|
|
|
</div>
|
2017-09-07 13:32:53 +00:00
|
|
|
<div class="field">
|
2018-01-28 07:48:37 +00:00
|
|
|
<input type="text" placeholder="标签名称" name="tag" value="{%.Params.Tag%}">
|
2017-09-07 13:32:53 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="six fields search">
|
2017-04-21 09:41:59 +00:00
|
|
|
<div class="field">
|
2017-04-22 15:39:33 +00:00
|
|
|
<select name="host_id" id="hostId">
|
2017-07-22 01:24:50 +00:00
|
|
|
<option value="">选择节点</option>
|
2018-01-28 07:48:37 +00:00
|
|
|
{%range $i, $v := .Hosts%}
|
|
|
|
<option value="{%.Id%}" {%if eq $.Params.HostId .Id %} selected {%end%} >{%.Alias%}-{%.Name%}</option>
|
|
|
|
{%end%}
|
2017-04-22 15:39:33 +00:00
|
|
|
</select>
|
2017-04-21 09:41:59 +00:00
|
|
|
</div>
|
|
|
|
<div class="field">
|
2017-04-22 15:39:33 +00:00
|
|
|
<select name="protocol" id="protocol">
|
2017-05-04 02:47:14 +00:00
|
|
|
<option value="0">执行方式</option>
|
2018-01-28 07:48:37 +00:00
|
|
|
<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>
|
2017-04-22 15:39:33 +00:00
|
|
|
</select>
|
2017-04-21 09:41:59 +00:00
|
|
|
</div>
|
|
|
|
<div class="field">
|
2017-04-22 15:39:33 +00:00
|
|
|
<select name="status">
|
|
|
|
<option value="0">状态</option>
|
2018-01-28 07:48:37 +00:00
|
|
|
<option value="1" {%if eq .Params.Status 0%}selected{%end%} >停止</option>
|
|
|
|
<option value="2" {%if eq .Params.Status 1%}selected{%end%}>激活</option>
|
2017-04-22 15:39:33 +00:00
|
|
|
</select>
|
2017-04-21 09:41:59 +00:00
|
|
|
</div>
|
|
|
|
<div class="field">
|
|
|
|
<button class="ui linkedin submit button">搜索</button>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</form>
|
2018-01-28 07:48:37 +00:00
|
|
|
{%if .IsAdmin%}
|
2017-10-01 14:53:22 +00:00
|
|
|
<div class="field">
|
|
|
|
<select id="batch-operation">
|
|
|
|
<option value="0">批量操作</option>
|
|
|
|
<option value="1">激活</option>
|
|
|
|
<option value="2">停止</option>
|
|
|
|
<option value="3">删除</option>
|
|
|
|
</select>
|
|
|
|
</div>
|
2018-01-28 07:48:37 +00:00
|
|
|
{%end%}
|
2017-09-05 14:31:16 +00:00
|
|
|
<br>
|
2017-09-03 13:30:03 +00:00
|
|
|
<table class="ui celled table task-list">
|
2017-05-18 04:00:55 +00:00
|
|
|
<thead>
|
|
|
|
<tr>
|
2018-01-28 07:48:37 +00:00
|
|
|
{%if .IsAdmin%}
|
2017-10-01 14:53:22 +00:00
|
|
|
<th>
|
|
|
|
<input type="checkbox" onclick="checkAll(this)" style="width:25px;height: 25px;">
|
|
|
|
</th>
|
2018-01-28 07:48:37 +00:00
|
|
|
{%end%}
|
2017-05-18 04:00:55 +00:00
|
|
|
<th>任务ID</th>
|
|
|
|
<th>任务名称</th>
|
2017-06-08 10:04:55 +00:00
|
|
|
<th>任务类型</th>
|
2017-09-07 13:32:53 +00:00
|
|
|
<th>标签</th>
|
2017-05-18 04:00:55 +00:00
|
|
|
<th>cron表达式</th>
|
|
|
|
<th>执行方式</th>
|
|
|
|
<th>超时时间</th>
|
|
|
|
<th>重试次数</th>
|
|
|
|
<th>单实例运行</th>
|
2017-07-22 01:24:50 +00:00
|
|
|
<th>任务节点</th>
|
2017-05-18 04:00:55 +00:00
|
|
|
<th>状态</th>
|
|
|
|
<th>操作</th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
2018-01-28 07:48:37 +00:00
|
|
|
{%range $i, $v := .Tasks%}
|
2017-05-18 04:00:55 +00:00
|
|
|
<tr>
|
2018-01-28 07:48:37 +00:00
|
|
|
{%if $.IsAdmin%}
|
2017-10-01 14:53:22 +00:00
|
|
|
<td>
|
|
|
|
<input type="checkbox"
|
|
|
|
class="sub-check"
|
2018-01-28 07:48:37 +00:00
|
|
|
data-id="{%.Id%}"
|
2017-10-01 14:53:22 +00:00
|
|
|
style="width:25px;height: 25px;">
|
|
|
|
</td>
|
2018-01-28 07:48:37 +00:00
|
|
|
{%end%}
|
|
|
|
<td>{%.Id%}</td>
|
|
|
|
<td>{%.Name%}</td>
|
|
|
|
<td>{%if eq .Level 1%}主任务{%else%}子任务{%end%}</td>
|
|
|
|
<td>{%.Tag%}</td>
|
|
|
|
<td>{%.Spec%}</td>
|
|
|
|
<td>{%if eq .Protocol 1%} HTTP {%else if eq .Protocol 2%} SHELL {%end%}</td>
|
|
|
|
<td>{%if eq .Timeout -1%}后台运行{%else if gt .Timeout 0%}{%.Timeout%}秒{%else%}不限制{%end%}</td>
|
|
|
|
<td>{%.RetryTimes%}</td>
|
|
|
|
<td>{%if gt .Multi 0%}否{%else%}是{%end%}</td>
|
2017-08-06 14:49:24 +00:00
|
|
|
<td>
|
2018-01-28 07:48:37 +00:00
|
|
|
{%range $k, $h := .Hosts%}
|
|
|
|
{%$h.Alias%}<br>
|
|
|
|
{%end%}
|
2017-08-06 14:49:24 +00:00
|
|
|
</td>
|
2017-06-08 10:04:55 +00:00
|
|
|
<td>
|
2018-01-28 07:48:37 +00:00
|
|
|
{%if eq .Level 1%}
|
|
|
|
{%if eq .Status 1%}<span><i class="checkmark big icon"></i></span>{%else%}<span><i class="minus big icon"></i><span>{%end%}
|
|
|
|
{%end%}
|
2017-06-08 10:04:55 +00:00
|
|
|
</td>
|
2017-05-18 04:00:55 +00:00
|
|
|
<td>
|
|
|
|
<div class="ui buttons operation">
|
2018-01-28 07:48:37 +00:00
|
|
|
{%if $.IsAdmin%}
|
|
|
|
<a href="/task/edit/{%.Id%}" ><i class="edit big icon" title="编辑"></i></a>
|
|
|
|
{%if eq .Level 1%}
|
|
|
|
{%if eq .Status 1%}
|
|
|
|
<a href="javascript:void(0);" @click="changeStatus({%.Id%},{%.Status%})"><i class="pause circle big icon" title="停止"></i></a>
|
|
|
|
{%else%}
|
|
|
|
<a href="javascript:void(0);" @click="changeStatus({%.Id%},{%.Status%})"><i class="play big icon" title="激活"></i></a>
|
|
|
|
{%end%}
|
|
|
|
{%end%}
|
|
|
|
<a href="javascript:void(0);" @click="remove({%.Id%})"><i class="remove big icon" title="删除"></i></a>
|
|
|
|
<a href="javascript:void(0);" @click="run({%.Id%})"><i class="rocket big icon" title="手动执行"></i></a>
|
|
|
|
{%end%}
|
2017-10-01 14:53:22 +00:00
|
|
|
|
2018-01-28 07:48:37 +00:00
|
|
|
<a href="/task/log?task_id={%.Id%}"><i class="bar chart icon big" title="查看日志"></i></a>
|
2017-05-18 04:00:55 +00:00
|
|
|
</div>
|
|
|
|
</td>
|
|
|
|
</tr>
|
2018-01-28 07:48:37 +00:00
|
|
|
{%end%}
|
2017-05-18 04:00:55 +00:00
|
|
|
</tbody>
|
|
|
|
</table>
|
2018-01-28 07:48:37 +00:00
|
|
|
{% template "common/pagination" .%}
|
2017-04-08 09:15:30 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<script type="text/javascript">
|
2017-04-10 09:37:16 +00:00
|
|
|
$('.ui.checkbox').checkbox();
|
2017-04-13 09:35:59 +00:00
|
|
|
|
2017-09-05 14:31:16 +00:00
|
|
|
$('#batch-operation').change(function() {
|
|
|
|
var type = $(this).val();
|
|
|
|
if (type == 0) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
var ids = [];
|
|
|
|
$('.sub-check:checked').each(function() {
|
|
|
|
ids.push($(this).data('id'));
|
|
|
|
});
|
|
|
|
if (ids.length == 0) {
|
|
|
|
swal('错误提示', '至少选择一个任务', 'warning');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
util.confirm("确定要执行此操作吗", function () {
|
|
|
|
$.ajaxSetup({
|
|
|
|
async: false
|
|
|
|
});
|
|
|
|
switch (type) {
|
|
|
|
case "1":
|
|
|
|
for (i in ids) {
|
|
|
|
changeStatus(ids[i], false, true);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case "2":
|
|
|
|
for (i in ids) {
|
|
|
|
changeStatus(ids[i], true, true);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case "3":
|
|
|
|
for (i in ids) {
|
|
|
|
remove(ids[i], true);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
location.reload();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-04-21 05:36:45 +00:00
|
|
|
var vue = new Vue(
|
|
|
|
{
|
2017-04-23 09:00:47 +00:00
|
|
|
el: '.task-list',
|
2017-04-21 05:36:45 +00:00
|
|
|
methods: {
|
2017-09-05 14:31:16 +00:00
|
|
|
changeStatus: changeStatus,
|
|
|
|
remove: remove,
|
2017-04-21 05:36:45 +00:00
|
|
|
run: function(id) {
|
|
|
|
util.get("/task/run/" + id, function(code, message) {
|
|
|
|
swal('操作成功', message, 'success');
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
2017-09-05 14:31:16 +00:00
|
|
|
function checkAll(ele) {
|
|
|
|
if ($(ele).is(":checked")) {
|
|
|
|
$('.sub-check').prop("checked", true);
|
|
|
|
} else {
|
|
|
|
$('.sub-check').prop("checked", false);
|
|
|
|
}
|
|
|
|
}
|
2017-04-21 05:36:45 +00:00
|
|
|
|
2017-09-05 14:31:16 +00:00
|
|
|
function remove(id, stopReload) {
|
2017-12-09 02:16:30 +00:00
|
|
|
var url = '/task/remove/' + id;
|
|
|
|
if (stopReload === undefined) {
|
|
|
|
util.removeConfirm(url);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
util.post(url, {}, function () {
|
2017-09-05 14:31:16 +00:00
|
|
|
if (stopReload === undefined) {
|
|
|
|
location.reload();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2017-04-13 09:35:59 +00:00
|
|
|
|
2017-09-05 14:31:16 +00:00
|
|
|
function changeStatus(id ,status, stopReload) {
|
|
|
|
var url = '';
|
|
|
|
if (status) {
|
|
|
|
url = '/task/disable';
|
|
|
|
} else {
|
|
|
|
url = '/task/enable';
|
|
|
|
}
|
|
|
|
url += '/' + id;
|
|
|
|
util.post(url,{}, function() {
|
|
|
|
if (stopReload === undefined) {
|
|
|
|
location.reload();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2017-04-08 09:15:30 +00:00
|
|
|
</script>
|
|
|
|
|
2018-01-28 07:48:37 +00:00
|
|
|
{% template "common/footer" . %}
|