c572fcfe04
Rename the Go module path from code.gitea.io/gitea to git.mokoconsulting.tech/MokoConsulting/MokoGitea across the entire codebase. Scope: - go.mod module declaration - 2,235 Go source files (import paths) - Dockerfile WORKDIR and COPY paths - Swagger API templates - golangci.yml linter config External dependencies (code.gitea.io/gitea-vet, code.gitea.io/sdk/gitea, gitea.com/gitea/act, etc.) are intentionally NOT renamed — they are separate upstream modules. Closes #132 Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
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"
|
|
|
|
"git.mokoconsulting.tech/MokoConsulting/MokoGitea/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
|
|
}
|