49 lines
1.6 KiB
Go
49 lines
1.6 KiB
Go
package tasksch
|
|
|
|
import (
|
|
"sort"
|
|
"time"
|
|
)
|
|
|
|
var (
|
|
defTaskMan TaskMan
|
|
defLastHours = 24
|
|
)
|
|
|
|
type TaskMan struct {
|
|
taskList map[string]ITask
|
|
}
|
|
|
|
func init() {
|
|
defTaskMan.taskList = make(map[string]ITask)
|
|
}
|
|
|
|
func (m *TaskMan) RunTask(taskName string, isContinueWhenError bool, resultHandler ResultHandlerFunc, parallelCount, batchSize int, userName string, worker WorkFunc, itemList interface{}, params ...interface{}) *Task {
|
|
task := RunTask(taskName, isContinueWhenError, resultHandler, parallelCount, batchSize, userName, worker, itemList, params...)
|
|
m.taskList[task.ID] = task
|
|
return task
|
|
}
|
|
|
|
func (m *TaskMan) GetTasks(taskID string, fromStatus, toStatus int, lastHours int) (taskList TaskList) {
|
|
if lastHours == 0 {
|
|
lastHours = defLastHours
|
|
}
|
|
lastTime := time.Now().Add(time.Duration(-lastHours) * time.Hour).Unix()
|
|
for k, v := range m.taskList {
|
|
status := v.GetStatus()
|
|
if !((taskID != "" && taskID != k) || status < fromStatus || status > toStatus || v.GetCreatedAt().Unix() < lastTime) {
|
|
taskList = append(taskList, v)
|
|
}
|
|
}
|
|
sort.Sort(TaskList(taskList))
|
|
return taskList
|
|
}
|
|
|
|
func RunManagedTask(taskName string, isContinueWhenError bool, resultHandler ResultHandlerFunc, parallelCount, batchSize int, userName string, worker WorkFunc, itemList interface{}, params ...interface{}) *Task {
|
|
return defTaskMan.RunTask(taskName, isContinueWhenError, resultHandler, parallelCount, batchSize, userName, worker, itemList, params...)
|
|
}
|
|
|
|
func GetTasks(taskID string, fromStatus, toStatus int, lastHours int) (taskList TaskList) {
|
|
return defTaskMan.GetTasks(taskID, fromStatus, toStatus, lastHours)
|
|
}
|