2020-05-17 07:31:38 +08:00
// Copyright 2020 The Gitea Authors. All rights reserved.
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file.
package cron
import (
"time"
"github.com/unknwon/i18n"
)
// Config represents a basic configuration interface that cron task
type Config interface {
IsEnabled ( ) bool
DoRunAtStart ( ) bool
GetSchedule ( ) string
2022-03-29 09:31:07 +08:00
FormatMessage ( locale , name , status , doer string , args ... interface { } ) string
2020-08-06 04:40:36 +08:00
DoNoticeOnSuccess ( ) bool
2020-05-17 07:31:38 +08:00
}
// BaseConfig represents the basic config for a Cron task
type BaseConfig struct {
2020-08-06 04:40:36 +08:00
Enabled bool
RunAtStart bool
Schedule string
2022-03-27 05:13:04 +08:00
NoticeOnSuccess bool
2020-05-17 07:31:38 +08:00
}
// OlderThanConfig represents a cron task with OlderThan setting
type OlderThanConfig struct {
BaseConfig
OlderThan time . Duration
}
// UpdateExistingConfig represents a cron task with UpdateExisting setting
type UpdateExistingConfig struct {
BaseConfig
UpdateExisting bool
}
2021-01-27 05:02:42 +08:00
// CleanupHookTaskConfig represents a cron task with settings to cleanup hook_task
type CleanupHookTaskConfig struct {
BaseConfig
CleanupType string
OlderThan time . Duration
NumberToKeep int
}
2020-05-17 07:31:38 +08:00
// GetSchedule returns the schedule for the base config
func ( b * BaseConfig ) GetSchedule ( ) string {
return b . Schedule
}
// IsEnabled returns the enabled status for the config
func ( b * BaseConfig ) IsEnabled ( ) bool {
return b . Enabled
}
// DoRunAtStart returns whether the task should be run at the start
func ( b * BaseConfig ) DoRunAtStart ( ) bool {
return b . RunAtStart
}
2020-08-06 04:40:36 +08:00
// DoNoticeOnSuccess returns whether a success notice should be posted
func ( b * BaseConfig ) DoNoticeOnSuccess ( ) bool {
2022-03-27 05:13:04 +08:00
return b . NoticeOnSuccess
2020-08-06 04:40:36 +08:00
}
2020-05-17 07:31:38 +08:00
// FormatMessage returns a message for the task
2022-03-29 09:31:07 +08:00
// Please note the `status` string will be concatenated with `admin.dashboard.cron.` and `admin.dashboard.task.` to provide locale messages. Similarly `name` will be composed with `admin.dashboard.` to provide the locale name for the task.
func ( b * BaseConfig ) FormatMessage ( locale , name , status , doer string , args ... interface { } ) string {
2020-05-17 07:31:38 +08:00
realArgs := make ( [ ] interface { } , 0 , len ( args ) + 2 )
2022-03-29 09:31:07 +08:00
realArgs = append ( realArgs , i18n . Tr ( locale , "admin.dashboard." + name ) )
if doer == "" {
2020-05-17 07:31:38 +08:00
realArgs = append ( realArgs , "(Cron)" )
} else {
2022-03-29 09:31:07 +08:00
realArgs = append ( realArgs , doer )
2020-05-17 07:31:38 +08:00
}
if len ( args ) > 0 {
realArgs = append ( realArgs , args ... )
}
2022-03-29 09:31:07 +08:00
if doer == "" {
return i18n . Tr ( locale , "admin.dashboard.cron." + status , realArgs ... )
2020-05-17 07:31:38 +08:00
}
2022-03-29 09:31:07 +08:00
return i18n . Tr ( locale , "admin.dashboard.task." + status , realArgs ... )
2020-05-17 07:31:38 +08:00
}