mirror of
https://github.com/go-gitea/gitea.git
synced 2026-03-28 06:42:29 +01:00
1. remove `TEST_CONFLICTING_PATCHES_WITH_GIT_APPLY` * it defaults to false and is unlikely to be useful for most users (see #22130) * with new git versions (>= 2.40), "merge-tree" is used, "checkConflictsByTmpRepo" isn't called, the option does nothing. 2. fix fragile `db.Cell2Int64` (new: `CellToInt`) 3. allow more routes in maintenance mode (e.g.: captcha) 4. fix MockLocale html escaping to make it have the same behavior as production locale
87 lines
2.1 KiB
Go
87 lines
2.1 KiB
Go
// Copyright 2019 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package db
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"code.gitea.io/gitea/modules/setting"
|
|
|
|
"xorm.io/xorm"
|
|
"xorm.io/xorm/convert"
|
|
"xorm.io/xorm/schemas"
|
|
)
|
|
|
|
// ConvertDatabaseTable converts database and tables from utf8 to utf8mb4 if it's mysql and set ROW_FORMAT=dynamic
|
|
func ConvertDatabaseTable() error {
|
|
if xormEngine.Dialect().URI().DBType != schemas.MYSQL {
|
|
return nil
|
|
}
|
|
|
|
r, err := CheckCollations(xormEngine)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
_, err = xormEngine.Exec(fmt.Sprintf("ALTER DATABASE `%s` CHARACTER SET utf8mb4 COLLATE %s", setting.Database.Name, r.ExpectedCollation))
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
tables, err := xormEngine.DBMetas()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
for _, table := range tables {
|
|
if _, err := xormEngine.Exec(fmt.Sprintf("ALTER TABLE `%s` ROW_FORMAT=dynamic", table.Name)); err != nil {
|
|
return err
|
|
}
|
|
|
|
if _, err := xormEngine.Exec(fmt.Sprintf("ALTER TABLE `%s` CONVERT TO CHARACTER SET utf8mb4 COLLATE %s", table.Name, r.ExpectedCollation)); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// ConvertVarcharToNVarchar converts database and tables from varchar to nvarchar if it's mssql
|
|
func ConvertVarcharToNVarchar() error {
|
|
if xormEngine.Dialect().URI().DBType != schemas.MSSQL {
|
|
return nil
|
|
}
|
|
|
|
sess := xormEngine.NewSession()
|
|
defer sess.Close()
|
|
res, err := sess.QuerySliceString(`SELECT 'ALTER TABLE ' + OBJECT_NAME(SC.object_id) + ' MODIFY SC.name NVARCHAR(' + CONVERT(VARCHAR(5),SC.max_length) + ')'
|
|
FROM SYS.columns SC
|
|
JOIN SYS.types ST
|
|
ON SC.system_type_id = ST.system_type_id
|
|
AND SC.user_type_id = ST.user_type_id
|
|
WHERE ST.name ='varchar'`)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
for _, row := range res {
|
|
if len(row) == 1 {
|
|
if _, err = sess.Exec(row[0]); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
}
|
|
return err
|
|
}
|
|
|
|
// CellToInt converts a xorm.Cell field value to an int value
|
|
func CellToInt[T ~int | int64](cell xorm.Cell, def T) (ret T, has bool, err error) {
|
|
if *cell == nil {
|
|
return def, false, nil
|
|
}
|
|
val, err := convert.AsInt64(*cell)
|
|
if err != nil {
|
|
return def, false, err
|
|
}
|
|
return T(val), true, err
|
|
}
|