From 6edfa6bc88ed73fc5a31f1b2fe9f5587c932ada7 Mon Sep 17 00:00:00 2001 From: Lunny Xiao Date: Thu, 10 Dec 2020 01:20:13 +0800 Subject: Fix broken migration on webhook (#13911) * Fix broken migration on webhook * Fix lint Co-authored-by: John Olheiser --- models/migrations/migrations.go | 2 ++ models/migrations/v162.go | 59 +++++++++++++++++++++++++++++++++++++++++ models/repo_generate.go | 22 +++++++-------- models/webhook.go | 10 +++---- 4 files changed, 77 insertions(+), 16 deletions(-) create mode 100644 models/migrations/v162.go (limited to 'models') diff --git a/models/migrations/migrations.go b/models/migrations/migrations.go index d2ad20a36c..cac36edf50 100644 --- a/models/migrations/migrations.go +++ b/models/migrations/migrations.go @@ -267,6 +267,8 @@ var migrations = []Migration{ NewMigration("Add block on official review requests branch protection", addBlockOnOfficialReviewRequests), // v161 -> v162 NewMigration("Convert task type from int to string", convertTaskTypeToString), + // v162 -> v163 + NewMigration("Convert webhook task type from int to string", convertWebhookTaskTypeToString), } // GetCurrentDBVersion returns the current db version diff --git a/models/migrations/v162.go b/models/migrations/v162.go new file mode 100644 index 0000000000..b65eb4cd94 --- /dev/null +++ b/models/migrations/v162.go @@ -0,0 +1,59 @@ +// 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 migrations + +import ( + "xorm.io/xorm" +) + +func convertWebhookTaskTypeToString(x *xorm.Engine) error { + const ( + GOGS int = iota + 1 + SLACK + GITEA + DISCORD + DINGTALK + TELEGRAM + MSTEAMS + FEISHU + MATRIX + ) + + var hookTaskTypes = map[int]string{ + GITEA: "gitea", + GOGS: "gogs", + SLACK: "slack", + DISCORD: "discord", + DINGTALK: "dingtalk", + TELEGRAM: "telegram", + MSTEAMS: "msteams", + FEISHU: "feishu", + MATRIX: "matrix", + } + + type Webhook struct { + Type string `xorm:"char(16) index"` + } + if err := x.Sync2(new(Webhook)); err != nil { + return err + } + + for i, s := range hookTaskTypes { + if _, err := x.Exec("UPDATE webhook set type = ? where hook_task_type=?", s, i); err != nil { + return err + } + } + + sess := x.NewSession() + defer sess.Close() + if err := sess.Begin(); err != nil { + return err + } + if err := dropTableColumns(sess, "webhook", "hook_task_type"); err != nil { + return err + } + + return sess.Commit() +} diff --git a/models/repo_generate.go b/models/repo_generate.go index 0b234d8e34..b0016494c4 100644 --- a/models/repo_generate.go +++ b/models/repo_generate.go @@ -117,17 +117,17 @@ func GenerateWebhooks(ctx DBContext, templateRepo, generateRepo *Repository) err for _, templateWebhook := range templateWebhooks { generateWebhook := &Webhook{ - RepoID: generateRepo.ID, - URL: templateWebhook.URL, - HTTPMethod: templateWebhook.HTTPMethod, - ContentType: templateWebhook.ContentType, - Secret: templateWebhook.Secret, - HookEvent: templateWebhook.HookEvent, - IsActive: templateWebhook.IsActive, - HookTaskType: templateWebhook.HookTaskType, - OrgID: templateWebhook.OrgID, - Events: templateWebhook.Events, - Meta: templateWebhook.Meta, + RepoID: generateRepo.ID, + URL: templateWebhook.URL, + HTTPMethod: templateWebhook.HTTPMethod, + ContentType: templateWebhook.ContentType, + Secret: templateWebhook.Secret, + HookEvent: templateWebhook.HookEvent, + IsActive: templateWebhook.IsActive, + Type: templateWebhook.Type, + OrgID: templateWebhook.OrgID, + Events: templateWebhook.Events, + Meta: templateWebhook.Meta, } if err := createWebhook(ctx.e, generateWebhook); err != nil { return err diff --git a/models/webhook.go b/models/webhook.go index 39122808fe..dbad2d3449 100644 --- a/models/webhook.go +++ b/models/webhook.go @@ -110,11 +110,11 @@ type Webhook struct { Secret string `xorm:"TEXT"` Events string `xorm:"TEXT"` *HookEvent `xorm:"-"` - IsSSL bool `xorm:"is_ssl"` - IsActive bool `xorm:"INDEX"` - HookTaskType HookTaskType - Meta string `xorm:"TEXT"` // store hook-specific attributes - LastStatus HookStatus // Last delivery status + IsSSL bool `xorm:"is_ssl"` + IsActive bool `xorm:"INDEX"` + Type HookTaskType `xorm:"char(16) 'type'"` + Meta string `xorm:"TEXT"` // store hook-specific attributes + LastStatus HookStatus // Last delivery status CreatedUnix timeutil.TimeStamp `xorm:"INDEX created"` UpdatedUnix timeutil.TimeStamp `xorm:"INDEX updated"` -- cgit v1.2.3