mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 16:40:24 +08:00 
			
		
		
		
	Fix migration (#10641)
Signed-off-by: jolheiser <john.olheiser@gmail.com>
This commit is contained in:
		@@ -7,17 +7,23 @@ package migrations
 | 
			
		||||
import (
 | 
			
		||||
	"encoding/json"
 | 
			
		||||
 | 
			
		||||
	"code.gitea.io/gitea/modules/setting"
 | 
			
		||||
 | 
			
		||||
	"xorm.io/xorm"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func expandWebhooks(x *xorm.Engine) error {
 | 
			
		||||
 | 
			
		||||
	type ChooseEvents struct {
 | 
			
		||||
	type HookEvents struct {
 | 
			
		||||
		Create               bool `json:"create"`
 | 
			
		||||
		Delete               bool `json:"delete"`
 | 
			
		||||
		Fork                 bool `json:"fork"`
 | 
			
		||||
		Issues               bool `json:"issues"`
 | 
			
		||||
		IssueAssign          bool `json:"issue_assign"`
 | 
			
		||||
		IssueLabel           bool `json:"issue_label"`
 | 
			
		||||
		IssueMilestone       bool `json:"issue_milestone"`
 | 
			
		||||
		IssueComment         bool `json:"issue_comment"`
 | 
			
		||||
		Push                 bool `json:"push"`
 | 
			
		||||
		PullRequest          bool `json:"pull_request"`
 | 
			
		||||
		PullRequestAssign    bool `json:"pull_request_assign"`
 | 
			
		||||
		PullRequestLabel     bool `json:"pull_request_label"`
 | 
			
		||||
@@ -25,14 +31,17 @@ func expandWebhooks(x *xorm.Engine) error {
 | 
			
		||||
		PullRequestComment   bool `json:"pull_request_comment"`
 | 
			
		||||
		PullRequestReview    bool `json:"pull_request_review"`
 | 
			
		||||
		PullRequestSync      bool `json:"pull_request_sync"`
 | 
			
		||||
		Repository           bool `json:"repository"`
 | 
			
		||||
		Release              bool `json:"release"`
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	type Events struct {
 | 
			
		||||
	type HookEvent struct {
 | 
			
		||||
		PushOnly       bool   `json:"push_only"`
 | 
			
		||||
		SendEverything bool   `json:"send_everything"`
 | 
			
		||||
		ChooseEvents   bool   `json:"choose_events"`
 | 
			
		||||
		BranchFilter   string `json:"branch_filter"`
 | 
			
		||||
		Events         ChooseEvents `json:"events"`
 | 
			
		||||
 | 
			
		||||
		HookEvents `json:"events"`
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	type Webhook struct {
 | 
			
		||||
@@ -40,10 +49,9 @@ func expandWebhooks(x *xorm.Engine) error {
 | 
			
		||||
		Events string
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	var events Events
 | 
			
		||||
	var bytes []byte
 | 
			
		||||
	var last int
 | 
			
		||||
	const batchSize = 50
 | 
			
		||||
	batchSize := setting.Database.IterateBufferSize
 | 
			
		||||
	sess := x.NewSession()
 | 
			
		||||
	defer sess.Close()
 | 
			
		||||
	for {
 | 
			
		||||
@@ -63,24 +71,29 @@ func expandWebhooks(x *xorm.Engine) error {
 | 
			
		||||
		last += len(results)
 | 
			
		||||
 | 
			
		||||
		for _, res := range results {
 | 
			
		||||
			var events HookEvent
 | 
			
		||||
			if err = json.Unmarshal([]byte(res.Events), &events); err != nil {
 | 
			
		||||
				return err
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
			if events.Events.Issues {
 | 
			
		||||
				events.Events.IssueAssign = true
 | 
			
		||||
				events.Events.IssueLabel = true
 | 
			
		||||
				events.Events.IssueMilestone = true
 | 
			
		||||
				events.Events.IssueComment = true
 | 
			
		||||
			if !events.ChooseEvents {
 | 
			
		||||
				continue
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
			if events.Events.PullRequest {
 | 
			
		||||
				events.Events.PullRequestAssign = true
 | 
			
		||||
				events.Events.PullRequestLabel = true
 | 
			
		||||
				events.Events.PullRequestMilestone = true
 | 
			
		||||
				events.Events.PullRequestComment = true
 | 
			
		||||
				events.Events.PullRequestReview = true
 | 
			
		||||
				events.Events.PullRequestSync = true
 | 
			
		||||
			if events.Issues {
 | 
			
		||||
				events.IssueAssign = true
 | 
			
		||||
				events.IssueLabel = true
 | 
			
		||||
				events.IssueMilestone = true
 | 
			
		||||
				events.IssueComment = true
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
			if events.PullRequest {
 | 
			
		||||
				events.PullRequestAssign = true
 | 
			
		||||
				events.PullRequestLabel = true
 | 
			
		||||
				events.PullRequestMilestone = true
 | 
			
		||||
				events.PullRequestComment = true
 | 
			
		||||
				events.PullRequestReview = true
 | 
			
		||||
				events.PullRequestSync = true
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
			if bytes, err = json.Marshal(&events); err != nil {
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user