mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-12-15 14:08:21 +00:00
65248945c9
Clarify when "string" should be used (and be escaped), and when "template.HTML" should be used (no need to escape) And help PRs like #29059 , to render the error messages correctly. (cherry picked from commit f3eb835886031df7a562abc123c3f6011c81eca8) Conflicts: modules/web/middleware/binding.go routers/web/feed/convert.go tests/integration/branches_test.go tests/integration/repo_branch_test.go trivial context conflicts
87 lines
2.4 KiB
Go
87 lines
2.4 KiB
Go
// Copyright 2020 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package cron
|
|
|
|
import (
|
|
"time"
|
|
|
|
"code.gitea.io/gitea/modules/translation"
|
|
)
|
|
|
|
// Config represents a basic configuration interface that cron task
|
|
type Config interface {
|
|
IsEnabled() bool
|
|
DoRunAtStart() bool
|
|
GetSchedule() string
|
|
FormatMessage(locale translation.Locale, name, status, doer string, args ...any) string
|
|
DoNoticeOnSuccess() bool
|
|
}
|
|
|
|
// BaseConfig represents the basic config for a Cron task
|
|
type BaseConfig struct {
|
|
Enabled bool
|
|
RunAtStart bool
|
|
Schedule string
|
|
NoticeOnSuccess bool
|
|
}
|
|
|
|
// 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
|
|
}
|
|
|
|
// CleanupHookTaskConfig represents a cron task with settings to cleanup hook_task
|
|
type CleanupHookTaskConfig struct {
|
|
BaseConfig
|
|
CleanupType string
|
|
OlderThan time.Duration
|
|
NumberToKeep int
|
|
}
|
|
|
|
// 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
|
|
}
|
|
|
|
// DoNoticeOnSuccess returns whether a success notice should be posted
|
|
func (b *BaseConfig) DoNoticeOnSuccess() bool {
|
|
return b.NoticeOnSuccess
|
|
}
|
|
|
|
// FormatMessage returns a message for the task
|
|
// 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 translation.Locale, name, status, doer string, args ...any) string {
|
|
realArgs := make([]any, 0, len(args)+2)
|
|
realArgs = append(realArgs, locale.TrString("admin.dashboard."+name))
|
|
if doer == "" {
|
|
realArgs = append(realArgs, "(Cron)")
|
|
} else {
|
|
realArgs = append(realArgs, doer)
|
|
}
|
|
if len(args) > 0 {
|
|
realArgs = append(realArgs, args...)
|
|
}
|
|
if doer == "" {
|
|
return locale.TrString("admin.dashboard.cron."+status, realArgs...)
|
|
}
|
|
return locale.TrString("admin.dashboard.task."+status, realArgs...)
|
|
}
|