mirror of https://github.com/go-gitea/gitea.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
56 lines
1.6 KiB
56 lines
1.6 KiB
// Copyright 2019 The Gitea Authors. All rights reserved. |
|
// SPDX-License-Identifier: MIT |
|
|
|
package cmd |
|
|
|
import ( |
|
"fmt" |
|
|
|
"code.gitea.io/gitea/models/db" |
|
"code.gitea.io/gitea/modules/log" |
|
"code.gitea.io/gitea/modules/setting" |
|
|
|
"github.com/urfave/cli/v2" |
|
) |
|
|
|
// cmdDoctorConvert represents the available convert sub-command. |
|
var cmdDoctorConvert = &cli.Command{ |
|
Name: "convert", |
|
Usage: "Convert the database", |
|
Description: "A command to convert an existing MySQL database from utf8 to utf8mb4 or MSSQL database from varchar to nvarchar", |
|
Action: runDoctorConvert, |
|
} |
|
|
|
func runDoctorConvert(ctx *cli.Context) error { |
|
stdCtx, cancel := installSignals() |
|
defer cancel() |
|
|
|
if err := initDB(stdCtx); err != nil { |
|
return err |
|
} |
|
|
|
log.Info("AppPath: %s", setting.AppPath) |
|
log.Info("AppWorkPath: %s", setting.AppWorkPath) |
|
log.Info("Custom path: %s", setting.CustomPath) |
|
log.Info("Log path: %s", setting.Log.RootPath) |
|
log.Info("Configuration file: %s", setting.CustomConf) |
|
|
|
switch { |
|
case setting.Database.Type.IsMySQL(): |
|
if err := db.ConvertDatabaseTable(); err != nil { |
|
log.Fatal("Failed to convert database & table: %v", err) |
|
return err |
|
} |
|
fmt.Println("Converted successfully, please confirm your database's character set is now utf8mb4") |
|
case setting.Database.Type.IsMSSQL(): |
|
if err := db.ConvertVarcharToNVarchar(); err != nil { |
|
log.Fatal("Failed to convert database from varchar to nvarchar: %v", err) |
|
return err |
|
} |
|
fmt.Println("Converted successfully, please confirm your database's all columns character is NVARCHAR now") |
|
default: |
|
fmt.Println("This command can only be used with a MySQL or MSSQL database") |
|
} |
|
|
|
return nil |
|
}
|
|
|