mirror of
				https://gitcode.com/gitea/gitea.git
				synced 2025-10-26 05:04:27 +08:00 
			
		
		
		
	 a598877fdf
			
		
	
	a598877fdf
	
	
	
		
			
			Close **Prune hook_task Table (#10741)** Added a cron job to delete webhook deliveries in the hook_task table. It can be turned on/off and the schedule controlled globally via app.ini. The data can be deleted by either the age of the delivery which is the default or by deleting the all but the most recent deliveries _per webhook_. Note: I had previously submitted pr #11416 but I closed it when I realized that I had deleted per repository instead of per webhook. Also, I decided allowing the settings to be overridden via the ui was overkill. Also this version allows the deletion by age which is probably what most people would want.
		
			
				
	
	
		
			88 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // 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"
 | |
| 
 | |
| 	"code.gitea.io/gitea/models"
 | |
| 	"github.com/unknwon/i18n"
 | |
| )
 | |
| 
 | |
| // Config represents a basic configuration interface that cron task
 | |
| type Config interface {
 | |
| 	IsEnabled() bool
 | |
| 	DoRunAtStart() bool
 | |
| 	GetSchedule() string
 | |
| 	FormatMessage(name, status string, doer *models.User, args ...interface{}) string
 | |
| 	DoNoticeOnSuccess() bool
 | |
| }
 | |
| 
 | |
| // BaseConfig represents the basic config for a Cron task
 | |
| type BaseConfig struct {
 | |
| 	Enabled         bool
 | |
| 	RunAtStart      bool
 | |
| 	Schedule        string
 | |
| 	NoSuccessNotice 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.NoSuccessNotice
 | |
| }
 | |
| 
 | |
| // FormatMessage returns a message for the task
 | |
| func (b *BaseConfig) FormatMessage(name, status string, doer *models.User, args ...interface{}) string {
 | |
| 	realArgs := make([]interface{}, 0, len(args)+2)
 | |
| 	realArgs = append(realArgs, i18n.Tr("en-US", "admin.dashboard."+name))
 | |
| 	if doer == nil {
 | |
| 		realArgs = append(realArgs, "(Cron)")
 | |
| 	} else {
 | |
| 		realArgs = append(realArgs, doer.Name)
 | |
| 	}
 | |
| 	if len(args) > 0 {
 | |
| 		realArgs = append(realArgs, args...)
 | |
| 	}
 | |
| 	if doer == nil || (doer.ID == -1 && doer.Name == "(Cron)") {
 | |
| 		return i18n.Tr("en-US", "admin.dashboard.cron."+status, realArgs...)
 | |
| 	}
 | |
| 	return i18n.Tr("en-US", "admin.dashboard.task."+status, realArgs...)
 | |
| }
 |