diff options
author | Lunny Xiao <xiaolunwen@gmail.com> | 2021-01-06 23:11:23 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-01-06 16:11:23 +0100 |
commit | 9f73cae6358c9647cf64589eb2ce055f3dd07f38 (patch) | |
tree | 8ed003cd1434f46c3fc5d3aa518084eb4bdb30a6 /models/migrations/v165.go | |
parent | d2ee1221cc7f52c8063e764b6515fbe4e83db517 (diff) | |
download | gitea-9f73cae6358c9647cf64589eb2ce055f3dd07f38.tar.gz gitea-9f73cae6358c9647cf64589eb2ce055f3dd07f38.zip |
Fix wrong type on hooktask to convert typ from char(16) to varchar(16) (#14148)
* Fix wrong type on hooktask to convert typ from char(16) to varchar(16)
* Fix bugs
* Improve code
* Use different trim function for MSSQL
* Fix bug
* Removed wrong changed line
* Removed wrong changed line
* Fix nullable
* Fix lint
* Ignore sqlite on migration
* Fix mssql modify column failure
* Move modifyColumn to migrations.go so that other migrate function could use it
Diffstat (limited to 'models/migrations/v165.go')
-rw-r--r-- | models/migrations/v165.go | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/models/migrations/v165.go b/models/migrations/v165.go new file mode 100644 index 0000000000..d7df0f07a9 --- /dev/null +++ b/models/migrations/v165.go @@ -0,0 +1,66 @@ +// 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" + "xorm.io/xorm/schemas" +) + +func convertHookTaskTypeToVarcharAndTrim(x *xorm.Engine) error { + dbType := x.Dialect().URI().DBType + if dbType == schemas.SQLITE { // For SQLITE, varchar or char will always be represented as TEXT + return nil + } + + type HookTask struct { + Typ string `xorm:"VARCHAR(16) index"` + } + + if err := modifyColumn(x, "hook_task", &schemas.Column{ + Name: "typ", + SQLType: schemas.SQLType{ + Name: "VARCHAR", + }, + Length: 16, + Nullable: true, // To keep compatible as nullable + }); err != nil { + return err + } + + var hookTaskTrimSQL string + if dbType == schemas.MSSQL { + hookTaskTrimSQL = "UPDATE hook_task SET typ = RTRIM(LTRIM(typ))" + } else { + hookTaskTrimSQL = "UPDATE hook_task SET typ = TRIM(typ)" + } + if _, err := x.Exec(hookTaskTrimSQL); err != nil { + return err + } + + type Webhook struct { + Type string `xorm:"VARCHAR(16) index"` + } + + if err := modifyColumn(x, "webhook", &schemas.Column{ + Name: "type", + SQLType: schemas.SQLType{ + Name: "VARCHAR", + }, + Length: 16, + Nullable: true, // To keep compatible as nullable + }); err != nil { + return err + } + + var webhookTrimSQL string + if dbType == schemas.MSSQL { + webhookTrimSQL = "UPDATE webhook SET type = RTRIM(LTRIM(type))" + } else { + webhookTrimSQL = "UPDATE webhook SET type = TRIM(type)" + } + _, err := x.Exec(webhookTrimSQL) + return err +} |