2017-04-08 09:15:30 +00:00
|
|
|
package tasklog
|
|
|
|
|
2017-05-10 08:09:10 +00:00
|
|
|
// 任务日志
|
|
|
|
|
2017-04-08 09:15:30 +00:00
|
|
|
import (
|
2018-03-25 05:12:12 +00:00
|
|
|
"github.com/ouqiang/gocron/internal/models"
|
|
|
|
"github.com/ouqiang/gocron/internal/modules/logger"
|
|
|
|
"github.com/ouqiang/gocron/internal/modules/utils"
|
|
|
|
"github.com/ouqiang/gocron/internal/routers/base"
|
|
|
|
"github.com/ouqiang/gocron/internal/service"
|
2018-01-30 11:26:04 +00:00
|
|
|
"gopkg.in/macaron.v1"
|
2017-04-08 09:15:30 +00:00
|
|
|
)
|
|
|
|
|
2018-05-02 12:41:41 +00:00
|
|
|
func Index(ctx *macaron.Context) string {
|
2017-09-16 09:58:33 +00:00
|
|
|
logModel := new(models.TaskLog)
|
|
|
|
queryParams := parseQueryParams(ctx)
|
|
|
|
total, err := logModel.Total(queryParams)
|
|
|
|
if err != nil {
|
|
|
|
logger.Error(err)
|
|
|
|
}
|
|
|
|
logs, err := logModel.List(queryParams)
|
|
|
|
if err != nil {
|
|
|
|
logger.Error(err)
|
|
|
|
}
|
2018-05-02 12:41:41 +00:00
|
|
|
jsonResp := utils.JsonResponse{}
|
|
|
|
|
|
|
|
return jsonResp.Success(utils.SuccessContent, map[string]interface{}{
|
|
|
|
"total": total,
|
|
|
|
"data": logs,
|
|
|
|
})
|
2017-04-13 09:35:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// 清空日志
|
2017-09-16 09:58:33 +00:00
|
|
|
func Clear(ctx *macaron.Context) string {
|
|
|
|
taskLogModel := new(models.TaskLog)
|
|
|
|
_, err := taskLogModel.Clear()
|
|
|
|
json := utils.JsonResponse{}
|
|
|
|
if err != nil {
|
|
|
|
return json.CommonFailure(utils.FailureContent)
|
|
|
|
}
|
2017-04-13 09:35:59 +00:00
|
|
|
|
2017-09-16 09:58:33 +00:00
|
|
|
return json.Success(utils.SuccessContent, nil)
|
2017-04-22 15:39:33 +00:00
|
|
|
}
|
|
|
|
|
2018-01-27 03:10:08 +00:00
|
|
|
// 停止运行中的任务
|
2018-01-30 11:26:04 +00:00
|
|
|
func Stop(ctx *macaron.Context) string {
|
2018-01-27 03:10:08 +00:00
|
|
|
id := ctx.QueryInt64("id")
|
|
|
|
taskId := ctx.QueryInt("task_id")
|
|
|
|
taskModel := new(models.Task)
|
|
|
|
task, err := taskModel.Detail(taskId)
|
|
|
|
json := utils.JsonResponse{}
|
|
|
|
if err != nil {
|
2018-01-30 11:26:04 +00:00
|
|
|
return json.CommonFailure("获取任务信息失败#"+err.Error(), err)
|
2018-01-27 03:10:08 +00:00
|
|
|
}
|
|
|
|
if task.Protocol != models.TaskRPC {
|
|
|
|
return json.CommonFailure("仅支持SHELL任务手动停止")
|
|
|
|
}
|
|
|
|
if len(task.Hosts) == 0 {
|
|
|
|
return json.CommonFailure("任务节点列表为空")
|
|
|
|
}
|
|
|
|
for _, host := range task.Hosts {
|
2018-01-27 10:08:46 +00:00
|
|
|
service.ServiceTask.Stop(host.Name, host.Port, id)
|
2018-01-27 03:10:08 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2018-01-30 11:26:04 +00:00
|
|
|
return json.Success("已执行停止操作, 请等待任务退出", nil)
|
2018-01-27 03:10:08 +00:00
|
|
|
}
|
|
|
|
|
2017-05-10 08:09:10 +00:00
|
|
|
// 删除N个月前的日志
|
|
|
|
func Remove(ctx *macaron.Context) string {
|
2017-09-16 09:58:33 +00:00
|
|
|
month := ctx.ParamsInt(":id")
|
|
|
|
json := utils.JsonResponse{}
|
|
|
|
if month < 1 || month > 12 {
|
|
|
|
return json.CommonFailure("参数取值范围1-12")
|
|
|
|
}
|
|
|
|
taskLogModel := new(models.TaskLog)
|
|
|
|
_, err := taskLogModel.Remove(month)
|
|
|
|
if err != nil {
|
|
|
|
return json.CommonFailure("删除失败", err)
|
|
|
|
}
|
2017-05-10 08:09:10 +00:00
|
|
|
|
2017-09-16 09:58:33 +00:00
|
|
|
return json.Success("删除成功", nil)
|
2017-05-10 08:09:10 +00:00
|
|
|
}
|
|
|
|
|
2017-04-22 15:39:33 +00:00
|
|
|
// 解析查询参数
|
2017-09-16 09:58:33 +00:00
|
|
|
func parseQueryParams(ctx *macaron.Context) models.CommonMap {
|
|
|
|
var params models.CommonMap = models.CommonMap{}
|
|
|
|
params["TaskId"] = ctx.QueryInt("task_id")
|
|
|
|
params["Protocol"] = ctx.QueryInt("protocol")
|
|
|
|
status := ctx.QueryInt("status")
|
|
|
|
if status >= 0 {
|
|
|
|
status -= 1
|
|
|
|
}
|
|
|
|
params["Status"] = status
|
|
|
|
base.ParsePageAndPageSize(ctx, params)
|
2017-04-22 15:39:33 +00:00
|
|
|
|
2017-09-16 09:58:33 +00:00
|
|
|
return params
|
|
|
|
}
|