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 (
|
|
|
|
"gopkg.in/macaron.v1"
|
|
|
|
"github.com/ouqiang/gocron/models"
|
|
|
|
"github.com/ouqiang/gocron/modules/logger"
|
2017-04-13 09:35:59 +00:00
|
|
|
"github.com/ouqiang/gocron/modules/utils"
|
2017-04-23 06:11:53 +00:00
|
|
|
"github.com/Unknwon/paginater"
|
|
|
|
"fmt"
|
|
|
|
"html/template"
|
2017-04-30 22:02:49 +00:00
|
|
|
"github.com/ouqiang/gocron/routers/base"
|
2017-05-10 09:58:05 +00:00
|
|
|
"github.com/ouqiang/gocron/service"
|
|
|
|
"errors"
|
2017-04-08 09:15:30 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func Index(ctx *macaron.Context) {
|
|
|
|
logModel := new(models.TaskLog)
|
2017-04-22 15:39:33 +00:00
|
|
|
queryParams := parseQueryParams(ctx)
|
2017-04-23 06:11:53 +00:00
|
|
|
total, err := logModel.Total(queryParams)
|
|
|
|
if err != nil {
|
|
|
|
logger.Error(err)
|
|
|
|
}
|
2017-04-22 15:39:33 +00:00
|
|
|
logs, err := logModel.List(queryParams)
|
2017-04-08 09:15:30 +00:00
|
|
|
if err != nil {
|
|
|
|
logger.Error(err)
|
|
|
|
}
|
2017-04-23 06:11:53 +00:00
|
|
|
PageParams := fmt.Sprintf("task_id=%d&protocol=%d&status=%d&page_size=%d",
|
|
|
|
queryParams["TaskId"], queryParams["Protocol"], queryParams["Status"],
|
|
|
|
queryParams["PageSize"]);
|
|
|
|
queryParams["PageParams"] = template.URL(PageParams)
|
|
|
|
p := paginater.New(int(total), queryParams["PageSize"].(int), queryParams["Page"].(int), 5)
|
|
|
|
ctx.Data["Pagination"] = p
|
2017-04-08 09:15:30 +00:00
|
|
|
ctx.Data["Title"] = "任务日志"
|
|
|
|
ctx.Data["Logs"] = logs
|
2017-04-22 15:39:33 +00:00
|
|
|
ctx.Data["Params"] = queryParams
|
2017-04-08 09:15:30 +00:00
|
|
|
ctx.HTML(200, "task/log")
|
2017-04-13 09:35:59 +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)
|
|
|
|
}
|
|
|
|
|
|
|
|
return json.Success(utils.SuccessContent, nil)
|
2017-04-22 15:39:33 +00:00
|
|
|
}
|
|
|
|
|
2017-05-10 08:09:10 +00:00
|
|
|
// 删除N个月前的日志
|
|
|
|
func Remove(ctx *macaron.Context) string {
|
|
|
|
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)
|
|
|
|
}
|
|
|
|
|
|
|
|
return json.Success("删除成功", nil)
|
|
|
|
}
|
|
|
|
|
2017-05-04 02:47:14 +00:00
|
|
|
// 更新任务状态
|
|
|
|
func UpdateStatus(ctx *macaron.Context) string {
|
|
|
|
id := ctx.QueryTrim("id")
|
|
|
|
status := ctx.QueryInt("status")
|
|
|
|
result := ctx.QueryTrim("result")
|
|
|
|
json := utils.JsonResponse{}
|
2017-05-10 08:09:10 +00:00
|
|
|
|
2017-05-04 02:47:14 +00:00
|
|
|
if id == "" {
|
|
|
|
return json.CommonFailure("任务ID不能为空")
|
|
|
|
}
|
|
|
|
if status != 1 && status != 2 {
|
|
|
|
return json.CommonFailure("status值错误")
|
|
|
|
}
|
|
|
|
if status == 1 {
|
|
|
|
status -= 1
|
|
|
|
}
|
|
|
|
taskLogModel := new(models.TaskLog)
|
|
|
|
affectRows, err := taskLogModel.UpdateStatus(id, models.Status(status), result)
|
|
|
|
if err != nil || affectRows == 0 {
|
|
|
|
return json.CommonFailure("更新任务状态失败")
|
|
|
|
}
|
|
|
|
|
2017-05-10 09:58:05 +00:00
|
|
|
// 发送通知
|
|
|
|
taskId, err := taskLogModel.GetTaskIdByNotifyId(id)
|
|
|
|
if err != nil || taskId <= 0 {
|
|
|
|
logger.Error("异步任务回调#根据notify-id获取taskId失败", err)
|
|
|
|
return json.Success("success", nil)
|
|
|
|
}
|
|
|
|
taskModel := new(models.Task)
|
|
|
|
task, err := taskModel.Detail(taskId)
|
|
|
|
if err != nil || task.Id <= 0 {
|
|
|
|
logger.Error("异步任务回调#根据获取任务详情失败", err)
|
|
|
|
return json.Success("success", nil)
|
|
|
|
}
|
|
|
|
|
|
|
|
taskResult := service.TaskResult{}
|
|
|
|
taskResult.Result = result
|
|
|
|
if status == 0 {
|
|
|
|
taskResult.Err = errors.New("error")
|
|
|
|
}
|
|
|
|
service.SendNotification(task, taskResult)
|
|
|
|
|
2017-05-04 02:47:14 +00:00
|
|
|
return json.Success("success", nil)
|
|
|
|
}
|
|
|
|
|
2017-04-22 15:39: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")
|
2017-04-23 06:11:53 +00:00
|
|
|
status := ctx.QueryInt("status")
|
|
|
|
if status >=0 {
|
|
|
|
status -= 1
|
|
|
|
}
|
|
|
|
params["Status"] = status
|
2017-04-30 22:02:49 +00:00
|
|
|
base.ParsePageAndPageSize(ctx, params)
|
2017-04-22 15:39:33 +00:00
|
|
|
|
|
|
|
return params
|
2017-04-08 09:15:30 +00:00
|
|
|
}
|